/* ============================================================
   Stockholms Kajakled — shared stylesheet
   Brand palette from SKT style guide (2021)
   ============================================================ */

:root{
  /* ---- brand palette ---- */
  --blue:#004B66;        /* primary deep blue */
  --aqua:#B4DCD7;        /* primary light aqua */
  --red:#C32211;         /* primary kayak red */
  --teal:#649696;        /* secondary */
  --gold:#BB8B38;        /* secondary */
  --taupe:#89665C;       /* secondary */
  --green:#50B464;       /* accent */
  --amber:#F0B43C;       /* accent — access points */
  --coral:#DC6450;       /* accent */

  /* ---- working tokens ---- */
  --paper:#FAF8F3;
  --ink:#004B66;
  --text:#2D434A;
  --line:rgba(0,75,102,0.16);
  --line-soft:rgba(0,75,102,0.08);

  --font:"Oxygen", system-ui, -apple-system, sans-serif;
  --wrap:1140px;

  /* swap this for one of your archipelago photos: url('assets/img/hero.jpg') center/cover */
  --hero-photo:linear-gradient(160deg,#0a5a78 0%,#004B66 45%,#06384b 100%);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--paper);color:var(--text);font-family:var(--font);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
h1,h2,h3,h4{font-weight:700;line-height:1.12;margin:0;color:var(--ink);letter-spacing:-0.01em;}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px;}
.narrow{max-width:780px;}
.skip{position:absolute;left:-9999px;top:0;background:var(--blue);color:#fff;padding:10px 16px;z-index:200;}
.skip:focus{left:8px;top:8px;}

.eyebrow{
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:700;
  color:var(--teal);display:inline-flex;align-items:center;gap:11px;margin:0 0 18px;
}
.eyebrow::before{content:"";width:30px;border-top:2px dashed var(--teal);}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-weight:700;font-size:16px;padding:14px 26px;border-radius:3px;border:2px solid transparent;cursor:pointer;transition:transform .15s,background .15s,color .15s,border-color .15s;}
.btn:focus-visible{outline:3px solid var(--amber);outline-offset:3px;}
.btn-primary{background:var(--red);color:#fff;}
.btn-primary:hover{background:#a51d0e;transform:translateY(-2px);}
.btn-ghost{border-color:currentColor;color:#fff;}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-2px);}
.btn-ghost.dark{color:var(--blue);}
.btn-ghost.dark:hover{background:rgba(0,75,102,.07);}
.btn-solid-blue{background:var(--blue);color:#fff;}
.btn-solid-blue:hover{background:#063e54;transform:translateY(-2px);}
.btn .arr{transition:transform .15s;}
.btn:hover .arr{transform:translateX(4px);}
/* keep button styling when a button sits inside .prose (which styles plain links) */
.prose a.btn{border-bottom:0;}
.prose a.btn-primary,.prose a.btn-solid-blue{color:#fff;}
.prose a.btn-ghost{color:#fff;}
.prose a.btn-ghost.dark{color:var(--blue);}

/* ---------- header ---------- */
header.site{position:sticky;top:0;z-index:50;background:rgba(250,248,243,.90);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft);}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:24px;}
.brand{display:flex;align-items:center;gap:12px;color:var(--blue);}
.brand img{height:42px;width:auto;display:block;}
.nav-links{display:flex;align-items:center;gap:20px;font-weight:400;font-size:14.5px;}
.nav-links a{color:var(--text);transition:color .15s;padding:4px 0;border-bottom:2px solid transparent;}
.nav-links a:hover{color:var(--red);}
.nav-links a.active{color:var(--blue);border-bottom-color:var(--red);font-weight:700;}
.nav-right{display:flex;align-items:center;gap:12px;}
.lang{display:flex;border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.lang button,.lang a{font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.08em;padding:7px 11px;border:0;background:transparent;color:var(--teal);cursor:pointer;text-decoration:none;display:inline-block;line-height:1.3;}
.lang button[aria-pressed="true"],.lang a.active{background:var(--blue);color:#fff;}
.lang button:focus-visible,.lang a:focus-visible{outline:2px solid var(--amber);outline-offset:-2px;}
.menu-btn{display:none;background:transparent;border:1px solid var(--line);border-radius:3px;padding:8px 12px;cursor:pointer;font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--blue);}

/* ---------- hero ---------- */
.hero{position:relative;color:#fff;background:linear-gradient(180deg,rgba(0,40,55,.55),rgba(0,40,55,.30) 40%,rgba(0,55,72,.78)),var(--hero-photo);background-size:cover;background-position:center;}
.hero .wrap{padding-top:84px;padding-bottom:92px;position:relative;}
.hero .hero-badge{width:110px;height:auto;margin-bottom:26px;filter:drop-shadow(0 10px 30px rgba(0,0,0,.35));}
.hero h1{color:#fff;font-size:clamp(38px,6.2vw,72px);font-weight:700;max-width:15ch;}
.hero p.lead{font-size:clamp(18px,2.2vw,22px);color:#EAF4F2;max-width:48ch;margin:22px 0 32px;font-weight:300;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;}
.hero-meta{display:flex;gap:34px;margin-top:44px;flex-wrap:wrap;}
.hero-meta b{display:block;font-size:30px;font-weight:700;color:#fff;}
.hero-meta span{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#BFE0DB;}

/* compact page hero (interior pages) */
.pagehero{position:relative;color:#fff;background:linear-gradient(180deg,rgba(0,40,55,.50),rgba(0,55,72,.80)),var(--hero-photo);background-size:cover;background-position:center;}
.pagehero .wrap{padding:64px 24px 58px;}
.pagehero h1{color:#fff;font-size:clamp(30px,5vw,52px);max-width:18ch;}
.pagehero p{color:#EAF4F2;font-weight:300;font-size:clamp(17px,2vw,20px);max-width:56ch;margin:18px 0 0;}
.crumbs{font-size:13px;letter-spacing:.04em;color:#BFE0DB;margin-bottom:18px;}
.crumbs a{color:#fff;border-bottom:1px solid rgba(255,255,255,.4);}

/* route ribbon */
.ribbon{background:var(--blue);height:8px;background-image:repeating-linear-gradient(90deg,var(--amber) 0 18px,transparent 18px 34px);}

/* ---------- sections ---------- */
.section{padding:88px 0;border-top:1px solid var(--line-soft);}
.section.tint{background:var(--aqua);border-top:0;}
.section.bluebg{background:var(--blue);color:#EAF4F2;border-top:0;}
.section-head{max-width:64ch;margin-bottom:46px;}
.section-head h2{font-size:clamp(28px,4vw,42px);}
.section-head p{color:var(--text);font-size:18px;margin:16px 0 0;font-weight:300;}
.bluebg .section-head h2{color:#fff;}
.bluebg .section-head p{color:#BFE0DB;}
.bluebg .eyebrow{color:var(--amber);}
.bluebg .eyebrow::before{border-top-color:var(--amber);}

/* prose */
.prose p{font-weight:300;margin:0 0 18px;}
.prose h3{font-size:22px;margin:34px 0 10px;}
.prose h2{font-size:clamp(24px,3.2vw,32px);margin:48px 0 14px;}
.prose ul{padding-left:1.1em;margin:0 0 18px;}
.prose li{margin:0 0 9px;font-weight:300;}
.prose strong{font-weight:700;color:var(--ink);}
.prose a{color:var(--blue);font-weight:700;border-bottom:1px solid var(--line);}
.lede{font-size:20px;font-weight:300;color:var(--text);margin:0 0 28px;}

/* ---------- start-here steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:4px;overflow:hidden;background:#fff;}
.step{padding:34px 30px;border-right:1px dashed var(--line);}
.step:last-child{border-right:0;}
.step .num{font-size:13px;font-weight:700;color:var(--red);letter-spacing:.12em;}
.step h3{font-size:21px;margin:14px 0 8px;}
.step p{margin:0;color:var(--text);font-size:15.5px;font-weight:300;}

/* ---------- stage cards / list ---------- */
.stages{position:relative;}
.stages .course{position:absolute;left:31px;top:18px;bottom:60px;border-left:2px dashed var(--line);}
.stage{position:relative;display:grid;grid-template-columns:64px 1fr auto;gap:26px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:4px;padding:24px 30px;margin-bottom:16px;transition:transform .15s,box-shadow .15s,border-color .15s;}
.stage:hover{transform:translateX(4px);border-color:var(--teal);box-shadow:0 18px 40px -28px rgba(0,75,102,.5);}
.stage .badge-n{width:48px;height:48px;border-radius:50%;background:var(--aqua);border:2px solid var(--blue);color:var(--blue);display:grid;place-items:center;font-size:22px;font-weight:700;z-index:1;}
.stage h3{font-size:22px;}
.stage .data{font-size:13px;color:var(--teal);margin-top:6px;letter-spacing:.03em;text-transform:uppercase;font-weight:700;}
.stage .go{font-size:14px;color:var(--blue);white-space:nowrap;font-weight:700;}
.stage:hover .go{color:var(--red);}
.stages-foot{margin-top:6px;font-size:15px;color:var(--text);font-weight:300;}
.stages-foot a{color:var(--blue);font-weight:700;border-bottom:1px solid var(--line);}
.bluebg .stages-foot{color:#BFE0DB;}
.bluebg .stages-foot a{color:#fff;border-bottom-color:rgba(255,255,255,.4);}

/* detailed stage block (trail page) */
.stagecard{background:#fff;border:1px solid var(--line);border-radius:5px;padding:30px 32px;margin-bottom:22px;}
.stagecard .top{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;margin-bottom:6px;}
.stagecard .ref{display:inline-grid;place-items:center;min-width:34px;height:34px;padding:0 8px;border-radius:4px;background:var(--blue);color:#fff;font-weight:700;font-size:16px;}
.stagecard h3{font-size:24px;}
.stagecard .facts{display:flex;flex-wrap:wrap;gap:10px;margin:16px 0 6px;}
.chip{font-size:13px;font-weight:700;letter-spacing:.02em;padding:6px 13px;border-radius:40px;border:1px solid var(--line);color:var(--blue);background:var(--paper);}
.chip.km{background:var(--aqua);border-color:transparent;}
.chip.cross{background:#fff;color:var(--coral);border-color:rgba(220,100,80,.4);}
.stagecard p{font-weight:300;margin:12px 0 0;color:var(--text);}

/* generic feature/card grids */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.card{background:#fff;border:1px solid var(--line);border-radius:5px;padding:28px 28px;}
.card h3{font-size:20px;margin:0 0 9px;}
.card p{font-weight:300;margin:0;color:var(--text);font-size:15.5px;}
.card .k{font-size:13px;font-weight:700;letter-spacing:.1em;color:var(--red);text-transform:uppercase;}

/* ---------- map + downloads ---------- */
.map-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;}
.map-frame{border:1px solid var(--line);border-radius:4px;overflow:hidden;background:#fff;min-height:440px;}
.map-frame iframe{width:100%;height:100%;min-height:440px;border:0;display:block;}
.dl{display:flex;flex-direction:column;gap:13px;}
.dl a{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid var(--line);border-radius:4px;padding:19px 22px;transition:border-color .15s,transform .15s;}
.dl a:hover{border-color:var(--teal);transform:translateY(-2px);}
.dl a .l b{display:block;font-size:17px;font-weight:700;color:var(--ink);}
.dl a .l span{font-size:12.5px;color:var(--teal);letter-spacing:.04em;font-weight:400;}
.dl a .ic{font-size:13px;font-weight:700;color:var(--red);white-space:nowrap;}
.dl .soon{opacity:.6;}
.dl .soon .ic{color:var(--taupe);}

/* ---------- safety grid ---------- */
.safe-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.safe{border-top:2px solid rgba(255,255,255,.18);padding-top:18px;}
.safe .k{font-size:13px;font-weight:700;letter-spacing:.1em;color:var(--amber);}
.safe h3{color:#fff;font-size:18px;margin:10px 0 7px;}
.safe p{color:#A9C9CE;font-size:14.5px;margin:0;font-weight:300;}
.safe .em{color:var(--coral);font-weight:700;}

/* callout box */
.callout{background:#fff;border:1px solid var(--line);border-left:4px solid var(--amber);border-radius:5px;padding:22px 26px;margin:28px 0;}
.callout.warn{border-left-color:var(--red);}
.callout h3{font-size:18px;margin:0 0 8px;}
.callout p{font-weight:300;margin:0;}
.callout .em{color:var(--red);font-weight:700;}

/* ---------- mission / who ---------- */
.mission{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.mission .quote{font-size:clamp(22px,3vw,30px);line-height:1.32;font-weight:700;color:var(--ink);}
.mission .quote .em{color:var(--red);}
.mission .body{color:var(--text);margin-top:22px;font-weight:300;}
.who{display:flex;flex-direction:column;gap:18px;}
.who .row{display:flex;gap:15px;align-items:flex-start;}
.who .row .dot{margin-top:9px;width:9px;height:9px;border-radius:50%;background:var(--amber);flex:0 0 auto;}
.who .row b{font-size:18px;font-weight:700;color:var(--ink);}
.who .row p{margin:2px 0 0;color:var(--text);font-size:15px;font-weight:300;}

/* ---------- partners ---------- */
.partners{text-align:center;}
.partners .lead{color:var(--teal);font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin-bottom:10px;}
.partners .funder{font-size:22px;font-weight:700;color:var(--ink);margin-bottom:34px;}
.plist{display:flex;flex-wrap:wrap;gap:14px 12px;justify-content:center;}
.plist span,.plist a{font-size:15px;font-weight:400;color:var(--text);border:1px solid var(--line);border-radius:40px;padding:9px 18px;background:#fff;text-decoration:none;transition:border-color .15s,color .15s,transform .15s;}
.plist a:hover{border-color:var(--teal);color:var(--blue);transform:translateY(-2px);}

/* ---------- FAQ accordion ---------- */
.faq{max-width:820px;}
.faq details{background:#fff;border:1px solid var(--line);border-radius:5px;margin-bottom:12px;overflow:hidden;}
.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:700;color:var(--ink);font-size:17px;display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-size:24px;font-weight:400;color:var(--red);transition:transform .2s;line-height:1;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .ans{padding:0 24px 22px;font-weight:300;color:var(--text);}
.faq .ans p{margin:0 0 12px;}
.faq .ans p:last-child{margin:0;}
.faq .ans a{color:var(--blue);font-weight:700;border-bottom:1px solid var(--line);}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;}
.contact-grid .big a{color:var(--blue);font-weight:700;}
.contact-list b{display:block;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);margin-bottom:3px;}
.contact-list p{margin:0 0 20px;font-weight:300;}

/* ---------- footer ---------- */
footer.site{background:var(--blue);color:#CFE6E2;padding:62px 0 34px;}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;}
.foot-brand img{height:46px;width:auto;margin-bottom:14px;}
footer.site p{margin:6px 0;font-size:15px;color:#A9C9CE;font-weight:300;}
footer.site a{color:#fff;}
.foot-col .label{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#7FB0B9;margin-bottom:13px;font-weight:700;}
.foot-col a{display:block;color:#CFE6E2;margin:7px 0;font-size:15px;font-weight:300;}
.foot-col a:hover{color:#fff;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.16);margin-top:46px;padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:#7FB0B9;letter-spacing:.04em;}

/* ---------- photos / figures ---------- */
.figure{border-radius:6px;overflow:hidden;border:1px solid var(--line);margin:0;background:var(--aqua);}
.figure img{display:block;width:100%;height:100%;object-fit:cover;}
.figure.wide{aspect-ratio:16/9;}
.figure.tall{aspect-ratio:3/4;}
.figure.square{aspect-ratio:1/1;}
.figcap{font-size:12.5px;color:var(--teal);margin-top:8px;font-weight:400;letter-spacing:.02em;}
.imgsplit{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center;}
.imgsplit.rev .txt{order:2;}
.photoband{height:clamp(220px,34vw,400px);background-size:cover;background-position:center;border-top:0;}
.partner-logos{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;align-items:center;margin-bottom:32px;}
.partner-logos a{display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid var(--line);border-radius:8px;padding:16px 26px;transition:transform .15s,box-shadow .15s;}
.partner-logos a:hover{transform:translateY(-2px);box-shadow:0 14px 30px -22px rgba(0,75,102,.55);}
.partner-logos img{display:block;height:auto;max-height:40px;max-width:175px;width:auto;}

/* ---------- reveal animation ---------- */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s;}
  .reveal.in{opacity:1;transform:none;}
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .map-grid,.mission,.contact-grid,.grid-3,.grid-2,.imgsplit{grid-template-columns:1fr;gap:30px;}
  .imgsplit.rev .txt{order:0;}
  .steps{grid-template-columns:1fr;}
  .step{border-right:0;border-bottom:1px dashed var(--line);}
  .step:last-child{border-bottom:0;}
  .safe-grid{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1fr;gap:30px;}
  .nav-links{display:none;}
  .nav-links.open{display:flex;position:absolute;top:74px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:8px 24px 18px;box-shadow:0 20px 30px -20px rgba(0,75,102,.4);}
  .nav-links.open a{padding:12px 0;width:100%;border-bottom:1px solid var(--line-soft);}
  .nav-links.open a.active{border-bottom-color:var(--line-soft);}
  .menu-btn{display:inline-block;}
  .section{padding:62px 0;}
}
@media (max-width:520px){
  .safe-grid{grid-template-columns:1fr;}
  .stage{grid-template-columns:48px 1fr;}
  .stage .go{display:none;}
  .hero-meta{gap:22px;}
}
