/*
Theme Name: Rechtspause
Theme URI: https://rechtspause.de
Author: Rechtspause – Steffan Schwerin
Author URI: https://rechtspause.de
Description: Homepage-Theme für Rechtspause – die Bibliothek für Juristinnen, Juristen und Familien im Verfahren. Teal/Gold-Markendesign mit getrennter Familien-Welt.
Version: 1.0.0
Requires at least: 5.9
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rechtspause
*/

/* ============================================================
   Rechtspause — Redesign (Markenfarben: Teal · Gold · Dunkelgrün)
   ============================================================ */

:root{
  /* brand */
  --teal:#1D9E75;
  --teal-deep:#157a5b;
  --gold:#BA7517;
  --gold-deep:#9c6012;
  --green-900:#132820;
  --green-800:#1b3a2d;
  --teal-light:#5DCAA5;
  --gold-light:#FAC775;
  --sky:#2f9fb8;            /* Familien-Welt (helleres Türkis der Familien-Cover) */

  /* paper / ink (warmes Creme wie die Cover) */
  --paper:#f6f1e6;
  --paper-2:#efe7d6;
  --card:#fffdf8;
  --ink:#1b2a23;
  --ink-2:#4c5b52;
  --ink-3:#7e8a81;
  --line:color-mix(in oklch, var(--ink) 14%, transparent);
  --line-2:color-mix(in oklch, var(--ink) 7%, transparent);

  /* role colors (tweakable) */
  --accent:var(--teal);
  --accent-2:var(--gold);
  --calm:var(--sky);

  --font-display:"Spectral", Georgia, "Times New Roman", serif;
  --font-sans:"Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --font-mono:"Space Mono", ui-monospace, monospace;

  --radius:14px;
  --maxw:1240px;
  --gutter:clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-sans); font-size:18px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* ---------- type helpers ---------- */
.kicker{
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.18em;
  text-transform:uppercase; color:var(--accent); margin:0 0 .9rem;
  display:inline-flex; align-items:center; gap:.6em;
}
.kicker::before{ content:""; width:1.8em; height:2px; background:currentColor; display:inline-block; }
h1,h2,h3{ font-family:var(--font-display); font-weight:600; line-height:1.08; margin:0; letter-spacing:-.01em; }
.serif-italic{ font-style:italic; }

/* ============================================================
   NAV  (Wortmarke: RECHTS teal · § gold · PAUSE gold)
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(1.2) blur(8px);
  background:color-mix(in oklch, var(--paper) 84%, transparent);
  border-bottom:1px solid var(--line);
}
.nav__inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; height:70px; }
.brand{
  text-decoration:none; font-family:var(--font-sans); font-weight:700;
  font-size:1.18rem; letter-spacing:.14em; display:inline-flex; align-items:center; gap:.5em;
}
.brand__mark{ height:30px; width:auto; }
.brand .r{ color:var(--teal); }
.brand .p{ color:var(--gold); }
.brand .par{ color:var(--gold); font-family:var(--font-display); font-weight:700; font-style:italic; letter-spacing:0; margin:0 .02em; }
.nav__links{ display:flex; align-items:center; gap:.3rem; }
.nav__links a{
  text-decoration:none; color:var(--ink-2); font-size:.95rem;
  padding:.5rem .85rem; border-radius:9px; transition:color .15s, background .15s;
}
.nav__links a:hover{ color:var(--ink); background:var(--paper-2); }
.nav__links .nav-cta{ color:#fff; background:var(--teal); }
.nav__links .nav-cta:hover{ background:var(--teal-deep); color:#fff; }
@media(max-width:760px){ .nav__links a:not(.nav-cta){ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; overflow:hidden; }
.hero::after{
  content:""; position:absolute; right:-8%; top:-30%; width:48vw; height:120%;
  background:radial-gradient(closest-side, color-mix(in oklch,var(--teal) 12%, transparent), transparent 72%);
  pointer-events:none;
}
.hero__inner{
  display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(28px,5vw,72px);
  align-items:center; padding-block:clamp(48px,8vw,100px); position:relative; z-index:1;
}
@media(max-width:880px){ .hero__inner{ grid-template-columns:1fr; } }
.hero h1{ font-size:clamp(2.6rem, 7.5vw, 5.6rem); line-height:1.07; margin:.2rem 0 0; padding-bottom:.3em; }
.hero h1 .u{ position:relative; white-space:nowrap; color:var(--teal); }
.hero h1 .u::after{
  content:""; position:absolute; left:-1%; right:-1%; bottom:.08em; height:.14em;
  background:var(--gold); opacity:.9; border-radius:2px; transform:rotate(-1deg);
}
.hero__lead{ font-size:clamp(1.05rem,1.6vw,1.26rem); color:var(--ink-2); max-width:46ch; margin:1.6rem 0 0; text-wrap:pretty; }
.hero__cats{ display:flex; flex-wrap:wrap; gap:.55rem; margin-top:2rem; }
.chip{
  font-family:var(--font-mono); font-size:.8rem; text-decoration:none; color:var(--ink);
  background:var(--card); border:1px solid var(--line); border-radius:999px;
  padding:.5rem .9rem; transition:all .15s; display:inline-flex; align-items:center; gap:.5em;
}
.chip .dot{ width:.55em; height:.55em; border-radius:50%; background:var(--accent); }
.chip:hover{ border-color:var(--teal); transform:translateY(-1px); }

.hero__art{ position:relative; min-height:380px; display:flex; align-items:center; justify-content:center; }
.shelf-fan{ position:relative; width:min(100%,460px); height:430px; }
.shelf-fan .fc{ position:absolute; width:215px; }
.shelf-fan .cover img{
  width:100%; height:auto; border-radius:4px;
  box-shadow:0 26px 50px -20px rgba(19,40,32,.5), 0 4px 12px rgba(19,40,32,.2);
}
.shelf-fan .fc1{ left:2%;  top:34px; transform:rotate(-7deg); z-index:1; }
.shelf-fan .fc2{ left:30%; top:0;    transform:rotate(0deg);  z-index:3; }
.shelf-fan .fc3{ left:56%; top:40px; transform:rotate(7deg);  z-index:2; }

.hero__stamp{
  position:absolute; right:var(--gutter); top:20px; z-index:2;
  font-family:var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold); border:1.5px solid var(--gold); border-radius:8px;
  padding:.4rem .7rem; transform:rotate(5deg); opacity:.9;
}
@media(max-width:880px){ .hero__stamp{ display:none; } }

/* ============================================================
   SECTION
   ============================================================ */
.section{ padding-block:clamp(46px,7vw,84px); position:relative; scroll-margin-top:80px; }
.section + .section{ border-top:1px solid var(--line-2); }
.section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:1.5rem; margin-bottom:clamp(28px,4vw,50px); flex-wrap:wrap; }
.section__num{ font-family:var(--font-mono); font-size:.8rem; color:var(--ink-3); letter-spacing:.1em; }
.section h2{ font-size:clamp(2rem,4.4vw,3.1rem); margin-top:.45rem; }
.section__sub{ color:var(--ink-2); font-size:1.06rem; max-width:42ch; text-align:right; font-style:italic; font-family:var(--font-display); }
@media(max-width:680px){ .section__sub{ text-align:left; } }

.grid{ display:grid; gap:clamp(22px,2.6vw,36px); grid-template-columns:repeat(4,1fr); align-items:start; }
.grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.grid.cols-2{ grid-template-columns:repeat(2,1fr); }
@media(max-width:1040px){ .grid,.grid.cols-3{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:560px){ .grid,.grid.cols-3,.grid.cols-2{ grid-template-columns:1fr; } }

/* ---------- book card ---------- */
.book{ display:flex; flex-direction:column; }
.book__coverwrap{
  position:relative; display:flex; align-items:center; justify-content:center;
  aspect-ratio:3/4; margin-bottom:1.1rem; text-decoration:none;
  transition:transform .25s ease;
}
.book:hover .book__coverwrap{ transform:translateY(-6px); }
.cover{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; }
.cover img{
  max-width:100%; max-height:100%; width:auto; height:auto; border-radius:3px;
  filter:drop-shadow(0 16px 24px rgba(19,40,32,.30)) drop-shadow(0 3px 6px rgba(19,40,32,.18));
}
.cover--ph{ background:var(--paper-2); border:1px dashed var(--line); border-radius:6px; padding:14px; }
.cover--ph span{ font-family:var(--font-display); font-size:1.05rem; text-align:center; color:var(--ink-2); }

.book__badge{
  position:absolute; top:8px; left:8px; z-index:4;
  font-family:var(--font-mono); font-size:.64rem; letter-spacing:.06em; text-transform:uppercase;
  background:var(--green-900); color:var(--paper); padding:.3rem .55rem; border-radius:6px;
}
.book__badge.is-accent{ background:var(--gold); color:var(--green-900); }
.book__badge.is-soon{ background:color-mix(in oklch,var(--card) 80%, transparent); color:var(--ink-2); border:1.5px dashed var(--line); }

.book h3{ font-size:1.16rem; line-height:1.18; }
.book__role{ font-family:var(--font-mono); font-size:.73rem; color:var(--accent); margin:.45rem 0 .55rem; line-height:1.4; }
.book__desc{ font-size:.92rem; color:var(--ink-2); margin:0 0 1rem; text-wrap:pretty; flex:1; }
.book__cta{
  align-self:flex-start; text-decoration:none; font-weight:600; font-size:.92rem; color:var(--ink);
  display:inline-flex; align-items:center; gap:.4em;
  border-bottom:2px solid var(--accent); padding-bottom:2px; transition:gap .15s, color .15s;
}
.book__cta:hover{ gap:.8em; color:var(--accent); }
.book__soon{ font-family:var(--font-mono); font-size:.8rem; color:var(--ink-3); }

/* ============================================================
   FAMILIEN — ruhige, eigene Welt (Sky-Türkis)
   ============================================================ */
.familien{ --accent:var(--calm); background:color-mix(in oklch, var(--calm) 9%, var(--paper)); border-top:1px solid var(--line); }
.familien .kicker,.familien .book__role{ color:var(--calm); }
.familien .book__cta{ border-bottom-color:var(--calm); }
.familien .book__cta:hover{ color:var(--calm); }
.familien .book__badge.is-accent{ background:var(--calm); color:#fff; }
.familien.is-square .book__coverwrap{ aspect-ratio:1/1; }
.familien .section__intro{ max-width:60ch; color:var(--ink-2); font-size:1.1rem; margin:0 0 clamp(26px,4vw,44px); text-wrap:pretty; }
.familien__note{
  margin-top:clamp(30px,4vw,48px); padding:1.4rem 1.6rem; background:var(--card);
  border:1px solid var(--line); border-radius:var(--radius); display:flex; gap:1rem;
  align-items:flex-start; font-size:.96rem; color:var(--ink-2);
}
.familien__note b{ color:var(--ink); }
.familien__note-tag{ font-family:var(--font-mono); color:var(--calm); font-size:.8rem; white-space:nowrap; }

/* ============================================================
   QUOTE — dunkelgrün
   ============================================================ */
.quote{ background:var(--green-900); color:var(--paper); padding-block:clamp(56px,9vw,108px); }
.quote__big{ font-family:var(--font-display); font-weight:600; font-size:clamp(2.1rem,5.4vw,4rem); line-height:1.08; letter-spacing:-.02em; max-width:18ch; margin:0; }
.quote__big em{ color:var(--gold-light); font-style:italic; }
.quote__by{ font-family:var(--font-mono); font-size:.82rem; letter-spacing:.1em; margin-top:1.6rem; color:var(--teal-light); }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ padding-block:clamp(56px,8vw,104px); }
.about__inner{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(32px,5vw,72px); align-items:center; }
@media(max-width:840px){ .about__inner{ grid-template-columns:1fr; } }
.about__photo{
  aspect-ratio:4/5; border-radius:var(--radius); background:var(--paper-2);
  border:1px solid var(--line); overflow:hidden; position:relative;
}
.about__photo img{ width:100%; height:100%; object-fit:cover; object-position:center 18%; }
.about h2{ font-size:clamp(1.9rem,3.4vw,2.6rem); max-width:20ch; line-height:1.16; padding-bottom:.12em; }
.about h2 + p, .about p{ color:var(--ink-2); max-width:54ch; margin:2.2rem 0 0; text-wrap:pretty; }
.about p + p{ margin-top:1.3rem; }
.about p b{ color:var(--ink); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ border-top:1px solid var(--line); padding-block:48px; }
.footer__inner{ display:flex; align-items:center; justify-content:space-between; gap:1.2rem; flex-wrap:wrap; }
.footer a{ text-decoration:none; color:var(--ink-2); font-size:.9rem; }
.footer a:hover{ color:var(--accent); }
.footer__links{ display:flex; gap:1.4rem; align-items:center; }
.footer__copy{ font-family:var(--font-mono); font-size:.74rem; color:var(--ink-3); }

/* reveal */
@media(prefers-reduced-motion:no-preference){
  .rp-js .reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
  .rp-js .reveal.in{ opacity:1; transform:none; }
}


/* ---- generic WP pages (Impressum, Datenschutz, Posts) ---- */
.rp-page{ padding-block:clamp(48px,8vw,96px); }
.rp-page .wrap{ max-width:760px; }
.rp-page__title{ font-family:var(--font-display); font-size:clamp(2rem,4vw,2.8rem); margin:0 0 1.4rem; }
.rp-page__content{ font-size:1.05rem; color:var(--ink-2); }
.rp-page__content p{ margin:0 0 1.1rem; text-wrap:pretty; }
.rp-page__content a{ color:var(--teal); }
.rp-page__content h2{ font-family:var(--font-display); font-size:1.6rem; margin:2rem 0 .8rem; color:var(--ink); }
.rp-page__content ul,.rp-page__content ol{ padding-left:1.3rem; margin:0 0 1.1rem; }
