/* mckinney.life theme — purple / pink / lavender */
:root{
  --bg:#ffffff;
  --page:#f3e5f5;
  --ink:#1a0d24;
  --muted:#5b4a66;
  --line:#e1c7ec;
  --purple:#3d1a5a;
  --purple-ink:#2a0f42;
  --pink:#e91e63;
  --pink-dark:#c2185b;
  --lav:#f3e5f5;
  --nav-strip:#2a0f42;
  --mckinney-coral:#e9547d;
  --b:#fff;
  --mx:min(1180px,94vw);
  --acc:var(--pink);
  --acc-dark:var(--pink-dark);
  --nav-on:rgba(233,30,99,.12);
}
*,*::before,*::after{box-sizing:border-box}
html{background:var(--page);scroll-behavior:smooth}
body{margin:0;font:16px/1.55 Inter,system-ui,Segoe UI,Arial,sans-serif;color:var(--ink);background:var(--page)}
a{color:var(--purple)}a:hover{color:var(--pink-dark);text-decoration:underline}
img{max-width:100%;display:block}
.skip{position:absolute;left:-9999px;top:8px;background:var(--b);padding:8px}.skip:focus{left:8px;z-index:99;outline:2px solid var(--pink)}
.vhide{position:absolute;width:1px;height:1px;clip:rect(0,0,0,0);overflow:hidden}
.shell{max-width:var(--mx);margin:0 auto;padding:0 20px}
.muted{color:#c5b8cf}

/* header */
.site-header{position:sticky;top:0;z-index:20;background:var(--b);box-shadow:0 6px 18px rgba(45,10,70,.06)}
.header-top{display:flex;align-items:center;justify-content:space-between;padding:12px 0 10px;position:relative}
.header-logo{display:block;line-height:0;text-decoration:none}
.header-logo img{height:clamp(34px,4.8vw,48px);width:auto;max-width:min(320px,72vw)}
.nav-strip{background:var(--nav-strip);border-top:1px solid #3d1a5a}
.nav-strip-inner{padding:6px 0 0}
.nav-toggle{display:none;border:1px solid var(--line);background:var(--b);border-radius:6px;padding:6px 10px;cursor:pointer;font:700 16px/1 Inter,sans-serif;color:var(--purple)}
.main-nav{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(6px,1.6vw,16px)}
.main-nav .nb{
  color:#fff;
  text-decoration:none;
  font-weight:700;
  font-size:0.88rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:12px 14px 10px;
  border-radius:0;
  border-bottom:3px solid transparent;
  background:transparent;
  box-sizing:border-box;
}
.main-nav .nb:hover{
  color:var(--mckinney-coral);
  border-bottom-color:var(--mckinney-coral);
  text-decoration:none;
}
.main-nav .nb:focus-visible{
  color:var(--mckinney-coral);
  border-bottom-color:var(--mckinney-coral);
  text-decoration:none;
  outline:2px solid var(--mckinney-coral);
  outline-offset:4px;
}
.main-nav .nb.on{
  color:var(--mckinney-coral);
  border-bottom-color:var(--mckinney-coral);
}
.nd-menu{background:#fff;border:1px solid var(--line)}
.nd-menu a{color:var(--ink) !important}

.nd{position:relative;display:flex;align-items:center;gap:2px}
.nd::after{content:"";position:absolute;left:0;right:0;top:100%;height:8px;}
.nd-link{padding-right:8px}
.nd-menu{display:none;position:absolute;top:calc(100% - 1px);left:0;z-index:30;min-width:280px;margin:0;padding:6px 0;list-style:none;border-radius:8px;box-shadow:0 12px 30px rgba(15,23,42,.18);text-align:left}
.nd-menu li{margin:0}
.nd-menu a{display:block;padding:7px 10px;text-decoration:none;font:500 0.84rem/1.3 Inter,system-ui,sans-serif;}
.nd-menu a:hover{background:var(--page);text-decoration:none}
.nd:hover .nd-menu,.nd:focus-within .nd-menu,.nd.open .nd-menu{display:block}

@media(max-width:900px){
  .nav-toggle{display:block}
  .main-nav{display:none;flex-direction:column;width:100%;align-items:stretch;padding:10px 0 14px}
  .main-nav.is-open{display:flex}
  .main-nav .nb{text-align:center}
  .nd{flex-wrap:wrap;justify-content:center}
  .nd-link{flex:1;text-align:center}
  .nd-menu{position:static;display:none;min-width:0;width:100%;margin:0 0 6px;box-shadow:none}
  .nd.open .nd-menu{display:block}
  .nd:hover .nd-menu,.nd:focus-within .nd-menu{display:none}
  .nd.open:hover .nd-menu,.nd.open:focus-within .nd-menu{display:block}
}

/* mckinney home — full-bleed cycling panorama + left purple wash (mockup) */
:root{--mckinney-plum:#2b103d;}
.mckinney-mck{
  position:relative;
  width:100vw;
  left:50%;
  right:50%;
  margin-left:-50vw;
  margin-right:-50vw;
  color:#fff;
  border-bottom:1px solid #1a0a24;
  background-color:var(--mckinney-plum);
  background-image:
    linear-gradient(90deg,
      rgba(43,16,61,0.98) 0%,
      rgba(43,16,61,0.95) 18%,
      rgba(43,16,61,0.78) 34%,
      rgba(43,16,61,0.45) 52%,
      rgba(43,16,61,0.15) 68%,
      rgba(43,16,61,0) 82%),
    url('/images/mckinney/mckinney-cycling-bg.png');
  background-repeat:no-repeat,no-repeat;
  background-size:cover,cover;
  background-position:center right,center center;
  min-height:clamp(360px,48vw,560px);
  display:flex;
  flex-direction:column;
}
.mckinney-mck-inner{
  position:relative;
  z-index:1;
  flex:1;
  max-width:var(--mx);
  width:100%;
  margin:0 auto;
  padding:clamp(22px,4vw,40px) 20px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  min-height:0;
}
.mckinney-copy{max-width:min(36rem,92vw)}
.mckinney-prefix{
  margin:0 0 6px;
  font-size:clamp(1.65rem,4.2vw,2.85rem);
  font-weight:800;
  line-height:1.06;
  letter-spacing:-.025em;
  color:var(--mckinney-coral);
}
.mckinney-title{
  margin:0 0 14px;
  font-size:clamp(1.65rem,4.2vw,2.85rem);
  line-height:1.06;
  font-weight:800;
  letter-spacing:-.025em;
  color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.25);
}
.mckinney-lead{
  margin:0 0 12px;
  max-width:42rem;
  font-size:clamp(0.95rem,1.55vw,1.12rem);
  line-height:1.55;
  font-weight:400;
  color:#fff;
  opacity:0.96;
  text-shadow:0 1px 2px rgba(0,0,0,.2);
}
.mckinney-meta{
  margin:0 0 20px;
  font-size:0.9rem;
  line-height:1.45;
  font-weight:500;
  color:#fff;
  opacity:0.88;
}
.mckinney-cta{margin:0}
.btn-mckinney{
  display:inline-block;
  background:var(--mckinney-coral);
  color:#fff !important;
  padding:12px 28px;
  border-radius:999px;
  font-weight:800;
  font-size:0.95rem;
  letter-spacing:0.02em;
  text-decoration:none;
  border:0;
  box-shadow:0 6px 20px rgba(233,84,125,.45);
}
.btn-mckinney:hover{filter:brightness(1.06);text-decoration:none;color:#fff}
@media(max-width:640px){
  .mckinney-mck{background-position:center,center 30%}
}

/* worth reading */
.home-main{padding-bottom:40px}
.worth-reading{padding:32px 0 8px}
.worth-cols{display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:720px){.worth-cols{grid-template-columns:1fr}}
.worth-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:16px}
.worth-a{display:block;font-weight:700;color:var(--purple-ink);text-decoration:none;font-size:1.02rem}
.worth-a:hover{color:var(--pink-dark);text-decoration:underline}
.worth-date{display:block;font-size:12.5px;color:var(--muted);margin-top:4px}

/* lavender sections */
.section-lav{background:var(--lav);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.dark-purple{color:var(--purple)}
.seo-sub{margin:0 0 14px;font-weight:600;color:var(--purple);font-size:1.05rem}
.seo-columns{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:900px){.seo-columns{grid-template-columns:1fr}}
.seo-columns p{margin:0;color:#3b2f46;line-height:1.7}
.seo-columns .seo-col p{margin:0 0 14px}
.seo-columns .seo-col p:last-child{margin-bottom:0}

.editorial-home .shell{padding:28px 20px 34px}
.events-block .shell{padding:28px 20px 34px}
.events-grid{display:grid;grid-template-columns:1fr;gap:18px;align-items:start}
@media(max-width:960px){.events-grid{grid-template-columns:1fr}}
.events-collage{display:grid;grid-template-columns:1.1fr 0.9fr;gap:10px;min-height:220px}
.collage-big{border-radius:12px;min-height:220px}
.collage-small{display:flex;flex-direction:column;gap:10px}
.ph-box{border-radius:12px;background:linear-gradient(145deg,#3d1a5a,#6a1b9a);color:#f3e5f5;display:flex;align-items:center;justify-content:center;font-weight:800;letter-spacing:.06em;border:1px solid rgba(255,255,255,.12)}
.ph-box.sm{min-height:100px;font-size:0.9rem}
.events-list{list-style:none;margin:12px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.events-list li{display:flex;gap:10px;align-items:flex-start;color:#2f2438;font-size:0.98rem}
.events-list-wrap--full{max-width:min(920px,96vw)}
.events-sub{margin:6px 0 0;font-size:0.92rem;color:#5b4a66}
.events-sub a{color:var(--purple);font-weight:700;text-decoration:none}
.events-sub a:hover{text-decoration:underline}
.ev-cat{font-weight:700}
.ev-loc{color:#5b4a66;font-weight:500}
.ev-phase{font-weight:600;color:#4a2f66}

.page-events{padding:28px 0 40px}
.page-events .page-head{margin:0 0 22px;max-width:min(52rem,94vw)}
.page-events .lead{margin:10px 0 0;color:#5b4a66;line-height:1.55}
.events-page-list{margin-top:10px}
.events-ol{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:14px;counter-reset:ev}
.events-ol-item{display:grid;grid-template-columns:140px minmax(0,1fr);gap:14px;align-items:start;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fff}
@media(max-width:640px){.events-ol-item{grid-template-columns:1fr}}
.ev-date{font-weight:800;color:var(--purple);letter-spacing:.02em}
.ev-title{margin:0;font-weight:700;color:#1a0d24}
.ev-meta{margin:6px 0 0;font-size:0.92rem;color:#5b4a66}


.ev-icon{color:var(--pink);font-size:12px;line-height:1.6}

/* home faq */
.home-faq{background:var(--b);padding:26px 20px 40px;border-top:1px solid var(--line)}
.home-faq .faq{margin-top:8px}

/* layout */
.grid-main{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:28px;align-items:start;padding:26px 0 10px}
@media(max-width:1023px){.grid-main{grid-template-columns:1fr}}
.h-sec{margin:0 0 14px;font-size:1.12rem;letter-spacing:.01em;font-weight:800;color:var(--purple-ink)}
.h1-sec{margin:0 0 6px;font-size:clamp(22px,2.2vw,28px)}
.bc{font:13px/1.2 Inter;color:#6b7280;margin:16px 0}
.bc .b-h{color:var(--ink);font-weight:600}
.le{color:var(--muted);margin:0 0 18px}

/* cards */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.cards-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards-3{grid-template-columns:1fr}}
.card{background:var(--b);border:1px solid var(--line);border-radius:10px;padding:12px;display:flex;flex-direction:column;box-shadow:0 1px 0 rgba(0,0,0,.04)}
.c-img{line-height:0}
.c-img img{width:100%;height:200px;object-fit:cover;border-radius:6px;background:#ede7f6}
.c-title{margin:6px 0 4px;font-size:1.02rem}
.c-title a{text-decoration:none;color:var(--ink);font-weight:700}
.c-title a:hover{text-decoration:underline;color:var(--pink-dark)}
.tag{font:700 11px/1.35 Inter,sans-serif;letter-spacing:0.04em;color:var(--pink);margin:8px 0 0;text-transform:none}
.ex{flex:1;font-size:.95rem;margin:0 0 6px;color:var(--muted)}
.by{font-size:12.5px;color:#6b7280;margin:0}
.by a{color:var(--purple);text-decoration:none;font-weight:600}
.by a:hover{text-decoration:underline}

/* sidebar */
.widget{background:var(--b);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:0 0 14px}
.widget h3{margin:0 0 8px;font-size:15px;font-weight:800;letter-spacing:.01em;color:var(--purple)}
.pop-list{margin:0;padding-left:1.1rem;color:var(--ink)}
.pop-list a{color:var(--ink);text-decoration:none;font-weight:600}
.pop-list a:hover{color:var(--pink-dark)}
.q{font-size:13px;color:var(--muted);margin:0 0 8px}
.dow{display:flex;justify-content:space-between;font-size:11px;font-weight:700;color:var(--muted);margin:0 0 6px;padding:0 2px}
.heat{display:flex;gap:4px;flex-wrap:wrap}
.heat span{flex:1;min-width:10px;height:22px;border-radius:4px;background:var(--pink)}
.heat .b0{opacity:.28}.heat .b1{opacity:.48}.heat .b2{opacity:.72}
.side-auth{display:grid;grid-template-columns:72px 1fr;gap:12px;align-items:start;margin-top:4px}
.side-auth-img{border-radius:50%;object-fit:cover;border:1px solid var(--line)}
.side-auth-name{margin:0 0 4px;font-weight:700}
.side-auth-name a{color:var(--ink);text-decoration:none}
.side-auth-name a:hover{color:var(--pink-dark)}
.side-auth-bio{margin:0;font-size:13px;color:var(--muted);line-height:1.45}

.btn{display:inline-block;background:var(--purple);color:#f8fafc;padding:8px 14px;border-radius:6px;font:600 13px Inter,sans-serif;text-decoration:none;border:0}
.btn:hover{opacity:.92;text-decoration:none;color:#fff}

/* post */
.post-wrap{max-width:min(1000px,94vw);padding:10px 0 40px}
.ymyl{background:#fff8db;border-left:3px solid #b45309;padding:10px 12px;font-size:0.95rem;margin:10px 0}
.ph{max-width:100ch}
.k{font:700 11px Inter;color:var(--pink);letter-spacing:.08em;text-transform:none;margin:0}
.ph h1{margin:6px 0 8px;font-size:clamp(1.45rem,3vw,2rem);color:var(--purple-ink)}
.dek{color:var(--muted);margin:0 0 8px}
.ph .byline{font-size:0.92rem;color:#6b7280}
.ph .byline a{color:var(--purple);font-weight:600}
.post-cover{margin:12px 0}
.pimg{width:100%;max-height:520px;object-fit:cover;border-radius:8px;border:1px solid var(--line);background:#ede7f6}
.pro{max-width:70ch;font-size:1.05rem}
.pro p{margin:0 0 0.85em;color:#243036;line-height:1.65}
.pro h2{margin:1.15em 0 0.45em;font-size:1.2rem;color:var(--purple-ink)}
.edit-note{color:#334155;font:0.95rem/1.35 Georgia,"Times New Roman",serif;margin:0 0 0.35em}

.ref,.faq{margin:1.2rem 0;max-width:75ch}
.faq h2{margin:0 0 0.35em;font-size:1.15rem}
.q button{
  all:initial;
  font:700 0.95rem/1.2 Inter,sans-serif;
  display:flex;justify-content:space-between;align-items:center;width:100%;text-align:left;padding:0.55rem 0.65rem;border:1px solid var(--line);
  background:#fff;border-radius:6px;cursor:pointer;color:var(--ink);box-sizing:border-box;
}
.q button::after{content:"▾";font-size:12px;color:var(--pink)}
.faq .a{border:1px solid var(--line);border-top:0;padding:0.5rem 0.65rem;border-radius:0 0 6px 6px;background:#fafafa}

.auth-box{max-width:100%;display:grid;grid-template-columns:72px 1fr;gap:12px;border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--b);margin-top:1.5rem}
.aimg{width:72px;height:72px;border-radius:50%;object-fit:cover;border:1px solid var(--line)}
.ab-h{margin:0 0 4px;font-size:1rem}
.a-n{margin:0 0 6px;font-size:0.95rem}
.a-bio{margin:0;font-size:0.92rem;color:var(--muted);line-height:1.45}

/* footer */
.site-footer{background:#120818;color:#e8dff5;margin-top:10px;padding:26px 0 34px;border-top:1px solid #000}
.footer-inner{max-width:var(--mx);margin:0 auto;padding:0 20px}
.footer-nav{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:center;font-size:0.95rem}
.footer-nav a{color:#fff;text-decoration:none;font-weight:600}
.footer-nav a:hover{color:#ffb3d0;text-decoration:underline}
.f-dot{opacity:.35}
.footer-bottom{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;margin-top:18px}
.f-copy{margin:0;font-size:13px;color:#cbbad8}
.f-disclaimer{margin:14px auto 0;max-width:52rem;padding:0 8px;font-size:12px;line-height:1.55;color:#b8a8c9;text-align:center}
.f-disclaimer a{color:#e8d4f5;text-decoration:underline;font-weight:600}
.f-disclaimer a:hover{color:#ffb3d0}

/* static docs */
.doc{background:var(--b);border:1px solid var(--line);border-radius:10px;padding:22px 22px 30px;margin:22px auto;box-shadow:0 1px 0 rgba(0,0,0,.03)}
.doc h1{margin-top:0;color:var(--purple-ink)}
.doc h2{margin-top:1.4em;font-size:1.15rem;color:var(--purple)}
.doc p{line-height:1.65;color:#333}

/* search + misc */
.cform label{font-weight:600}
input,textarea{font:inherit}
.page-wrap{min-height:50vh}

/* .btn would override .btn-mckinney background — combined selector fixes it */
.btn.btn-mckinney{background:var(--mckinney-coral)!important;color:#fff!important;padding:12px 28px;border-radius:999px;font-weight:800;font-size:0.95rem;letter-spacing:0.02em;box-shadow:0 6px 20px rgba(233,84,125,.45)}
.btn.btn-mckinney:hover{filter:brightness(1.06);opacity:1;text-decoration:none;color:#fff!important}


/* Home FAQ: always-visible Q&A (no accordion) */
.faq.faq-visible{max-width:min(920px,96vw);margin-left:auto;margin-right:auto}
.faq.faq-visible .faq-q{margin:0;padding:0.6rem 0.75rem;border:1px solid var(--line);border-bottom:0;border-radius:8px 8px 0 0;background:#fff;font:700 0.98rem/1.45 Inter,system-ui,sans-serif;color:var(--purple-ink)}
.faq.faq-visible .a{border-radius:0 0 8px 8px;padding:0.65rem 0.75rem 0.75rem}
.faq.faq-visible .a p{margin:0;color:#2f2438;line-height:1.65}
.faq.faq-visible .ac-item{margin-bottom:18px}
