/* ============================================================
   WEEKEND VIKINGS — shared styles
   Rugged, earthy: espresso / cream / warm stone.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Anton&family=Oswald:wght@400;500;600;700&family=Spectral:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root{
  --ink:#211815;
  --espresso:#2c211d;
  --espresso-2:#3a2c26;
  --cream:#f5eee0;
  --cream-2:#ece2cf;
  --paper:#fbf7ee;
  --stone:#b6a489;
  --stone-deep:#8a795f;
  --line:rgba(33,24,21,.14);
  --accent:#2c211d;          /* default = espresso (no extra accent) */
  --accent-ink:#f5eee0;
  --shadow:0 26px 60px -28px rgba(33,24,21,.55);
  --shadow-sm:0 14px 30px -18px rgba(33,24,21,.45);
  --topo:url('assets/topo.svg');
  --maxw:1240px;
  --font-display:'Anton',sans-serif;
  --font-head:'Oswald',sans-serif;
  --font-body:'Spectral',Georgia,serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-weight:600;
  font-size:13px;
  color:var(--stone-deep);
}
.h-display{font-family:var(--font-display);text-transform:uppercase;line-height:.92;letter-spacing:.01em;font-weight:400;}
.h2{
  font-family:var(--font-head);
  text-transform:uppercase;
  font-weight:700;
  letter-spacing:.02em;
  line-height:1.02;
  font-size:clamp(34px,5vw,62px);
  color:var(--espresso);
  margin:.1em 0 .35em;
}
.lead{font-size:18px;color:#4a3c35;max-width:60ch;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-head);text-transform:uppercase;font-weight:600;
  letter-spacing:.16em;font-size:14px;
  padding:16px 30px;border:0;cursor:pointer;
  background:var(--accent);color:var(--accent-ink);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
  box-shadow:var(--shadow-sm);
}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.btn--ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(245,238,224,.55);box-shadow:none;}
.btn--ghost:hover{background:rgba(245,238,224,.12);}
.btn--dark{background:var(--espresso);color:var(--cream);}
.btn--cream{background:var(--cream);color:var(--espresso);}

/* ---------- placeholder imagery ---------- */
.ph{
  position:relative;overflow:hidden;background:#cfc6b4;
  background-image:
    linear-gradient(135deg,rgba(44,33,29,.55),rgba(138,121,95,.25)),
    linear-gradient(0deg,#9a8f79,#c3b8a4);
  display:flex;align-items:center;justify-content:center;
}
.ph::after{
  content:attr(data-label);
  position:absolute;bottom:12px;left:12px;
  font-family:'Courier New',monospace;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:rgba(245,238,224,.85);
  background:rgba(33,24,21,.42);padding:4px 9px;border:1px solid rgba(245,238,224,.25);
  backdrop-filter:blur(2px);
}
.ph__big{
  font-family:var(--font-head);text-transform:uppercase;font-weight:600;
  letter-spacing:.18em;color:rgba(245,238,224,.78);font-size:15px;text-align:center;
}
.ph--photo{background-image:linear-gradient(160deg,#5f6f6a,#2f3a3c 70%),repeating-linear-gradient(45deg,rgba(255,255,255,.05) 0 8px,transparent 8px 16px);}
.ph--snow{background-image:linear-gradient(160deg,#9fb0bd,#56636e 75%);}
.ph--valley{background-image:linear-gradient(160deg,#7a8f6a,#34452f 78%);}
.ph--lake{background-image:linear-gradient(160deg,#5b8aa0,#243f52 78%);}
.ph--desert{background-image:linear-gradient(160deg,#b79468,#6c4f30 80%);}

/* ---------- topbar ---------- */
.topbar{background:var(--ink);color:var(--cream);font-family:var(--font-head);font-size:13px;letter-spacing:.05em;}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px;gap:18px;}
.topbar a{opacity:.82;}
.topbar a:hover{opacity:1;}
.topbar .tb-left{display:flex;gap:26px;align-items:center;}
.topbar .tb-left span{display:inline-flex;align-items:center;gap:8px;}
.topbar .tb-soc{display:flex;gap:16px;text-transform:uppercase;letter-spacing:.14em;}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:var(--paper);border-bottom:1px solid var(--line);}
.nav .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;height:96px;gap:20px;}
.nav__links{display:flex;align-items:center;gap:34px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.13em;font-size:14px;font-weight:500;}
.nav__links--right{justify-content:flex-end;}
.nav__links a{position:relative;padding:6px 0;color:var(--espresso);}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--stone-deep);transition:width .22s ease;}
.nav__links a:hover::after,.nav__links a.is-active::after{width:100%;}
.nav__logo{display:flex;justify-content:center;}
.nav__logo img{width:78px;height:78px;}
.nav__burger{display:none;}

/* ---------- generic section ---------- */
.section{padding:96px 0;}
.section--cream{background:var(--cream);}
.section--espresso{background:var(--espresso);color:var(--cream);}
.section--topo{background-color:var(--cream-2);}
.sec-head{text-align:center;max-width:680px;margin:0 auto 56px;}
.sec-head .lead{margin:0 auto;}

/* ---------- footer ---------- */
.foot{background-color:var(--cream-2);color:var(--espresso);padding:80px 0 34px;position:relative;}
.foot__top{display:grid;grid-template-columns:120px 1fr auto;gap:40px;align-items:start;margin-bottom:56px;}
.foot__logo{width:78px;height:78px;}
.foot__intro{font-size:18px;max-width:54ch;color:#463a33;}
.foot__cols{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.foot__cols h4{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:15px;margin:0 0 16px;}
.foot__cols ul{list-style:none;margin:0;padding:0;}
.foot__cols li{margin-bottom:9px;color:#52453d;}
.foot__cols a:hover{color:var(--ink);}
.foot__bar{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;font-size:13px;font-family:var(--font-head);letter-spacing:.06em;color:#6a5b50;text-transform:uppercase;}
.to-top{position:absolute;right:28px;top:64px;width:54px;height:54px;border-radius:50%;border:1.5px solid var(--line);background:rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:var(--espresso);transition:background .2s;}
.to-top:hover{background:#fff;}

/* ---------- cards ---------- */
.card{background:#fff;box-shadow:var(--shadow-sm);}
.tour-card{background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;overflow:hidden;}
.tour-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}

/* ============================================================
   TOUR DETAIL PAGES (shared)
   ============================================================ */
/* page hero (shared by sub-pages + trip pages) */
.phero{position:relative;background:var(--ink);color:var(--cream);overflow:hidden;}
.phero .ph,.phero__media{position:absolute;inset:0;}
.phero::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(33,24,21,.5),rgba(33,24,21,.82));}
.phero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:120px 28px 90px;}
.phero__crumb{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.22em;font-size:12px;color:rgba(245,238,224,.7);}
.phero__crumb a:hover{color:var(--cream);}
.phero__title{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(40px,7vw,92px);line-height:.92;margin:14px 0 12px;color:rgba(245,238,224,.96);max-width:18ch;}
.phero__sub{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.16em;font-size:clamp(12px,1.5vw,15px);color:rgba(245,238,224,.85);}
.phero__pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;}
.phero__pills span{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:12px;padding:8px 14px;border:1.5px solid rgba(245,238,224,.4);color:var(--cream);}

/* layout */
.td-wrap{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start;}
.td-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-bottom:46px;}
.td-fact{background:#fff;padding:20px 22px;}
.td-fact .l{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--stone-deep);}
.td-fact .v{font-family:var(--font-head);font-weight:600;font-size:16px;color:var(--espresso);margin-top:6px;}
.td-block{margin-bottom:46px;}
.td-block > h2{font-family:var(--font-head);text-transform:uppercase;font-weight:700;letter-spacing:.02em;font-size:clamp(24px,3.2vw,34px);color:var(--espresso);margin:0 0 18px;}
.td-block p{color:#4a3c35;font-size:17px;margin:0 0 16px;}

/* highlights */
.hl-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;}
.hl{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:#4a3c35;}
.hl::before{content:"▲";color:var(--stone-deep);font-size:12px;line-height:1.7;flex:0 0 auto;}

/* itinerary accordion */
.itin__item{border:1px solid var(--line);margin-bottom:12px;background:#fff;}
.itin__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 22px;display:flex;align-items:center;gap:18px;}
.itin__day{font-family:var(--font-display);font-size:30px;color:var(--stone);line-height:1;flex:0 0 auto;}
.itin__ttl{font-family:var(--font-head);text-transform:uppercase;font-weight:600;letter-spacing:.03em;font-size:16px;color:var(--espresso);flex:1;}
.itin__sign{font-family:var(--font-display);font-size:24px;color:var(--stone-deep);transition:transform .25s;}
.itin__item.is-open .itin__sign{transform:rotate(45deg);}
.itin__a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.itin__a p{margin:0;padding:0 22px 22px 70px;color:#4a3c35;font-size:15.5px;}

/* included / excluded */
.incex{display:grid;grid-template-columns:1fr 1fr;gap:30px;}
.incex ul{list-style:none;margin:0;padding:0;}
.incex li{position:relative;padding:9px 0 9px 30px;border-bottom:1px solid var(--line);font-size:15.5px;color:#4a3c35;}
.incex .inc li::before{content:"✓";position:absolute;left:0;color:#3c7a4a;font-weight:700;}
.incex .exc li::before{content:"✕";position:absolute;left:0;color:#b15140;font-weight:700;}
.incex h3{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.08em;font-size:18px;color:var(--espresso);margin:0 0 8px;}

/* pricing table */
.ptable{width:100%;border-collapse:collapse;font-size:15px;}
.ptable th,.ptable td{border:1px solid var(--line);padding:13px 16px;text-align:left;}
.ptable th{background:var(--espresso);color:var(--cream);font-family:var(--font-head);text-transform:uppercase;letter-spacing:.06em;font-size:12px;}
.ptable td:first-child{font-family:var(--font-head);font-weight:600;color:var(--espresso);}
.ptable tr:nth-child(even) td{background:var(--paper);}

/* note box */
.td-note{background:var(--cream);border-left:4px solid var(--stone-deep);padding:18px 22px;font-size:15px;color:#4a3c35;}

/* booking card */
.book-card{position:sticky;top:116px;background:#fff;box-shadow:var(--shadow);border-top:5px solid var(--stone-deep);}
.book-card__head{padding:26px 28px 22px;border-bottom:1px solid var(--line);}
.book-card__from{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--stone-deep);}
.book-card__price{font-family:var(--font-display);font-size:42px;color:var(--espresso);line-height:1;margin-top:4px;}
.book-card__price small{font-family:var(--font-head);font-size:12px;letter-spacing:.1em;color:var(--stone-deep);display:block;margin-top:4px;}
.book-card__body{padding:24px 28px 28px;}
.fld{margin-bottom:16px;}
.fld label{font-family:var(--font-head);text-transform:uppercase;letter-spacing:.12em;font-size:11px;color:var(--stone-deep);display:block;margin-bottom:7px;}
.fld input,.fld select{width:100%;font-family:var(--font-body);font-size:15px;color:var(--ink);background:var(--paper);border:1px solid var(--line);padding:12px 13px;outline:none;transition:border-color .2s;}
.fld input:focus,.fld select:focus{border-color:var(--stone-deep);}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.btn--wa{background:#1faf54;color:#fff;width:100%;justify-content:center;}
.btn--wa:hover{background:#188f45;}
.book-card__alt{display:block;text-align:center;margin-top:14px;font-family:var(--font-head);text-transform:uppercase;letter-spacing:.1em;font-size:12px;color:var(--stone-deep);}
.book-card__alt:hover{color:var(--espresso);}

/* related strip */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}

@media (max-width:980px){
  .td-wrap{grid-template-columns:1fr;}
  .book-card{position:static;}
  .td-facts{grid-template-columns:1fr 1fr;}
  .hl-grid,.incex,.rel-grid{grid-template-columns:1fr;}
}

@media (max-width:920px){
  .nav .wrap{grid-template-columns:1fr auto;height:74px;}
  .nav__links{position:fixed;inset:0 0 0 auto;width:78%;max-width:340px;background:var(--paper);
    flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:8px;padding:90px 30px;
    transform:translateX(100%);transition:transform .3s ease;box-shadow:var(--shadow);z-index:50;}
  .nav__links a{font-size:18px;padding:12px 0;width:100%;border-bottom:1px solid var(--line);}
  .nav.is-open .nav__links{transform:translateX(0);}
  .nav__logo{order:-1;justify-self:start;}
  .nav__logo img{width:58px;height:58px;}
  .nav__burger{display:flex;flex-direction:column;gap:5px;justify-self:end;background:none;border:0;cursor:pointer;padding:10px;}
  .nav__burger span{width:26px;height:2.5px;background:var(--espresso);transition:.25s;}
  .nav.is-open .nav__burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
  .nav.is-open .nav__burger span:nth-child(2){opacity:0;}
  .nav.is-open .nav__burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
  .topbar{display:none;}
  .section{padding:64px 0;}
  .foot__top{grid-template-columns:1fr;gap:22px;}
  .foot__cols{grid-template-columns:repeat(2,1fr);}
  .to-top{display:none;}
}
