/* Wellness Iceland — brand v2 stylesheet
   Palette: basalt / geothermal / steam + warm linen. No clay. No gradients.
   Type: Cormorant Garamond (large headlines only) + Jost (everything else). No italics. */

:root{
  --basalt:#1E2A2D; --geo:#3C7A85; --geo-deep:#2A5963; --steam:#DCE6E5;
  --linen:#F5F0E8; --cloud:#FBF9F3; --stone:#C9C1B2; --moss:#6F8C6A;
  --ink:#1E2A2D; --muted:#5d6a6a; --line:#e2dcce;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--linen); color:var(--ink);
  font-family:"Jost",system-ui,-apple-system,sans-serif; font-weight:300;
  line-height:1.7; -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:var(--geo-deep);text-decoration:none}
a:hover{text-decoration:underline}

/* Cormorant ONLY for large display headings */
h1,h2,.display{font-family:"Cormorant Garamond",Georgia,serif;font-weight:500;line-height:1.08;letter-spacing:.005em;font-style:normal}
h3,h4,.label,nav,.btn,.eyebrow,.chip,.meta{font-family:"Jost",sans-serif}
h3{font-size:1.05rem;font-weight:500;letter-spacing:.01em}
h4{font-size:.95rem;font-weight:500}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;font-weight:500;color:var(--geo-deep)}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---------- nav ---------- */
.nav{position:absolute;top:0;left:0;right:0;z-index:20}
.nav.solid{position:sticky;background:var(--linen);border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{font-family:"Cormorant Garamond",serif;font-weight:500;font-size:1.5rem;letter-spacing:.04em;color:inherit}
.brand small{display:block;font-family:"Jost";font-size:.56rem;letter-spacing:.34em;text-transform:uppercase;font-weight:400;opacity:.8;margin-top:1px}
.nav .links{display:flex;gap:30px;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:400}
.nav.onlight .links a,.nav.onlight .brand{color:var(--basalt)}
.nav.ondark .links a,.nav.ondark .brand{color:#fff}
.nav .links a{text-decoration:none}
.navbtn{font-family:"Jost";font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;padding:10px 22px;border-radius:2px;border:1px solid currentColor}
.nav.ondark .navbtn{color:#fff}.nav.onlight .navbtn{color:var(--basalt)}

/* ---------- buttons ---------- */
.btn{display:inline-block;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;padding:14px 30px;border-radius:2px;cursor:pointer;border:1px solid transparent;transition:background .25s ease,color .25s ease}
.btn.dark{background:var(--basalt);color:var(--linen)}
.btn.dark:hover{background:#13201f;text-decoration:none}
.btn.teal{background:var(--geo-deep);color:#fff}
.btn.teal:hover{background:#21474f;text-decoration:none}
.btn.ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn.ghost:hover{background:rgba(255,255,255,.12);text-decoration:none}
.btn.ghost-dark{background:transparent;color:var(--basalt);border-color:var(--basalt)}
.btn.ghost-dark:hover{background:rgba(30,42,45,.06);text-decoration:none}
.btn.sm{padding:10px 20px;font-size:.72rem}

/* ---------- media (photo placeholders, flat tint — no gradient) ---------- */
.media{position:relative;overflow:hidden;background:var(--steam)}
.media img.cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.05) contrast(1.02)}
.media .tint{position:absolute;inset:0;background:rgba(30,42,45,.42)}
.media .tint.soft{background:rgba(30,42,45,.10)}
.media .tint.teal{background:rgba(42,89,99,.5)}
.media>.inner{position:relative;z-index:2}
.ph-tag{position:absolute;z-index:3;top:14px;left:14px;background:rgba(251,249,243,.9);color:var(--geo-deep);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;padding:5px 11px;border-radius:2px}

/* ---------- hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.hero .media{position:absolute;inset:0}
.hero .inner{position:relative;z-index:5;padding-bottom:64px}
.hero h1{font-size:clamp(2.6rem,6vw,5rem);max-width:17ch;font-weight:500;margin:14px 0 16px}
.hero p.sub{font-size:1.15rem;max-width:46ch;font-weight:300}
.hero .eyebrow{color:#cfe0d4}
.hero .ctas{margin-top:28px;display:flex;gap:12px;flex-wrap:wrap}

/* ---------- search / booking bar ---------- */
.searchbar{position:relative;z-index:6;background:var(--cloud);border-radius:3px;box-shadow:0 1px 0 rgba(0,0,0,.04);
  display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:0;border:1px solid var(--line);max-width:var(--maxw);margin:-36px auto 0}
.searchbar .f{padding:14px 18px;border-right:1px solid var(--line)}
.searchbar .f label{display:block;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:3px}
.searchbar .f .val{font-size:.95rem;color:var(--basalt)}
.searchbar .go{display:flex;align-items:center;justify-content:center;padding:0 28px;background:var(--geo-deep);color:#fff;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;cursor:pointer}
@media(max-width:780px){.searchbar{grid-template-columns:1fr;margin-top:0}.searchbar .f{border-right:none;border-bottom:1px solid var(--line)}.searchbar .go{padding:16px}}

/* ---------- sections ---------- */
section{padding:84px 0}
.section-head{max-width:62ch}
.section-head.c{margin:0 auto;text-align:center}
.section-head h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:12px 0 10px}
.section-head p{font-size:1.08rem;color:var(--muted)}
.band{background:var(--basalt);color:#f3ead0}
.band h2{color:#fff}
.band .section-head p{color:#b9c6c5}
.band.steam{background:var(--steam);color:var(--basalt)}
.band.steam h2{color:var(--basalt)}.band.steam .section-head p{color:#4f5f5f}

/* ---------- modes filter ---------- */
.modes{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;justify-content:center}
.mode{display:flex;align-items:center;gap:9px;border:1px solid var(--line);background:var(--cloud);border-radius:2px;padding:11px 18px;cursor:pointer;transition:border-color .2s}
.mode:hover{border-color:var(--geo)}
.mode .ic{width:26px;height:26px;border-radius:50%;border:1px solid var(--geo);color:var(--geo);display:flex;align-items:center;justify-content:center;font-size:.8rem}
.mode b{font-family:"Jost";font-weight:500;font-size:.9rem;letter-spacing:.04em}

/* ---------- cards ---------- */
.grid{display:grid;gap:26px;margin-top:36px}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.grid.c4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.grid.c3,.grid.c4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid.c2,.grid.c3,.grid.c4{grid-template-columns:1fr}}
.card{background:var(--cloud);border:1px solid var(--line);border-radius:3px;overflow:hidden;display:flex;flex-direction:column}
.card .media{height:210px}
.card .body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.card h3{font-size:1.05rem;margin-bottom:7px}
.card .ttl{font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-weight:500;line-height:1.1;margin-bottom:8px;color:var(--basalt)}
.card p{font-size:.95rem;color:var(--muted);flex:1}
.card .row2{display:flex;align-items:center;justify-content:space-between;margin-top:18px}
.card .price{font-family:"Jost";font-weight:500;font-size:.95rem;color:var(--basalt)}
.card .price span{font-weight:300;color:var(--muted);font-size:.8rem}
.chip{display:inline-block;font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;padding:5px 12px;border-radius:2px;margin:0 6px 6px 0}
.chip.geo{background:var(--steam);color:var(--geo-deep)}
.chip.moss{background:#e3eadf;color:#3f5a3c}

/* ---------- article / journal ---------- */
.article{max-width:760px;margin:0 auto;padding:0 32px}
.article .hero-lite{padding:120px 0 30px}
.article h1{font-size:clamp(2.2rem,4.6vw,3.3rem);margin:14px 0 14px;max-width:24ch}
.article .eyebrow{display:none}
.article .dek{font-size:1.2rem;color:var(--muted);font-family:"Jost",sans-serif;font-weight:300;line-height:1.5;margin-bottom:10px}
.article .byline{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:400}
.article .lede{font-size:1.18rem;margin:26px 0}
.article-body p{font-size:1.06rem;margin:0 0 20px}
.article-body h2{font-size:1.9rem;margin:42px 0 12px}
.article-body h3{font-size:1.15rem;margin:28px 0 8px;color:var(--basalt)}
.article-body ul{margin:0 0 20px 1.1rem}
.article-body li{font-size:1.05rem;margin:7px 0}
.article-body blockquote{border-left:2px solid var(--geo);padding:6px 22px;margin:26px 0;font-family:"Cormorant Garamond",serif;font-size:1.4rem;font-weight:400;color:var(--geo-deep)}
.article-body .figure{margin:30px 0}
.article-body .figure .media{height:340px;border-radius:3px}
.article-body .figure figcaption{font-size:.82rem;color:var(--muted);margin-top:8px}
.callout{background:var(--steam);border-radius:3px;padding:22px 26px;margin:30px 0}
.callout .eyebrow{margin-bottom:6px}
.callout .ttl{font-family:"Cormorant Garamond",serif;font-size:1.4rem;color:var(--basalt);margin-bottom:6px}

/* journal index list */
.post-list{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px}
@media(max-width:860px){.post-list{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.post-list{grid-template-columns:1fr}}
.post{display:flex;flex-direction:column;background:var(--cloud);border:1px solid var(--line);border-radius:3px;overflow:hidden}
.post .media{height:180px}
.post .body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.post .cat{font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--geo-deep);font-weight:500;margin-bottom:8px}
.post .ttl{font-family:"Cormorant Garamond",serif;font-size:1.4rem;font-weight:500;line-height:1.12;color:var(--basalt);margin-bottom:8px}
.post p{font-size:.92rem;color:var(--muted);flex:1}
.post .more{margin-top:14px;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--geo-deep);font-weight:500}

/* ---------- breadcrumbs ---------- */
.crumbs{font-size:.78rem;color:var(--muted);padding-top:14px}
.crumbs a{color:var(--muted)}

/* ---------- spring detail pages ---------- */
.detail{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:start;margin-top:36px}
@media(max-width:820px){.detail{grid-template-columns:1fr}}
.factbox{background:var(--cloud);border:1px solid var(--line);border-radius:3px;padding:24px;position:sticky;top:96px}
.factbox .price{font-family:"Cormorant Garamond",serif;font-size:1.8rem;color:var(--basalt)}
.factbox .price span{font-family:"Jost";font-size:.82rem;color:var(--muted);font-weight:300}
.factbox ul{list-style:none;margin:12px 0}
.factbox li{display:flex;justify-content:space-between;gap:10px;font-size:.9rem;padding:8px 0;border-bottom:1px solid var(--line)}
.factbox li span{color:var(--muted)}
.factbox li strong{font-weight:500;text-align:right}
.related{border-top:1px solid var(--line);margin-top:30px;padding-top:22px}
.related a{display:inline-block;margin:6px 16px 0 0;font-size:.92rem;color:var(--geo-deep)}
.spring .nm a{color:var(--basalt);text-decoration:none}
.spring .nm a:hover{color:var(--geo-deep)}
.card .ttl a{color:inherit;text-decoration:none}
.card .ttl a:hover{color:var(--geo-deep)}
.foot{background:var(--basalt);color:#aebcbb;padding:54px 0 28px;margin-top:60px}
.foot .cols{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px;border-bottom:1px solid #34433f;padding-bottom:30px;margin-bottom:22px}
.foot .brand{color:#fff}
.foot a{display:block;color:#aebcbb;padding:4px 0;font-size:.88rem}
.foot a:hover{color:#fff}
.foot strong{color:#fff;font-weight:500;display:block;margin-bottom:8px;font-family:"Jost"}
.foot .fine{font-size:.8rem;opacity:.7;letter-spacing:.05em}

/* ---------- placeholder note ---------- */
.devnote{background:#fff;border:1px dashed var(--moss);color:#566b50;font-size:.82rem;padding:13px 18px;border-radius:6px;margin:24px auto;max-widt