/*
Theme Name: Helenas Minimal
Theme URI: https://helenas.nu
Author: Krister Lindholm
Description: Minimalistiskt, snabbt och SEO-fokuserat tema för Helena Knapp. Klassiskt PHP-tema, system-fonts, JSON-LD inbyggt, diskret rörelse.
Version: 0.2.0
License: GPL-2.0-or-later
Text Domain: helenas-minimal
*/

/* ---------- Tokens ---------- */
:root{
  --fg:#15110e;
  --fg-soft:#5a5048;
  --fg-mute:#8a7e72;
  --bg:#fdfbf7;
  --bg-soft:#f4ede2;
  --bg-card:#ffffff;
  --line:#ece4d6;
  --line-strong:#d8cdb9;
  --accent:#c44a2c;
  --accent-2:#e8a35a;
  --accent-dark:#8a3221;
  --shadow-1: 0 1px 2px rgba(20,15,10,.04), 0 2px 8px rgba(20,15,10,.04);
  --shadow-2: 0 6px 20px rgba(20,15,10,.08), 0 2px 6px rgba(20,15,10,.05);
  --maxw:680px;
  --wide:1180px;
  --radius-s:6px;
  --radius:14px;
  --radius-l:24px;
  --pad:1.25rem;
  --ease: cubic-bezier(.2,.7,.2,1);
}

@media (prefers-color-scheme: dark){
  :root{
    --fg:#f4eee3;
    --fg-soft:#c8bfb1;
    --fg-mute:#9b9182;
    --bg:#15110e;
    --bg-soft:#1f1a14;
    --bg-card:#1a1611;
    --line:#2c2620;
    --line-strong:#3a3329;
    --accent:#e8744d;
    --accent-2:#f0b066;
    --shadow-1: 0 1px 2px rgba(0,0,0,.3), 0 2px 8px rgba(0,0,0,.3);
    --shadow-2: 0 8px 28px rgba(0,0,0,.5);
  }
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Inter var","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:17px;line-height:1.65;color:var(--fg);background:var(--bg);
  font-feature-settings:"ss01","cv11";
  -webkit-font-smoothing:antialiased;
}
@supports (font-variation-settings: normal){body{font-family:"Inter var",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}}

img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--accent-dark)}
.entry-content a{text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:color-mix(in oklab, var(--accent) 50%, transparent)}
.entry-content a:hover{text-decoration-color:var(--accent)}

h1,h2,h3,h4{
  line-height:1.15;margin:1.6em 0 .5em;font-weight:700;letter-spacing:-0.025em;
  font-family:"Playfair Display",ui-serif,Georgia,Cambria,"Times New Roman",serif;
}
h1{font-size:clamp(2rem,4vw,2.8rem);margin-top:.2em}
h2{font-size:clamp(1.4rem,2.6vw,1.8rem)}
h3{font-size:1.2rem;font-family:inherit;letter-spacing:-0.015em}
p,ul,ol,blockquote{margin:0 0 1em}
hr{border:0;border-top:1px solid var(--line);margin:2.5rem 0}
blockquote{border-left:3px solid var(--accent);padding:.4em 1.2em;color:var(--fg-soft);margin-left:0;font-style:italic}
code,pre{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.95em}

.container{max-width:var(--wide);margin:0 auto;padding:0 var(--pad)}
.prose{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.prose img{border-radius:var(--radius)}

::selection{background:var(--accent);color:#fff}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .25s var(--ease), background .25s var(--ease);
}
.site-header.is-scrolled{border-bottom-color:var(--line)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem var(--pad);max-width:var(--wide);margin:0 auto}
.site-title{font-weight:700;font-size:1.35rem;letter-spacing:-0.03em;margin:0;font-family:"Playfair Display",ui-serif,Georgia,serif}
.site-title a{color:var(--fg)}
.site-title a::after{content:".";color:var(--accent)}
.site-tagline{font-size:.78rem;color:var(--fg-mute);margin:.05rem 0 0;letter-spacing:.02em}

.nav-toggle{display:none;background:none;border:1px solid var(--line);padding:.5rem .8rem;border-radius:999px;cursor:pointer;font:inherit;font-size:.9rem;color:var(--fg)}
.main-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:1.6rem;flex-wrap:wrap;align-items:center}
.main-nav a{color:var(--fg);font-size:.95rem;font-weight:500;position:relative;padding:.3rem 0}
.main-nav a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.main-nav a:hover{color:var(--fg)}
.main-nav a:hover::after,.main-nav .current-menu-item>a::after{transform:scaleX(1)}

.search-toggle{background:none;border:0;cursor:pointer;color:var(--fg);padding:.4rem;border-radius:999px;transition:background .2s var(--ease)}
.search-toggle:hover{background:var(--bg-soft)}
.search-form{display:flex;gap:.5rem;padding:.8rem var(--pad);border-top:1px solid var(--line);background:var(--bg-soft);animation:slidedown .25s var(--ease)}
.search-form[hidden]{display:none}
.search-form input[type=search]{flex:1;padding:.7rem 1rem;border:1px solid var(--line);border-radius:999px;font:inherit;background:var(--bg-card);color:var(--fg)}
.search-form input[type=search]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklab, var(--accent) 25%, transparent)}
.search-form button{padding:.7rem 1.4rem;border:0;background:var(--fg);color:var(--bg);border-radius:999px;cursor:pointer;font:inherit;font-weight:500;transition:transform .15s var(--ease)}
.search-form button:hover{transform:translateY(-1px)}

@keyframes slidedown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

@media (max-width:760px){
  .nav-toggle{display:inline-block}
  .main-nav{display:none;width:100%;order:3}
  .main-nav.is-open{display:block;animation:slidedown .25s var(--ease)}
  .main-nav ul{flex-direction:column;gap:0;padding:.4rem 0 .8rem}
  .main-nav a{display:block;padding:.7rem 0;border-bottom:1px solid var(--line);width:100%}
  .main-nav a::after{display:none}
  .site-header__inner{flex-wrap:wrap}
}

/* ---------- Main ---------- */
main{padding:2rem 0 3rem;min-height:55vh}
.entry-meta{color:var(--fg-mute);font-size:.85rem;margin:0 0 1.5em;text-transform:uppercase;letter-spacing:.08em;font-weight:500}
.entry-meta a{color:var(--fg-mute)}
.entry-meta a:hover{color:var(--accent)}
.entry-title{margin-top:0}
.featured{margin:0 0 2rem;background:var(--bg-soft);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-1)}
.featured img{width:100%;max-height:560px;object-fit:cover}

/* ---------- Archive grid ---------- */
.archive-header{text-align:center;padding:3rem 0 2.5rem;margin-bottom:1rem;position:relative}
.archive-header h1{margin:0}
.archive-header p{color:var(--fg-soft);margin-top:.6rem;font-size:1.05rem}
.cards{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.6rem}
.card{
  position:relative;
  background:var(--bg-card);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-1);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.card a{color:inherit;display:block;height:100%}
.card__media{aspect-ratio:4/3;background:linear-gradient(135deg,var(--bg-soft),var(--line));overflow:hidden;position:relative}
.card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(0,0,0,.18));opacity:0;transition:opacity .35s var(--ease)}
.card:hover .card__media::after{opacity:1}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.card:hover .card__media img{transform:scale(1.05)}
.card__body{padding:1.1rem 1.2rem 1.3rem}
.card__kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--accent);font-weight:600;margin:0 0 .3rem}
.card__title{margin:0 0 .35rem;font-size:1.1rem;font-weight:600;line-height:1.3;font-family:"Playfair Display",ui-serif,serif;letter-spacing:-0.01em}
.card__excerpt{margin:0;color:var(--fg-soft);font-size:.92rem;line-height:1.5}

/* ---------- Pagination ---------- */
.pagination{display:flex;gap:.4rem;justify-content:center;margin:3rem 0 1rem;flex-wrap:wrap}
.pagination a,.pagination span{padding:.55rem 1rem;border-radius:999px;text-decoration:none;color:var(--fg);transition:all .2s var(--ease);font-size:.9rem;font-weight:500}
.pagination a{background:var(--bg-soft)}
.pagination a:hover{background:var(--accent);color:#fff}
.pagination .current{background:var(--fg);color:var(--bg)}

/* ---------- Hero (front page) ---------- */
.hero{
  position:relative;
  padding:6rem 0 5rem;
  text-align:center;
  overflow:hidden;
  isolation:isolate;
}
.hero::before{
  content:"";position:absolute;z-index:-1;
  width:60vmax;height:60vmax;border-radius:50%;
  top:-20vmax;left:50%;transform:translateX(-50%);
  background:radial-gradient(closest-side, color-mix(in oklab, var(--accent-2) 35%, transparent), transparent 70%);
  filter:blur(40px);
  animation:blob 18s ease-in-out infinite alternate;
}
.hero::after{
  content:"";position:absolute;z-index:-1;
  width:40vmax;height:40vmax;border-radius:50%;
  bottom:-15vmax;right:-10vmax;
  background:radial-gradient(closest-side, color-mix(in oklab, var(--accent) 28%, transparent), transparent 70%);
  filter:blur(50px);
  animation:blob 22s ease-in-out infinite alternate-reverse;
}
@keyframes blob{
  0%{transform:translateX(-50%) translateY(0) scale(1)}
  100%{transform:translateX(-40%) translateY(20px) scale(1.1)}
}
.hero h1{font-size:clamp(2.2rem,5.5vw,4rem);margin:0 auto .8rem;max-width:18ch;line-height:1.05}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:500}
.hero p{color:var(--fg-soft);max-width:54ch;margin:0 auto;font-size:1.1rem}
.hero__cta{margin-top:2rem;display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
.btn{
  display:inline-block;padding:.85rem 1.7rem;border-radius:999px;font-weight:500;font-size:.95rem;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
  border:1px solid transparent;
}
.btn--primary{background:var(--fg);color:var(--bg)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-2);color:var(--bg)}
.btn--ghost{background:transparent;color:var(--fg);border-color:var(--line-strong)}
.btn--ghost:hover{border-color:var(--fg);color:var(--fg);transform:translateY(-2px)}

/* ---------- Sections ---------- */
.section{padding:4rem 0;position:relative}
.section--soft{background:var(--bg-soft)}
.section__head{text-align:center;margin-bottom:2.5rem}
.section__head h2{margin:0}
.section__lead{color:var(--fg-soft);margin:.4rem auto 0;max-width:48ch}
.section__more{text-align:center;margin-top:2.5rem}
.cat-chips{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.cat-chips a{display:inline-block;padding:.55rem 1.1rem;border:1px solid var(--line-strong);border-radius:999px;color:var(--fg);font-size:.9rem;background:var(--bg-card);transition:all .2s var(--ease)}
.cat-chips a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}

/* ---------- Drink single ---------- */
.drink-block{background:var(--bg-soft);border-radius:var(--radius);padding:1.7rem 1.8rem;margin:1.8rem 0;border:1px solid var(--line)}
.drink-block h2{margin-top:0;font-size:1rem;text-transform:uppercase;letter-spacing:.12em;font-family:inherit;color:var(--accent);font-weight:600}
.drink-block ul,.drink-block ol{padding-left:1.3rem;margin-bottom:0}
.drink-block li{margin:.4em 0}
details.history{margin:2.5rem 0;border-top:1px solid var(--line);padding-top:1.2rem}
details.history summary{cursor:pointer;font-weight:600;list-style:none;display:flex;align-items:center;gap:.5rem}
details.history summary::-webkit-details-marker{display:none}
details.history summary::before{content:"+";display:inline-flex;width:1.6rem;height:1.6rem;align-items:center;justify-content:center;border-radius:50%;background:var(--accent);color:#fff;font-size:1.1rem;line-height:1;transition:transform .25s var(--ease)}
details.history[open] summary::before{transform:rotate(45deg)}
details.history[open] summary{margin-bottom:1rem}

/* ---------- Recept A-Ö ---------- */
.az-nav{display:flex;gap:.3rem;flex-wrap:wrap;justify-content:center;margin:1.5rem 0 2.5rem;position:sticky;top:64px;background:color-mix(in oklab, var(--bg) 92%, transparent);backdrop-filter:blur(10px);padding:.6rem;border-radius:var(--radius);z-index:10}
.az-nav a{padding:.35rem .6rem;border-radius:var(--radius-s);color:var(--fg);font-weight:600;font-size:.88rem;transition:all .15s var(--ease)}
.az-nav a:hover{background:var(--accent);color:#fff}
.az-letter{margin:2.5rem 0 1rem;padding-bottom:.4rem;border-bottom:2px solid var(--accent);font-size:1.5rem;display:inline-block}
.az-list{column-count:2;column-gap:2.5rem;list-style:none;padding:0;margin:0}
.az-list li{break-inside:avoid;padding:.25rem 0}
@media (max-width:600px){.az-list{column-count:1}}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);background:var(--bg-soft);padding:3rem 0;margin-top:4rem;color:var(--fg-soft);font-size:.92rem}
.site-footer__inner{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;align-items:center}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;gap:1.4rem;flex-wrap:wrap}
.site-footer a{color:var(--fg-soft)}
.site-footer a:hover{color:var(--accent)}
.site-footer__brand{font-family:"Playfair Display",ui-serif,serif;font-weight:700;color:var(--fg);font-size:1.1rem}

/* ---------- Related ---------- */
.related{margin-top:3.5rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.related h2{font-size:1.3rem;margin:0 0 1.3rem;text-align:center}

/* ---------- Tags ---------- */
.taglist{margin:2rem 0 0;font-size:.85rem;color:var(--fg-mute)}
.taglist a{display:inline-block;margin:0 .3rem .3rem 0;padding:.25rem .7rem;background:var(--bg-soft);border-radius:999px;color:var(--fg-soft);transition:all .2s var(--ease)}
.taglist a:hover{background:var(--accent);color:#fff}

/* ---------- Skip link ---------- */
.skip-link{position:absolute;left:-9999px;top:0;background:var(--fg);color:var(--bg);padding:.6rem 1rem;z-index:99}
.skip-link:focus{left:1rem;top:1rem}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease), transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.08s}
.reveal[data-delay="2"]{transition-delay:.16s}
.reveal[data-delay="3"]{transition-delay:.24s}
.cards .card{opacity:0;transform:translateY(14px);transition:opacity .6s var(--ease), transform .6s var(--ease), box-shadow .35s var(--ease)}
.cards.is-visible .card{opacity:1;transform:none}
.cards.is-visible .card:nth-child(1){transition-delay:0s}
.cards.is-visible .card:nth-child(2){transition-delay:.06s}
.cards.is-visible .card:nth-child(3){transition-delay:.12s}
.cards.is-visible .card:nth-child(4){transition-delay:.18s}
.cards.is-visible .card:nth-child(5){transition-delay:.24s}
.cards.is-visible .card:nth-child(6){transition-delay:.3s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  .reveal,.cards .card{opacity:1;transform:none}
}

/* ---------- BB cleanup ---------- */
.fl-builder-content,.fl-row-content-wrap{all:unset !important;display:block !important}
