/* ==========================================================================
   Knight Owls — site stylesheet
   Brand: Covenant + Knight Owls Extension palette
   Type:  Mulish (Avenir Next near-match) headlines/UI · EB Garamond body
   Contrast rule: dark ink on light surfaces; light text only on dark surfaces.
   ========================================================================== */

:root{
  /* palette */
  --forest:#091f2c;      /* Forest Night  — primary dark */
  --forest-2:#13344a;
  --slate:#5c82a5;       /* Mountain Slate */
  --gold:#d7a048;        /* Campfire Gold — signature accent */
  --gold-d:#b9842f;
  --stone:#cfb991;       /* Warm Stone */
  --red:#931a1d;         /* Covenant Red */
  --red-d:#6f1416;
  --antique:#9a8749;

  /* surfaces & ink (legibility-checked) */
  --paper:#faf7f1;       /* warm page background */
  --card:#ffffff;
  --cream:#f2ebdd;
  --line:#e6ddcc;
  --ink:#2c2a29;         /* Covenant Black — body & headings on light */
  --muted:#5d5648;       /* secondary text on light (AA on paper) */

  /* on-dark text */
  --on-dark:#ffffff;
  --on-dark-soft:#c4d0d9;

  --sans:'Mulish','Avenir Next','Avenir',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --serif:'EB Garamond',Garamond,Georgia,'Times New Roman',serif;

  --maxw:1180px;
  --radius:14px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--serif);
  font-size:18px;
  line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,.sans,.eyebrow,.btn,.badge,.nav,.main-nav,.gmeta,.kicker,.gr,.logo-text{
  font-family:var(--sans);
}
h1,h2,h3,h4{color:var(--ink);letter-spacing:-.01em;line-height:1.15;}
a{color:var(--red);}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Header / traditional nav ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:var(--forest);
  border-bottom:1px solid rgba(255,255,255,.06);
  box-shadow:0 2px 14px -8px rgba(0,0,0,.5);
}
.header-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 24px;height:70px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;flex:none;}
.logo img{width:40px;height:40px;}
.logo-text{color:#fff;font-weight:800;letter-spacing:.17em;font-size:16px;}
.main-nav{display:flex;align-items:center;gap:4px;}
.main-nav a{
  color:#e7ecf0;font-weight:600;font-size:14px;text-decoration:none;
  padding:9px 14px;border-radius:8px;transition:background .15s,color .15s;white-space:nowrap;
}
.main-nav a:hover{color:#fff;background:rgba(255,255,255,.09);}
.main-nav a.active{color:var(--gold);}
.main-nav a.active:hover{background:rgba(215,160,72,.12);}
.main-nav .nav-cta{
  background:var(--gold);color:var(--forest);font-weight:800;padding:9px 17px;margin-left:8px;
}
.main-nav .nav-cta:hover{background:#e7b15a;color:var(--forest);}
.nav-toggle{
  display:none;background:none;border:1.5px solid rgba(255,255,255,.35);border-radius:8px;
  width:42px;height:38px;cursor:pointer;color:#fff;font-size:18px;line-height:1;
}
@media(max-width:940px){
  .nav-toggle{display:flex;align-items:center;justify-content:center;}
  .main-nav{
    position:fixed;top:70px;left:0;right:0;
    background:var(--forest);flex-direction:column;align-items:stretch;gap:2px;
    padding:12px 16px 20px;border-bottom:1px solid rgba(255,255,255,.1);
    display:none;
  }
  .main-nav.open{display:flex;}
  .main-nav a{padding:13px 14px;font-size:15px;}
  .main-nav .nav-cta{margin:8px 0 0;text-align:center;}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-weight:800;font-size:14px;text-decoration:none;
  padding:13px 24px;border-radius:9px;cursor:pointer;border:none;transition:transform .12s,box-shadow .12s,background .15s;
}
.btn:hover{transform:translateY(-1px);}
.btn-gold{background:var(--gold);color:var(--forest);box-shadow:0 10px 22px -10px rgba(215,160,72,.75);}
.btn-gold:hover{background:#e7b15a;}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 22px -12px rgba(147,26,29,.7);}
.btn-red:hover{background:#a8232a;}
.btn-ghost-light{background:rgba(255,255,255,.10);color:#fff;border:1.5px solid rgba(255,255,255,.55);}
.btn-ghost-light:hover{background:rgba(255,255,255,.18);}
.btn-outline{background:transparent;color:var(--red);border:1.6px solid var(--red);}
.btn-outline:hover{background:var(--red);color:#fff;}

/* ---------- Sections ---------- */
.section{padding:64px 0;}
.section.tight{padding:40px 0;}
.eyebrow{color:var(--red);font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin:0 0 12px;}
.section h2{font-size:34px;font-weight:800;margin:0 0 12px;}
.lead{color:var(--muted);font-size:20px;max-width:620px;margin:0 0 8px;line-height:1.5;}

/* sections on dark */
.section--dark{background:var(--forest);color:var(--on-dark);}
.section--dark h2{color:#fff;}
.section--dark .eyebrow{color:var(--gold);}
.section--dark .lead{color:var(--on-dark-soft);}

/* ---------- Hero (Knight Skies) ---------- */
.hero{
  position:relative;min-height:460px;display:flex;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;color:#fff;
  background:
    radial-gradient(1.6px 1.6px at 16% 22%, rgba(255,255,255,.95), transparent),
    radial-gradient(1.4px 1.4px at 28% 14%, rgba(215,160,72,.9), transparent),
    radial-gradient(1.3px 1.3px at 61% 17%, rgba(255,255,255,.85), transparent),
    radial-gradient(1.7px 1.7px at 80% 25%, rgba(215,160,72,.8), transparent),
    radial-gradient(2px 2px at 45% 10%, rgba(255,255,255,.9), transparent),
    radial-gradient(1.3px 1.3px at 89% 13%, rgba(255,255,255,.8), transparent),
    linear-gradient(180deg,#091f2c 0%,#13344a 34%,#3a5d7b 58%,#091f2c 100%);
}
.hero .ridge{position:absolute;left:0;right:0;bottom:0;height:150px;background:var(--forest);
  clip-path:polygon(0 55%,12% 38%,24% 52%,38% 26%,52% 48%,66% 30%,80% 50%,92% 36%,100% 52%,100% 100%,0 100%);}
.hero .ridge2{position:absolute;left:0;right:0;bottom:0;height:100px;background:#050f17;opacity:.7;
  clip-path:polygon(0 70%,18% 50%,33% 66%,50% 44%,67% 64%,83% 48%,100% 66%,100% 100%,0 100%);}
.hero-photo-note{position:absolute;top:14px;right:16px;font-family:var(--sans);font-size:11px;
  color:rgba(255,255,255,.82);background:rgba(0,0,0,.3);padding:4px 10px;border-radius:20px;}
.hero-inner{position:relative;z-index:2;padding:48px 22px;max-width:640px;}
.kicker{color:var(--gold);font-family:var(--sans);font-size:12.5px;letter-spacing:.24em;
  text-transform:uppercase;font-weight:700;margin-bottom:16px;}
.hero h1{color:#fff;font-size:46px;font-weight:800;margin:0 0 18px;letter-spacing:-.02em;
  text-shadow:0 2px 22px rgba(0,0,0,.4);}
.hero p{color:#eef1f3;font-size:20px;margin:0 0 28px;line-height:1.5;}
.hero .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
@media(max-width:640px){.hero h1{font-size:33px;}.hero p{font-size:17px;}}

/* ---------- Pillars ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.card-soft{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;}
.picon{width:48px;height:48px;border-radius:12px;background:#f4ebda;display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.card-soft h3{font-size:21px;font-weight:800;margin:0 0 8px;}
.card-soft p{color:var(--muted);font-size:17px;margin:0;line-height:1.5;}

/* ---------- Journey arc ---------- */
.arc{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:34px;position:relative;}
.arc::before{content:"";position:absolute;top:14px;left:11%;right:11%;height:2px;
  background:linear-gradient(90deg,var(--slate),var(--gold));opacity:.8;}
.node{text-align:center;position:relative;padding:0 10px;}
.node .pip{width:28px;height:28px;border-radius:50%;background:var(--gold);border:3px solid var(--forest);
  margin:0 auto 16px;position:relative;z-index:2;box-shadow:0 0 0 3px rgba(215,160,72,.28);}
.node h4{font-size:18px;font-weight:800;margin:0 0 4px;color:#fff;}
.node .gr{font-family:var(--sans);font-size:11px;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;font-weight:700;margin-bottom:8px;}
.node p{font-size:16px;color:var(--on-dark-soft);margin:0;line-height:1.45;}

/* ---------- Guide cards ---------- */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.guide-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  text-decoration:none;color:inherit;display:block;transition:transform .14s,box-shadow .14s;}
.guide-card:hover{transform:translateY(-3px);box-shadow:0 18px 34px -22px rgba(9,31,44,.45);}
.guide-thumb{height:150px;position:relative;display:flex;align-items:flex-end;padding:12px;}
.thumb-forest{background:linear-gradient(160deg,#5c82a5,#091f2c);}
.thumb-gold{background:linear-gradient(160deg,#d7a048,#8a5a23);}
.thumb-red{background:linear-gradient(160deg,#b5413f,#6f1416);}
.thumb-slate{background:linear-gradient(160deg,#7fa0bd,#33536e);}
.photo-note{position:absolute;top:9px;right:9px;font-family:var(--sans);font-size:9.5px;
  color:rgba(255,255,255,.9);background:rgba(0,0,0,.26);padding:2px 8px;border-radius:12px;}
.badge{background:rgba(255,255,255,.95);color:var(--forest);font-family:var(--sans);font-size:11px;
  font-weight:700;padding:5px 10px;border-radius:20px;letter-spacing:.02em;}
.guide-body{padding:16px 17px 19px;}
.guide-body h3{font-size:20px;font-weight:800;margin:0 0 6px;}
.gmeta{font-size:12.5px;color:var(--muted);display:flex;gap:8px;align-items:center;font-weight:600;}
.stars{color:var(--gold);letter-spacing:1px;}

/* ---------- Two doors ---------- */
.doors{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.door{border-radius:16px;padding:34px;color:#fff;text-decoration:none;display:block;transition:transform .14s;}
.door:hover{transform:translateY(-3px);}
.door.d-forest{background:linear-gradient(150deg,#13344a,#091f2c);}
.door.d-red{background:linear-gradient(150deg,#93202d,#6f1416);}
.door .eyebrow{color:rgba(255,255,255,.85);}
.door h3{font-size:26px;font-weight:800;margin:0 0 8px;color:#fff;}
.door p{font-size:17px;color:rgba(255,255,255,.92);margin:0 0 18px;line-height:1.5;}
.door .go{font-family:var(--sans);font-size:14px;font-weight:800;color:#fff;border-bottom:2px solid rgba(255,255,255,.55);padding-bottom:3px;}

/* ---------- Footer ---------- */
.site-footer{background:#06141d;color:#a9b7c1;padding:46px 0 38px;}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:28px;}
.site-footer .logo-text{color:#fff;}
.nonnobis{font-family:var(--serif);font-style:italic;color:var(--gold);font-size:19px;margin:10px 0 6px;}
.foot-disc{font-size:13px;color:#6c7a83;max-width:300px;line-height:1.5;}
.foot-col h5{font-family:var(--sans);color:#fff;font-size:13px;letter-spacing:.04em;margin:0 0 10px;text-transform:uppercase;}
.foot-col a{display:block;color:#a9b7c1;font-family:var(--sans);font-size:14px;text-decoration:none;margin:7px 0;}
.foot-col a:hover{color:#fff;}
.foot-cols{display:flex;gap:54px;flex-wrap:wrap;}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .grid-3,.guide-grid,.doors{grid-template-columns:1fr;}
  .arc{grid-template-columns:1fr 1fr;gap:24px 0;}
  .arc::before{display:none;}
  .section h2{font-size:28px;}
}
@media(max-width:520px){
  .arc{grid-template-columns:1fr;}
}

/* ---------- Interior page hero ---------- */
.page-hero{background:var(--forest);color:#fff;padding:50px 0;}
.page-hero .eyebrow{color:var(--gold);}
.page-hero h1{color:#fff;font-size:40px;font-weight:800;margin:0 0 10px;}
.page-hero p{color:var(--on-dark-soft);font-size:19px;max-width:640px;margin:0;line-height:1.5;}

/* ---------- Guides library: filters ---------- */
.filter-bar{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;
  padding:18px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:18px;}
.filter-field{display:flex;flex-direction:column;gap:6px;}
.filter-field.grow{flex:1;min-width:200px;}
.filter-field label{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
.filter-field select,.filter-field input{font-family:var(--sans);font-size:14px;padding:10px 12px;
  border:1px solid var(--line);border-radius:9px;background:var(--paper);color:var(--ink);}
.filter-field input{width:100%;}
.result-count{font-family:var(--sans);font-size:13px;color:var(--muted);margin:0 0 22px;font-weight:600;}
.empty{color:var(--muted);font-size:18px;padding:30px 0;grid-column:1/-1;}

/* ---------- Guide detail ---------- */
.guide-hero{position:relative;min-height:300px;display:flex;align-items:flex-end;color:#fff;overflow:hidden;}
.guide-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,31,44,.15),rgba(9,31,44,.78));}
.guide-hero-inner{position:relative;z-index:2;padding:36px 24px;width:100%;}
.breadcrumb{display:inline-block;color:rgba(255,255,255,.9);font-family:var(--sans);font-size:13px;font-weight:700;text-decoration:none;margin-bottom:14px;}
.breadcrumb:hover{color:#fff;}
.guide-hero h1{color:#fff;font-size:42px;font-weight:800;margin:0 0 16px;text-shadow:0 2px 18px rgba(0,0,0,.45);max-width:780px;}
.guide-meta-row{display:flex;gap:8px;flex-wrap:wrap;}
.guide-hero .photo-note{z-index:3;}

.guide-layout{display:grid;grid-template-columns:1fr 320px;gap:46px;max-width:var(--maxw);margin:0 auto;padding:50px 24px 72px;}
.guide-main h2{font-size:25px;font-weight:800;margin:32px 0 10px;}
.guide-main p{font-size:18px;color:var(--ink);margin:0 0 14px;line-height:1.65;}
.guide-why{font-size:20px;color:var(--ink);}
.packlist{columns:2;column-gap:26px;list-style:none;padding:0;margin:6px 0 0;}
.packlist li{font-size:16px;color:var(--ink);padding:6px 0 6px 26px;position:relative;break-inside:avoid;}
.packlist li::before{content:"\2610";position:absolute;left:0;color:var(--gold);font-size:17px;line-height:1.4;}
.resource-list{padding-left:18px;margin:6px 0 0;}
.resource-list li{font-size:16px;margin:7px 0;}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:10px 0 6px;}
.gallery-ph{aspect-ratio:4/3;border:1px dashed var(--line);border-radius:10px;background:var(--cream);
  display:flex;align-items:center;justify-content:center;color:var(--muted);font-family:var(--sans);font-size:12px;}
.gallery-img{aspect-ratio:4/3;width:100%;object-fit:cover;border-radius:10px;border:1px solid var(--line);display:block;cursor:zoom-in;transition:opacity .15s;}
.gallery-img:hover{opacity:.9;}
.ko-lightbox{position:fixed;inset:0;z-index:200;background:rgba(6,16,23,.93);display:none;align-items:center;justify-content:center;padding:20px;cursor:zoom-out;}
.ko-lightbox.open{display:flex;}
.ko-lightbox img{max-width:95vw;max-height:90vh;border-radius:8px;box-shadow:0 24px 70px rgba(0,0,0,.6);}
.lb-close{position:absolute;top:14px;right:20px;background:none;border:none;color:#fff;font-size:38px;line-height:1;cursor:pointer;}
@media(max-width:560px){.gallery{grid-template-columns:1fr 1fr;}}
.photo-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:26px;}
.photo-strip a{display:block;border-radius:8px;overflow:hidden;}
.photo-strip img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform .25s,opacity .2s;}
.photo-strip a:hover img{transform:scale(1.06);opacity:.92;}
@media(max-width:760px){.photo-strip{grid-template-columns:repeat(3,1fr);}}
@media(max-width:420px){.photo-strip{grid-template-columns:repeat(2,1fr);}}
.guide-thumb.has-photo{background-size:cover;background-position:center;}
.guide-hero.has-photo{background-size:cover;background-position:center;}
.hero--photo{background:linear-gradient(180deg,rgba(9,31,44,.48),rgba(9,31,44,.66)),url("assets/photos/home-hero.jpg");background-size:cover;background-position:center 45%;}

.guide-side{display:flex;flex-direction:column;gap:18px;}
.qf-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;}
.qf-card h4{font-family:var(--sans);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 12px;font-weight:800;}
.qf-row{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-top:1px solid var(--line);font-size:14px;}
.qf-row:first-of-type{border-top:none;padding-top:0;}
.qf-label{font-family:var(--sans);font-weight:700;color:var(--muted);flex:none;}
.qf-value{text-align:right;color:var(--ink);font-family:var(--serif);}
.linked a{display:block;font-family:var(--sans);font-size:14px;color:var(--red);text-decoration:none;margin:9px 0;font-weight:600;}
.linked a:hover{text-decoration:underline;}
.contrib p{font-size:14px;color:var(--muted);margin:0 0 10px;}
.suggest{font-family:var(--sans);font-size:13px;font-weight:800;color:var(--red);text-decoration:none;}
.qf-row.cost-total{border-top:2px solid var(--ink);}
.qf-row.cost-total .qf-label,.qf-row.cost-total .qf-value{font-weight:800;color:var(--ink);}
.cost-gear{font-size:13px;color:var(--muted);margin:12px 0 0;line-height:1.5;}
.cost-gear strong{font-family:var(--sans);color:var(--ink);}
.cost-note{font-size:14px;color:var(--ink);margin:0;}
.planning-callout{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  background:var(--forest);color:#fff;border-left:5px solid var(--gold);border-radius:14px;
  padding:18px 22px;margin:0 0 26px;text-decoration:none;transition:background .15s;}
.planning-callout:hover{background:#0c2738;}
.pc-text{display:flex;flex-direction:column;gap:3px;}
.pc-text strong{font-family:var(--sans);font-size:16px;font-weight:800;color:#fff;}
.pc-text span{font-size:14px;color:var(--on-dark-soft);}
.pc-cta{font-family:var(--sans);font-size:14px;font-weight:800;color:var(--gold);white-space:nowrap;}
.draft-tag{font-family:var(--sans);font-size:10px;font-weight:800;letter-spacing:.04em;color:#fff;background:var(--gold-d);padding:2px 8px;border-radius:20px;vertical-align:middle;text-transform:uppercase;}
.draft-note{background:#fbf6ea;border:1px solid var(--stone);border-radius:10px;padding:14px 16px;font-size:15px;color:var(--ink);margin-bottom:22px;font-family:var(--sans);font-weight:600;}

@media(max-width:860px){
  .guide-layout{grid-template-columns:1fr;gap:30px;padding:34px 24px 50px;}
  .packlist{columns:1;}
  .guide-hero h1{font-size:30px;}
  .page-hero h1{font-size:30px;}
}

/* ---------- Interior content components ---------- */
.measure{max-width:760px;}
.body-text p{font-size:18px;line-height:1.7;color:var(--ink);margin:0 0 18px;}
.body-text h3{font-size:22px;font-weight:800;margin:30px 0 8px;}

.pullquote{border-left:4px solid var(--gold);padding:4px 0 4px 24px;margin:30px 0;
  font-family:var(--serif);font-style:italic;font-size:25px;line-height:1.4;color:var(--ink);}
.pullquote cite{display:block;font-style:normal;font-family:var(--sans);font-size:13px;font-weight:700;color:var(--muted);margin-top:12px;letter-spacing:.04em;}

.steps{list-style:none;counter-reset:step;padding:0;margin:26px 0 0;}
.steps>li{position:relative;padding:0 0 26px 40px;border-left:2px solid var(--line);margin-left:18px;}
.steps>li:last-child{border-left-color:transparent;padding-bottom:0;}
.steps>li::before{counter-increment:step;content:counter(step);position:absolute;left:-19px;top:-4px;
  width:38px;height:38px;border-radius:50%;background:var(--forest);color:#fff;font-family:var(--sans);
  font-weight:800;display:flex;align-items:center;justify-content:center;font-size:15px;}
.steps .when{font-family:var(--sans);font-size:12px;font-weight:700;color:var(--red);letter-spacing:.04em;text-transform:uppercase;}
.steps h3{font-size:19px;font-weight:800;margin:4px 0 6px;}
.steps p{font-size:16px;color:var(--muted);margin:0;line-height:1.55;}

.role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:26px;}
.role-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:24px;}
.role-card .tag{display:inline-block;font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--gold);background:var(--forest);padding:4px 10px;border-radius:20px;margin-bottom:12px;}
.role-card h3{font-size:19px;font-weight:800;margin:0 0 8px;}
.role-card p{font-size:16px;color:var(--muted);margin:0;line-height:1.55;}

.ko-table-wrap{overflow-x:auto;margin-top:24px;border:1px solid var(--line);border-radius:14px;}
.ko-table{width:100%;border-collapse:collapse;font-size:15px;min-width:640px;}
.ko-table th{background:var(--forest);color:#fff;font-family:var(--sans);font-size:12px;letter-spacing:.05em;
  text-transform:uppercase;text-align:left;padding:13px 16px;font-weight:700;}
.ko-table td{padding:13px 16px;border-top:1px solid var(--line);vertical-align:top;color:var(--ink);}
.ko-table tr:nth-child(even) td{background:var(--paper);}
.ko-table .park{font-family:var(--sans);font-weight:700;}
.ko-table .maplink{display:inline-block;margin-top:4px;font-family:var(--sans);font-weight:600;font-size:11px;color:var(--red);text-decoration:none;}
.ko-table .maplink:hover{text-decoration:underline;}
/* parks table → stacked cards on mobile */
@media(max-width:680px){
  .ko-table-wrap{border:none;overflow:visible;}
  .ko-table{min-width:0;width:100%;font-size:15px;}
  .ko-table thead{display:none;}
  .ko-table tbody,.ko-table tr,.ko-table td{display:block;}
  .ko-table tr{border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:12px;}
  .ko-table tr:nth-child(even) td{background:transparent;}
  .ko-table td{border:none;padding:5px 0;}
  .ko-table td.park{font-size:17px;margin-bottom:2px;}
  .ko-table td:not(.park)::before{display:block;font-family:var(--sans);font-weight:700;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:1px;}
  .ko-table td:nth-of-type(2)::before{content:"From Dallas";}
  .ko-table td:nth-of-type(3)::before{content:"Campsites";}
  .ko-table td:nth-of-type(4)::before{content:"Notes";}
}
.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px;}
@media(max-width:760px){.feature-row{grid-template-columns:1fr;}}
/* printable field-guide banner */
.pdf-banner{display:flex;align-items:center;gap:20px;background:linear-gradient(180deg,#fff,#fbf8f2);border:1px solid var(--line);border-left:5px solid var(--gold);border-radius:14px;padding:22px 24px;text-decoration:none;color:inherit;transition:box-shadow .2s ease,transform .2s ease;}
.pdf-banner:hover{box-shadow:0 16px 34px -22px rgba(9,31,44,.55);transform:translateY(-1px);}
.pdf-banner__icon{flex:0 0 auto;color:var(--red);display:flex;}
.pdf-banner__text{flex:1 1 auto;}
.pdf-banner__text h3{font-family:var(--sans);font-size:19px;font-weight:800;color:var(--forest);margin:0 0 4px;}
.pdf-banner__text p{color:var(--muted);margin:0;font-size:15px;line-height:1.5;}
.pdf-banner__cta{flex:0 0 auto;font-family:var(--sans);font-weight:800;font-size:14px;color:var(--forest);background:var(--gold);padding:12px 20px;border-radius:9px;white-space:nowrap;}
@media(max-width:640px){.pdf-banner{flex-direction:column;text-align:center;}.pdf-banner__cta{width:100%;}}

/* Get Started itinerary — stacked variant for mobile */
.arc-mobile{display:none;margin-top:24px;}
.arc-row{display:flex;gap:16px;padding:15px 2px;border-bottom:1px solid var(--line);}
.arc-row:first-child{border-top:1px solid var(--line);}
.arc-grade{font-family:var(--sans);font-weight:800;font-size:16px;color:var(--ink);flex:none;width:58px;}
.arc-campouts{display:flex;flex-direction:column;gap:10px;font-size:16px;}
.arc-campouts a{color:var(--red);text-decoration:none;font-weight:600;}
.arc-season{font-family:var(--sans);font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:1px;}
@media(max-width:680px){.arc-desktop{display:none;}.arc-mobile{display:block;}}

details.tmpl{border:1px solid var(--line);border-radius:12px;margin:12px 0;background:var(--card);overflow:hidden;}
details.tmpl>summary{cursor:pointer;list-style:none;padding:16px 20px;font-family:var(--sans);font-weight:700;
  font-size:16px;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:14px;}
details.tmpl>summary::-webkit-details-marker{display:none;}
details.tmpl>summary::after{content:"+";font-size:22px;color:var(--red);font-weight:700;line-height:1;}
details.tmpl[open]>summary::after{content:"\2013";}
.tmpl-body{padding:0 20px 20px;}
.tmpl-body pre{background:var(--cream);border:1px solid var(--line);border-radius:8px;padding:16px;
  white-space:pre-wrap;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:13px;line-height:1.6;color:var(--ink);}

.note{background:#fbf6ea;border:1px solid var(--stone);border-radius:10px;padding:14px 16px;font-size:15px;color:var(--ink);margin:20px 0;}
.note b{font-family:var(--sans);}

.checklist{columns:2;column-gap:30px;list-style:none;padding:0;margin:18px 0 0;max-width:700px;}
.checklist li{font-size:16px;padding:6px 0 6px 26px;position:relative;break-inside:avoid;}
.checklist li::before{content:"\2610";position:absolute;left:0;color:var(--gold);font-size:17px;}

[id]{scroll-margin-top:88px;}
@media(max-width:760px){.role-grid{grid-template-columns:1fr;}.checklist{columns:1;}}

/* visually-hidden */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}
