/* ===========================================================
   Skandia Kollektiv — shared site stylesheet
   Tokens + chrome (header, drawer, footer, sticky corner) +
   common page patterns. Matches the approved homepage exactly.
   =========================================================== */
:root{
  --cream:#F9F9E8; --slate:#58718A; --slate-d:#4d6379; --sage:#979D84; --sage-d:#878d75;
  --mist:#D1D6CF; --charcoal:#303030; --ink:#111111; --btn-text:#463939;
  --serif:'Antic Didone',Georgia,'Times New Roman',serif;
  --sans:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --maxw:1260px; --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;font-family:var(--sans);font-weight:300;color:var(--ink);background:#fff;line-height:1.6;font-size:16px;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:400;color:var(--ink);line-height:1.25;margin:0;}
p{margin:0 0 1em;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 30px;}
.section{padding:90px 0;position:relative;}
.section--cream{background:var(--cream);}
.section--mist{background:var(--mist);}
.section--slate{background:var(--slate);color:var(--cream);}
.section--charcoal{background:var(--charcoal);color:var(--cream);}
.h-center{text-align:center;}
.lead{max-width:820px;margin-left:auto;margin-right:auto;}
.eyebrow{display:block;font-family:var(--sans);font-weight:500;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--slate);margin-bottom:14px;}

/* Buttons — square, 50px, Poppins 16/300, WHITE text */
.btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;
  font-family:var(--sans);font-weight:300;font-size:16px;line-height:1.2;color:#fff;
  padding:0 26px;min-height:50px;cursor:pointer;border:0;transition:filter .25s var(--ease),transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease);}
.btn:hover{filter:brightness(.93);transform:translateY(-1px);}
.btn-slate{background:var(--slate);}
.btn-sage{background:var(--sage);}
.btn-ghost{background:transparent;border:1px solid rgba(249,249,232,.5);color:var(--cream);}
.btn-outline{background:transparent;border:1px solid rgba(249,249,232,.6);color:var(--cream);}
.btn-outline:hover{background:var(--cream);color:var(--charcoal);}
.btn-outline-dark{background:transparent;border:1px solid rgba(88,113,138,.5);color:var(--slate);}
.btn-outline-dark:hover{background:var(--slate);color:#fff;}

/* Header */
.hd{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;
  padding:22px 40px;transition:background .3s var(--ease),padding .3s var(--ease);}
.hd::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,rgba(20,22,26,.45),rgba(20,22,26,0));opacity:1;transition:opacity .3s;z-index:-1;}
.hd.scrolled{background:rgba(48,48,48,.96);padding:12px 40px;box-shadow:0 2px 16px rgba(0,0,0,.2);}
.hd.scrolled::before{opacity:0;}
.hd .logo img{height:60px;width:auto;transition:height .3s var(--ease);}
.hd.scrolled .logo img{height:46px;}
.burger{display:inline-flex;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:8px;}
.burger span{display:block;width:32px;height:2px;background:var(--cream);transition:.3s var(--ease);}
/* Header variant for pages with a light hero top (keeps logo/burger visible) */
.hd.hd--solid{background:rgba(48,48,48,.96);}
.hd.hd--solid::before{opacity:0;}

/* Drawer */
.backdrop{position:fixed;inset:0;background:rgba(20,20,20,.5);opacity:0;pointer-events:none;z-index:1100;transition:opacity .35s;}
.backdrop.open{opacity:1;pointer-events:auto;}
.drawer{position:fixed;top:0;right:0;height:100%;width:390px;max-width:88vw;background:var(--charcoal);z-index:1200;
  transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:28px 36px;overflow-y:auto;}
.drawer.open{transform:translateX(0);}
.drawer-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:26px;}
.drawer-top img{height:50px;width:auto;}
.drawer-x{background:none;border:0;color:var(--cream);font-size:30px;line-height:1;cursor:pointer;}
.drawer-addr{display:block;font-family:var(--sans);font-weight:300;font-size:.95rem;color:rgba(249,249,232,.82);line-height:1.55;margin:0 0 16px;}
.drawer-addr:hover{color:var(--sage);}
.drawer-book{width:100%;}
.drawer nav{display:flex;flex-direction:column;margin-top:14px;border-top:1px solid rgba(249,249,232,.12);padding-top:6px;}
.drawer-policies{display:block;width:100%;text-align:center;margin-top:6px;color:rgba(249,249,232,.7);font-size:.95rem;}
.drawer-policies:hover{color:var(--sage);}
.drawer nav a{font-family:var(--serif);font-size:1.3rem;color:var(--cream);padding:11px 0;border-bottom:1px solid rgba(249,249,232,.12);}
.drawer nav a:hover{color:var(--sage);}
.grp{font-family:var(--sans);font-weight:500;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sage);margin:20px 0 4px;}
.drawer .sub{display:flex;flex-direction:column;}
.drawer .sub a{display:block;font-size:1.05rem;color:rgba(249,249,232,.82);padding:9px 0 9px 16px;border-bottom:1px solid rgba(249,249,232,.07);}
.drawer-cta{margin-top:24px;display:flex;flex-direction:column;gap:12px;}
.drawer-cta .btn{width:100%;}

/* Interior page hero banner */
.page-hero{position:relative;min-height:52vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;background:#1a1c20;}
.page-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.page-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(18,20,24,.6),rgba(18,20,24,.35));}
.page-hero .inner{position:relative;z-index:2;padding:150px 30px 70px;max-width:1000px;}
.page-hero .eyebrow{color:var(--cream);opacity:.92;}
.page-hero h1{font-family:var(--serif);font-weight:400;color:var(--cream);font-size:clamp(2.2rem,4.4vw,54px);line-height:1.3;}
.page-hero p{color:rgba(249,249,232,.92);font-size:1.05rem;line-height:1.6;margin-top:16px;max-width:720px;margin-left:auto;margin-right:auto;}

/* Prose / article text */
.prose{max-width:880px;margin:0 auto;font-size:16px;line-height:1.85;color:#2a2a2a;}
.prose h2{font-size:clamp(1.6rem,2.6vw,36px);line-height:1.4;color:var(--ink);margin:1.4em 0 .5em;}
.prose h3{font-size:clamp(1.3rem,2vw,26px);line-height:1.4;color:var(--slate);margin:1.2em 0 .4em;}
.prose p{margin:0 0 1.1em;}
.prose a{color:var(--slate);text-decoration:underline;}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em;}
.prose li{margin:.4em 0;}

/* Two-column text + media */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.grid-2 .media{overflow:hidden;}
.grid-2 .media img{width:100%;height:100%;object-fit:cover;}
.grid-2 h2{font-size:clamp(1.7rem,2.8vw,40px);line-height:1.4;margin-bottom:18px;}

/* Centered section heading */
.sec-head{text-align:center;max-width:900px;margin:0 auto 50px;}
.sec-head h2{font-size:clamp(1.9rem,3.2vw,46px);line-height:1.35;margin-bottom:14px;}
.sec-head p{color:#444;font-size:1.02rem;line-height:1.7;}

/* FAQ (native details) */
.faq{max-width:880px;margin:0 auto;}
.faq details{border-bottom:1px solid rgba(48,48,48,.12);}
.faq summary{list-style:none;cursor:pointer;padding:20px 0;font-family:var(--serif);font-size:1.2rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:16px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:'+';color:var(--slate);font-size:1.5rem;transition:transform .3s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq details p{color:#444;line-height:1.75;padding:0 0 20px;margin:0;}

/* Gallery grid */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.gallery a,.gallery .cell{position:relative;display:block;overflow:hidden;aspect-ratio:3/4;}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease);}
.gallery a:hover img{transform:scale(1.05);}

/* Newsletter (shared, above footer) */
.news{background:var(--cream);text-align:center;}
.news h2{font-size:clamp(1.8rem,2.4vw,32px);color:var(--slate);margin-bottom:30px;}
.nl-form{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:1100px;margin:0 auto;}
.nl-form .field{display:flex;flex-direction:column;text-align:left;}
.nl-form label{font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:#7c7c70;margin-bottom:5px;}
.nl-form input{padding:13px 14px;border:1px solid #cfcfc2;background:#fff;font-family:var(--sans);font-size:.95rem;color:var(--ink);}
.nl-form input:focus{outline:none;border-color:var(--slate);}
.nl-form .submit{grid-column:1/-1;margin-top:6px;}
.nl-form .submit .btn{min-width:200px;}

/* Footer */
.foot{background:var(--cream);padding:64px 0 0;}
.foot-grid{display:grid;grid-template-columns:1.2fr 1.3fr 1fr;gap:44px;align-items:start;}
.foot-logo img{width:240px;height:auto;}
.foot-contact a{display:flex;align-items:flex-start;gap:11px;color:#3a3a3a;font-size:.95rem;padding:7px 0;}
.foot-contact a:hover{color:var(--slate);}
.foot-contact svg{flex:0 0 auto;margin-top:3px;color:var(--slate);}
.foot-social{display:flex;gap:12px;margin-top:14px;}
.foot-social a{width:38px;height:38px;border:1px solid rgba(88,113,138,.4);display:flex;align-items:center;justify-content:center;color:var(--slate);transition:.25s;}
.foot-social a:hover{background:var(--slate);color:#fff;}
.foot-right{display:flex;flex-direction:column;align-items:flex-start;gap:14px;}
.foot-right a.link{color:#3a3a3a;}
.foot-right a.link:hover{color:var(--slate);}
.copybar{margin-top:56px;background:var(--slate);color:var(--cream);text-align:center;padding:18px 10px;font-size:.85rem;}

/* Sticky corner */
.corner{position:fixed;right:18px;bottom:22px;z-index:900;display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.rail{display:flex;flex-direction:column;gap:10px;align-items:center;background:rgba(60,60,60,.78);padding:11px 7px;border-radius:34px;}
.rail a{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;}
.rail .ig{background:radial-gradient(circle at 30% 110%,#fdf497 0,#fd5949 45%,#d6249f 60%,#285AEB 90%);}
.rail .fb{background:#3373EE;}
.rail .gg{background:#fff;color:#EA4335;}
.corner>a{display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:30px;font-family:var(--sans);font-weight:600;font-size:14px;color:#fff;box-shadow:0 6px 18px rgba(0,0,0,.25);}
.corner .book{background:var(--sage);}
.corner .call{background:var(--charcoal);}
.mbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:950;background:var(--charcoal);grid-template-columns:repeat(3,1fr);box-shadow:0 -3px 16px rgba(0,0,0,.25);}
.mbar a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:9px 4px;color:var(--cream);font-size:.66rem;letter-spacing:.05em;text-transform:uppercase;}
.mbar a.book{background:var(--sage);}
.mbar svg{width:20px;height:20px;}

/* Responsive */
@media (max-width:1024px){
  .hd .logo img{height:50px;}
  .hd.scrolled .logo img{height:42px;}
  .section{padding:70px 0;}
  .grid-2{grid-template-columns:1fr;gap:36px;}
  .gallery{grid-template-columns:repeat(2,1fr);}
  .nl-form{grid-template-columns:repeat(2,1fr);}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media (max-width:680px){
  .hd{padding:16px 20px;}
  .hd .logo img{height:40px;}
  .hd.scrolled .logo img{height:34px;}
  .wrap{padding:0 20px;}
  .section{padding:54px 0;}
  .page-hero{min-height:44vh;}
  .page-hero .inner{padding:120px 20px 56px;}
  .gallery{grid-template-columns:1fr 1fr;}
  .nl-form{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;gap:34px;}
  .corner{display:none;}
  .mbar{display:grid;}
  body{padding-bottom:58px;}
}
