/* ===========================================================================
   Elite Camp — shared design system
   Premium outdoor editorial. Warm paper, deep pine, warm rust accent.
   Spectral (serif display) · Hanken Grotesk (UI) · IBM Plex Mono (data).
   =========================================================================== */

:root{
  /* palette */
  --paper:#F4F1E9;          /* warm off-white base */
  --paper-2:#ECE7DA;        /* deeper paper / section bg */
  --white:#FBFAF5;          /* card surface */
  --ink:#1B1913;            /* warm near-black */
  --ink-2:#46423A;          /* body text */
  --muted:#857C6A;          /* captions, meta */
  --line:#DBD4C4;           /* hairlines */
  --line-2:#CBC2AE;
  --pine:#27332B;           /* deep premium green — nav/footer/dark sections */
  --pine-2:#1B2620;
  --pine-soft:#34423A;
  --rust:#BC5A2C;           /* warm accent */
  --rust-2:#A44C23;
  --sand:#D9CEB7;
  --stone:#B4AB97;
  --gold:#B08A3E;          /* rating gold */
  --paper-on-dark:#EFEADD;
  --muted-on-dark:rgba(239,234,221,.62);
  --line-on-dark:rgba(239,234,221,.16);

  /* type */
  --serif:"Spectral",Georgia,"Times New Roman",serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --mono:"IBM Plex Mono","SFMono-Regular",monospace;

  /* metrics */
  --maxw:1320px;
  --pad:48px;
  --radius:4px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:rgba(188,90,44,.22)}

/* ---- layout ---- */
.ec-wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.ec-section{padding:88px 0}
.ec-section--tight{padding:64px 0}

/* ---- type ---- */
.ec-serif{font-family:var(--serif)}
.ec-mono{font-family:var(--mono)}
.ec-display{font-family:var(--serif);font-weight:400;letter-spacing:-0.02em;line-height:1.02}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;letter-spacing:-0.015em;margin:0}
p{margin:0}

.ec-eyebrow{
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.26em;
  text-transform:uppercase;color:var(--rust);
}
.ec-eyebrow--muted{color:var(--muted)}
.ec-kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.ec-lead{font-size:19px;line-height:1.6;color:var(--ink-2)}
.ec-muted{font-size:14.5px;line-height:1.55;color:var(--muted)}
.ec-source{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;line-height:1.5;color:var(--muted);margin-top:auto}
.ec-source a{color:var(--rust-2);text-decoration:underline;text-underline-offset:2px}
.ec-empty{grid-column:1/-1;border:1px solid var(--line);background:var(--white);border-radius:var(--radius);padding:24px;font-size:15px;color:var(--ink-2)}

/* section header */
.ec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:38px}
.ec-head h2{font-size:46px}
.ec-head .ec-eyebrow{margin-bottom:16px;display:block}
.ec-seeall{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;transition:gap .25s,color .2s}
.ec-seeall:hover{gap:13px;color:var(--rust)}

/* ---- buttons ---- */
.ec-btn{
  display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14.5px;font-weight:600;
  padding:14px 24px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;
  transition:transform .2s,background .25s,border-color .25s,color .25s;letter-spacing:.005em;white-space:nowrap;
}
.ec-btn:hover{transform:translateY(-1px)}
.ec-btn--primary{background:var(--ink);color:var(--paper)}
.ec-btn--primary:hover{background:var(--rust)}
.ec-btn--rust{background:var(--rust);color:#fff}
.ec-btn--rust:hover{background:var(--rust-2)}
.ec-btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.ec-btn--ghost:hover{border-color:var(--ink)}
.ec-btn--ondark{background:var(--paper-on-dark);color:var(--pine-2)}
.ec-btn--ondark:hover{background:#fff}
.ec-btn--ghostdark{background:transparent;color:var(--paper-on-dark);border-color:var(--line-on-dark)}
.ec-btn--ghostdark:hover{border-color:var(--paper-on-dark)}

/* ---- tags / chips ---- */
.ec-tag{
  display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);
  border:1px solid var(--line-2);padding:5px 9px;border-radius:2px;white-space:nowrap;
}
.ec-tag--solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.ec-tag--rust{background:rgba(188,90,44,.1);color:var(--rust-2);border-color:rgba(188,90,44,.3)}
.ec-tag--pine{background:var(--pine);color:var(--paper-on-dark);border-color:var(--pine)}

/* category label (filled small) */
.ec-cat{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:#fff;background:var(--rust);padding:6px 10px;border-radius:2px;white-space:nowrap}

/* ---- photo placeholder ---- */
.ph{
  position:relative;overflow:hidden;background:var(--sand);
  background-image:repeating-linear-gradient(135deg,transparent,transparent 13px,rgba(0,0,0,.045) 13px,rgba(0,0,0,.045) 14px);
}
.ph img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(.92) contrast(1.02);transition:transform .9s cubic-bezier(.2,.7,.3,1);
}
.ph::after{
  content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,20,17,.02),rgba(17,20,17,.18));
  pointer-events:none;
}
.ph-cap{z-index:2}
.ph[data-tone="moor"]{background-color:#9aa491}
.ph[data-tone="coast"]{background-color:#9fb1b4}
.ph[data-tone="forest"]{background-color:#7f9079}
.ph[data-tone="dusk"]{background-color:#b89a7e}
.ph[data-tone="stone"]{background-color:#b4ab97}
.ph[data-tone="heather"]{background-color:#a596a0}
.ph[data-tone="sand"]{background-color:#cdbf9f}
.ph[data-tone="pine"]{background-color:#3c4a3f}
.ph[data-tone="snow"]{background-color:#c7cdc8}
.ph[data-tone="ember"]{background-color:#b07a52}
.ph-cap{
  position:absolute;left:14px;bottom:14px;font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;
  text-transform:uppercase;color:rgba(28,24,18,.62);background:rgba(251,250,245,.72);
  padding:5px 9px;border-radius:2px;backdrop-filter:blur(2px);
}
.ph-cap--light{color:rgba(255,255,255,.9);background:rgba(20,24,20,.32)}

/* ---- star rating ---- */
.ec-rating{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;color:var(--ink)}
.ec-rating svg{width:12px;height:12px;fill:var(--rust)}
.ec-rating .n{font-weight:600}
.ec-rating .c{color:var(--muted)}

/* ---- detail/stat table (routes & stays) ---- */
.ec-stats{display:grid;border-top:1px solid var(--line);border-left:1px solid var(--line)}
.ec-stats .cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 16px}
.ec-stats .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.ec-stats .v{font-family:var(--serif);font-size:21px;margin-top:6px;line-height:1}

/* ---- generic card ---- */
.ec-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .3s cubic-bezier(.2,.7,.3,1),box-shadow .3s,border-color .3s;display:flex;flex-direction:column;min-width:0}
.ec-card:hover{transform:translateY(-4px);box-shadow:0 22px 50px -28px rgba(27,25,19,.45);border-color:var(--line-2)}
.ec-card .ec-card-img{position:relative;overflow:hidden}
.ec-card .ec-card-img .ph{transition:transform .9s cubic-bezier(.2,.7,.3,1)}
.ec-card:hover .ec-card-img .ph{transform:scale(1.05)}
.ec-card:hover .ec-card-img .ph img{transform:scale(1.04)}
.ec-card-body{padding:20px;display:flex;flex-direction:column;gap:12px;flex:1}

/* ---- listing cards ---- */
.routecard{display:flex;flex-direction:column}
.routecard .ec-card-img .ph{height:210px}
.route-card-meta{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-top:2px}
.route-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr))}
.route-stats .cell{padding:11px 12px;border-right:1px solid var(--line);border-top:1px solid var(--line);min-width:0}
.route-stats .cell:last-child{border-right:0}
.route-stats .k{font-family:var(--mono);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.route-stats .v{font-size:13px;font-weight:600;margin-top:4px;color:var(--ink);overflow-wrap:anywhere}

.staycard .ec-card-img .ph{height:230px}
.staycard .price{font-family:var(--serif);font-size:20px}
.staycard .price span{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.04em}

.gearcard .ec-card-img .ph{height:200px;background-color:#23211a}
.gearcard{background:var(--ink);border-color:#2a2820;color:var(--paper-on-dark)}
.gearcard h4{color:var(--paper-on-dark)}
.gearcard .verdict{font-size:13.5px;line-height:1.55;color:rgba(239,234,221,.66)}
.gearcard .ec-tag{color:rgba(239,234,221,.8);border-color:rgba(239,234,221,.18)}
.gearcard:hover{box-shadow:0 22px 50px -28px rgba(0,0,0,.6)}

/* tag row */
.ec-tagrow{display:flex;flex-wrap:wrap;gap:6px}

/* ---- nav ---- */
.ec-nav{position:sticky;top:0;z-index:50;background:rgba(244,241,233,.86);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line)}
.ec-nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);height:68px;display:flex;align-items:center;justify-content:space-between;gap:30px}
.ec-brand{font-family:var(--serif);font-size:22px;letter-spacing:.02em;font-weight:500;white-space:nowrap;display:flex;align-items:center;gap:9px}
.ec-brand .mark{width:9px;height:9px;background:var(--rust);border-radius:1px;transform:rotate(45deg)}
.ec-nav-links{display:flex;align-items:center;gap:30px}
.ec-nav-links a{font-size:14px;color:var(--ink-2);transition:color .2s;position:relative;white-space:nowrap}
.ec-nav-links a:hover{color:var(--ink)}
.ec-nav-links a.active{color:var(--ink)}
.ec-nav-right{display:flex;align-items:center;gap:18px}
.ec-iconbtn{width:38px;height:38px;border-radius:19px;border:1px solid var(--line-2);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,background .2s}
.ec-iconbtn:hover{border-color:var(--ink);background:var(--white)}
.ec-iconbtn svg{width:16px;height:16px;stroke:var(--ink);fill:none;stroke-width:1.6}

/* ---- footer ---- */
.ec-footer{background:var(--pine);color:var(--paper-on-dark);padding:72px 0 32px}
.ec-footer a{display:block;color:var(--muted-on-dark);font-size:14px;line-height:2.1;transition:color .2s}
.ec-footer a:hover{color:var(--paper-on-dark)}
.ec-footer .col-h{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--rust);margin-bottom:12px}
.ec-foot-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:40px;padding-bottom:48px;border-bottom:1px solid var(--line-on-dark)}
.ec-foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;gap:20px;flex-wrap:wrap}
.ec-foot-bottom .fine{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--muted-on-dark)}

/* ---- utility ---- */
.ec-grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:24px}
.ec-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
.ec-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.ec-divider{height:1px;background:var(--line);border:0;margin:0}
.ec-disclosure{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--muted);line-height:1.6}
.fchip,.chip{white-space:nowrap}

/* reveal on scroll */
.ec-reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.ec-reveal.in{opacity:1;transform:none}

@media (max-width:1080px){
  :root{--pad:32px}
  .ec-grid-4{grid-template-columns:repeat(2,1fr)}
  .ec-foot-grid{grid-template-columns:1fr 1fr 1fr}
}

@media (max-width:760px){
  :root{--pad:20px}
  .ec-section{padding:64px 0}
  .ec-nav-inner{height:auto;min-height:64px;align-items:flex-start;flex-wrap:wrap;padding-top:14px;padding-bottom:14px;gap:14px}
  .ec-nav-links{order:3;width:100%;gap:18px;overflow-x:auto;padding-bottom:2px}
  .ec-nav-right{margin-left:auto}
  .ec-nav-right .ec-btn{display:none}
  .ec-head{display:block}
  .ec-head h2{font-size:34px;line-height:1.05}
  .ec-wrap{max-width:100vw}
  h1,h2,h3,h4,p{overflow-wrap:anywhere}
  .ec-head .ec-seeall{margin-top:18px}
  .ec-grid-4,.ec-grid-3,.ec-grid-2{grid-template-columns:1fr}
  .ec-foot-grid{grid-template-columns:1fr;gap:26px}
  .ec-foot-bottom{display:block}
  .ec-foot-bottom .fine{display:block;margin-top:12px}
}

@media (max-width:430px){
  .ec-head h2{font-size:28px}
  .ec-card-body h3{font-size:22px!important}
  .route-stats .cell{padding:10px 9px}
}
