/* ============================================================
   LITTHOUSE — varje bok är ett rum
   Bold editorial art-pop theme. The House (home) is dark &
   intimate; the Rooms (posts) carry their own accent.
   Per-room accent: set on a single post via Code Injection
   (see README). Default accent = electric blue.
   ============================================================ */

:root{
  --ink:#0d0d0f;
  --ink-2:#16161b;
  --off:#f4f0e7;
  --off-2:#e9e3d6;
  --muted:#9b978c;
  --muted-d:#7c7a72;
  --line:#e2dccd;
  --line-dk:rgba(255,255,255,.14);
  --electric:#2f3bff;

  /* per-room accent — override on a single post via Code Injection */
  --accent:#2f3bff;
  --accent-ink:#1f2bff;

  --serif:"Fraunces", Georgia, serif;
  --sans:"Space Grotesk", system-ui, sans-serif;
  --body:"Inter", system-ui, sans-serif;
  --maxw:980px;
  --read:680px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--off);color:var(--ink);font-family:var(--body);font-size:1.08rem;line-height:1.7;-webkit-font-smoothing:antialiased}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.narrow{max-width:620px;margin:0 auto}
.read{max-width:var(--read);margin:0 auto}
a{color:inherit}
a:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
img{max-width:100%;display:block}

/* widow / orphan control */
h1,h2,h3,.manifesto p,.froom h2,.hero h1{text-wrap:balance}
p,.lead,.desc,.logline,.post-content p{text-wrap:pretty}

/* ---------------- bar ---------------- */
.bar{position:sticky;top:0;z-index:40;background:rgba(13,13,15,.92);backdrop-filter:blur(8px);color:var(--off)}
.bar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:60px;gap:18px}
.logo{font-family:var(--sans);font-weight:700;font-size:1.12rem;letter-spacing:.02em;text-transform:uppercase;
  text-decoration:none;color:var(--off);display:flex;align-items:center;gap:8px}
.logo .dot{width:7px;height:7px;background:var(--electric);border-radius:50%;display:inline-block;flex:none}
.bar .right{display:flex;align-items:center;gap:22px}
.nav{display:none;gap:22px}
@media(min-width:740px){.nav{display:flex}}
.nav-item{font-family:var(--sans);font-size:.78rem;letter-spacing:.04em;color:#c9c6bd;text-decoration:none}
.nav-item:hover,.nav-current{color:var(--off)}
.join{font-family:var(--sans);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--off);
  background:var(--electric);padding:8px 15px;border-radius:100px;text-decoration:none;white-space:nowrap}
.join:hover{background:var(--accent-ink)}

/* ---------------- hero (House / Lobby) ---------------- */
.hero{background:var(--ink);color:var(--off);position:relative;overflow:hidden;padding:104px 0 92px}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 78% 8%, rgba(47,59,255,.30), transparent 60%)}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-family:var(--serif);font-weight:500;font-size:3.4rem;line-height:1.0;letter-spacing:-.02em;margin:0;max-width:14ch}
.hero h1 em{font-style:italic;font-weight:400}
.hero .lead{font-size:1.18rem;line-height:1.55;color:#cdcabf;max-width:40ch;margin:30px 0 36px}
.hero .cta{font-family:var(--sans);font-weight:500;font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);background:var(--off);padding:14px 24px;border-radius:100px;text-decoration:none;display:inline-block}
.hero .cta:hover{background:#fff}
.hero .cta .ar{color:var(--electric)}

/* ---------------- section + label ---------------- */
section{padding:78px 0}
.label{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-d);
  margin:0 0 22px;display:flex;align-items:center;gap:.7em}
.label .sq{width:7px;height:7px;background:var(--electric);flex:none}

/* ---------------- featured room ---------------- */
.feature{background:var(--off-2)}
.froom{display:grid;gap:30px;align-items:center}
@media(min-width:720px){.froom{grid-template-columns:.85fr 1.15fr;gap:46px}}
.froom .door{aspect-ratio:2/3;border-radius:4px;position:relative;overflow:hidden;
  background-size:cover;background-position:center;
  box-shadow:0 40px 70px -34px rgba(13,13,15,.6);display:flex;align-items:center;justify-content:center;padding:26px;
  background-color:#15161d;background-image:linear-gradient(160deg,#23252f,#0f1014)}
.froom .door .stamp{position:absolute;top:18px;right:18px;font-family:var(--sans);font-weight:700;font-size:.62rem;
  letter-spacing:.12em;text-transform:uppercase;color:rgba(244,240,231,.72)}
.froom .door .dtitle{font-family:var(--serif);font-style:italic;font-weight:500;color:#f1ece0;font-size:2rem;line-height:1.05}
.froom h2{font-family:var(--serif);font-weight:500;font-size:2.4rem;line-height:1.02;margin:.3em 0 .15em;letter-spacing:-.01em}
.froom .by{font-family:var(--sans);font-size:.82rem;letter-spacing:.04em;color:var(--muted-d);margin:0 0 18px}
.froom .desc{font-size:1.1rem;line-height:1.55;color:#3b3a34;margin:0 0 26px}
.froom .enter{font-family:var(--sans);font-weight:500;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink);border-bottom:2px solid var(--electric);padding-bottom:4px;text-decoration:none}

/* ---------------- rooms grid (book-cover doors) ---------------- */
.rooms .grid{display:grid;gap:26px 18px}
@media(min-width:560px){.rooms .grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.rooms .grid{grid-template-columns:1fr 1fr 1fr}}
.room{display:flex;flex-direction:column;text-decoration:none;color:var(--ink)}
.room .door{position:relative;aspect-ratio:2/3;border-radius:3px;overflow:hidden;
  background-size:cover;background-position:center;background-color:#11151f;
  background-image:linear-gradient(160deg,#1b2740,#0a0f1d);
  box-shadow:0 24px 44px -22px rgba(13,13,15,.5);
  display:flex;align-items:center;justify-content:center;transition:transform .35s ease}
.room:hover .door{transform:translateY(-5px)}
.room .door .stamp{position:absolute;top:12px;left:14px;font-family:var(--sans);font-weight:700;font-size:.56rem;
  letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.room .door .door-title{font-family:var(--serif);font-style:italic;color:#e8e3d6;font-size:1.3rem;line-height:1.1;text-align:center;padding:22px}
.room-cap{padding-top:15px}
.room .rt{font-family:var(--serif);font-weight:500;font-size:1.24rem;line-height:1.12;color:var(--ink);display:block}
.room .ra{font-family:var(--sans);font-size:.82rem;letter-spacing:.02em;color:var(--muted-d);margin-top:3px;display:block}
.room .go{font-family:var(--sans);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-d);margin-top:11px;display:block;transition:color .25s}
.room:hover .go{color:var(--electric)}

/* ---------------- manifesto ---------------- */
.manifesto{text-align:center}
.manifesto p{font-family:var(--serif);font-weight:400;font-size:1.9rem;line-height:1.32;letter-spacing:-.01em;margin:0 auto;max-width:20ch}
.manifesto p em{font-style:italic;color:var(--electric)}
.manifesto .small{font-family:var(--body);font-size:1.05rem;line-height:1.6;color:#4a493f;max-width:42ch;margin:30px auto 0}

/* ---------------- move in / newsletter ---------------- */
.movein{background:var(--off-2)}
.movein h2{font-family:var(--serif);font-weight:500;font-size:2.2rem;line-height:1.05;margin:0 0 14px;max-width:16ch}
.movein > .narrow > p{color:#4a493f;max-width:42ch;margin:0 0 26px}
.movein ul{list-style:none;padding:0;margin:0 0 30px}
.movein li{padding:11px 0;border-top:1px solid var(--line);font-size:1.02rem;display:flex;gap:12px;align-items:baseline}
.movein li:first-child{border-top:none}
.movein li .sq{width:6px;height:6px;background:var(--electric);flex:none;transform:translateY(7px)}
.brev-form{display:flex;gap:10px;flex-wrap:wrap;max-width:440px}
.brev-form input{flex:1;min-width:200px;background:var(--off);border:1px solid var(--line);border-radius:100px;
  padding:14px 22px;font-family:var(--body);font-size:.95rem;color:var(--ink)}
.brev-form input::placeholder{color:#a8a499}
.brev-form button{background:var(--electric);border:none;border-radius:100px;padding:14px 28px;font-family:var(--sans);
  font-weight:500;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:#fff;cursor:pointer}
.brev-form button:hover{background:var(--accent-ink)}

/* ---------------- post / book ROOM ---------------- */
.post-hero{background:var(--ink);color:var(--off);position:relative;overflow:hidden;padding:64px 0 70px;text-align:center}
.post-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 50% at 50% 0%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 62%)}
.post-hero .wrap{position:relative;z-index:2}
.post-hero .stamp{font-family:var(--sans);font-weight:700;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,240,231,.6);margin:0 0 30px}
.post-hero .cover{width:210px;aspect-ratio:2/3;margin:0 auto 30px;border-radius:3px;overflow:hidden;
  box-shadow:0 36px 66px -28px rgba(0,0,0,.7);background:#15161d}
.post-hero .cover img{width:100%;height:100%;object-fit:cover}
.post-hero .kicker{font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin:0 0 18px}
.post-hero h1{font-family:var(--serif);font-weight:500;font-size:2.9rem;line-height:1.04;letter-spacing:-.015em;margin:0 0 .25em}
.post-hero h1 em{font-style:italic;font-weight:400}
.post-hero .logline{font-family:var(--serif);font-style:italic;font-size:1.2rem;line-height:1.5;color:#cdcabf;max-width:34ch;margin:0 auto}

.post-meta{padding:34px 0 0;text-align:center}
.meta-line{font-family:var(--sans);font-size:.8rem;letter-spacing:.02em;color:var(--muted-d);margin:0 0 18px}
.meta-line strong{color:var(--ink);font-weight:500}
.tags{display:flex;flex-wrap:wrap;gap:9px;list-style:none;padding:0;margin:0;justify-content:center}
.tags li{font-family:var(--sans);font-size:.72rem;letter-spacing:.03em;color:var(--ink);border:1px solid var(--line);
  border-radius:100px;padding:5px 13px;background:var(--off-2)}

/* ---------------- post content (Koenig) ---------------- */
.post-content{padding:30px 0 10px}
.post-content .read > *{margin-top:0}
.post-content p{margin:0 0 1.3em;font-size:1.18rem;line-height:1.78}
.post-content h2{font-family:var(--serif);font-weight:500;font-size:1.9rem;line-height:1.14;margin:2.2em 0 .55em}
.post-content h3{font-family:var(--serif);font-weight:500;font-size:1.4rem;line-height:1.2;margin:1.8em 0 .45em}
.post-content h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);
  margin:2.6em 0 1em;display:flex;align-items:center;gap:.7em;font-weight:500}
.post-content h4::before{content:"";width:7px;height:7px;background:var(--accent);flex:none}
.post-content h4::after{content:"";flex:1;height:1px;background:var(--line)}
.post-content a{color:var(--accent);text-decoration:none;border-bottom:1px solid color-mix(in srgb, var(--accent) 35%, transparent)}
.post-content a:hover{border-bottom-color:var(--accent)}
.post-content strong{font-weight:600}
.post-content blockquote{margin:1.8em 0;padding:0;font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:1.6rem;line-height:1.34;color:var(--ink);text-align:center;border:none}
.post-content blockquote::before{content:"";display:block;width:30px;height:3px;background:var(--accent);margin:0 auto 24px}
.post-content hr{border:none;height:1px;background:var(--line);margin:3em auto;width:60%}
.post-content ul,.post-content ol{margin:0 0 1.3em;padding-left:1.2em}
.post-content li{margin:0 0 .5em}
.post-content figure{margin:2.2em 0}
.post-content img{border-radius:3px;margin:0 auto}
.post-content figcaption{font-family:var(--sans);font-size:.76rem;color:var(--muted-d);margin-top:10px;line-height:1.5;text-align:center}

.kg-card{margin:2.2em 0}
.kg-width-wide{margin-left:-40px;margin-right:-40px}
.kg-width-full{margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.kg-gallery-container{display:flex;flex-direction:column;gap:10px}
.kg-gallery-row{display:flex;gap:10px}
.kg-bookmark-container{display:flex;border:1px solid var(--line);border-radius:5px;overflow:hidden;background:var(--off-2);text-decoration:none;border-bottom:none}
.kg-bookmark-content{padding:18px;flex:1}
.kg-bookmark-title{font-family:var(--serif);font-size:1.1rem;color:var(--ink)}
.kg-bookmark-description{font-size:.95rem;color:#4a493f;margin-top:6px}
.kg-bookmark-thumbnail img{width:150px;height:100%;object-fit:cover}
.kg-callout-card{border-radius:4px;padding:20px 22px;background:var(--off-2);border:1px solid var(--line);display:flex;gap:14px}

/* native audio card = the room's MOOD / sound dimension */
.kg-audio-card{background:var(--ink);color:var(--off);border-radius:6px;padding:14px 18px;margin:2.2em auto}
.kg-audio-title{font-family:var(--serif);font-style:italic;color:var(--off)}
.kg-audio-play-icon,.kg-audio-pause-icon{color:var(--accent)}
.kg-audio-current-time{color:var(--off)}
.kg-audio-time{color:#a6a299}
.kg-audio-seek-slider .kg-audio-seek-bar{background:var(--accent)}

/* ---------------- comments (members discussion in the room) ---------------- */
.post-comments{padding:64px 0 0}
.discuss-intro{text-align:center;margin:0 0 30px}
.discuss-title{font-family:var(--serif);font-weight:500;font-style:italic;font-size:2rem;line-height:1.1;margin:0 0 .3em;color:var(--text);text-wrap:balance}
.discuss-sub{font-family:var(--sans);font-size:.92rem;letter-spacing:.02em;color:var(--muted);margin:0}
.post-comments h3.comments-title{font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin:0 0 18px}

/* ---------------- read next ---------------- */
.next{padding:70px 0 0}
.next .grid{display:grid;gap:16px}
@media(min-width:620px){.next .grid{grid-template-columns:1fr 1fr}}

/* ---------------- archives / pages / error ---------------- */
.archive-hero,.page-hero{background:var(--ink);color:var(--off);padding:88px 0 80px;text-align:center}
.archive-hero .kicker,.page-hero .kicker{font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--electric);margin:0 0 16px}
.archive-hero h1,.page-hero h1{font-family:var(--serif);font-weight:500;font-size:2.8rem;line-height:1.05;margin:0}
.archive-hero .logline,.page-hero .logline{color:#cdcabf;max-width:40ch;margin:18px auto 0;font-family:var(--serif);font-style:italic}
.page-article .post-content{padding-top:34px}
.error-page{text-align:center;padding:120px 0}
.error-page .kicker{font-family:var(--sans);font-size:.8rem;letter-spacing:.2em;color:var(--electric)}
.error-page h1{font-family:var(--serif);font-weight:500;font-size:2.4rem;margin:.2em 0 .4em}
.error-page a{color:var(--accent)}

/* ---------------- pagination ---------------- */
.pagination{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:48px;font-family:var(--sans);
  font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-d)}
.pagination a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:3px}

/* ---------------- footer ---------------- */
.site-foot{background:var(--ink);color:#b6b3aa;padding:66px 0 40px}
.site-foot .logo{color:var(--off);font-size:1.5rem;margin-bottom:0}
.site-foot .nav{display:flex;margin-top:30px;border-top:1px solid var(--line-dk);padding-top:24px}
.site-foot .nav-item{color:#8a877e}
.site-foot .nav-item:hover{color:var(--off)}
.site-foot .spotify-follow{display:inline-flex;align-items:center;gap:13px;margin-top:30px;text-decoration:none;border:1px solid var(--line-dk);border-radius:100px;padding:9px 22px 9px 11px;transition:border-color .2s}
.site-foot .spotify-follow:hover{border-color:#1db954}
.site-foot .spotify-follow .sp-ic{width:32px;height:32px;flex:none;display:flex;align-items:center;justify-content:center}
.site-foot .spotify-follow .sp-ic svg{width:32px;height:32px;fill:#1db954}
.site-foot .spotify-follow .sp-t{display:block;font-family:var(--sans);font-size:.9rem;color:var(--off);font-weight:500}
.site-foot .spotify-follow .sp-s{display:block;font-family:var(--sans);font-size:.72rem;color:#8a877e;margin-top:2px}

/* ---------------- reveal ---------------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

@media(min-width:680px){
  .hero h1{font-size:4.6rem}
  .manifesto p{font-size:2.5rem}
  .post-hero h1{font-size:3.3rem}
  .post-content h2{font-size:2.1rem}
}
@media(max-width:520px){.kg-width-wide{margin-left:0;margin-right:0}}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .room:hover{transform:none}
}
