:root{
  --bg:#f0d9a5;
  --bg-alt:#e5c47e;
  --paper:#fffdf7;
  --ink:#201d18;
  --ink-soft:#3f3930;
  --muted:#655b4d;
  --accent:#9b7a2d;       
  --accent-deep:#6f561f;
  --border:#d9cba9;
  --shadow:0 18px 48px rgba(32,29,24,.09);
  --serif:"Segoe UI", Arial, Helvetica, sans-serif;
  --sans:"Segoe UI", Arial, Helvetica, sans-serif;
  --container:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  font-size:17px;
  line-height:1.78;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  animation:pageIn .6s ease both;
}
img{max-width:100%;display:block}
a{color:var(--accent-deep);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--ink)}

.container{max-width:var(--container);margin:0 auto;padding:0 28px}

h1,h2,h3,h4{font-family:var(--serif);font-weight:600;color:var(--ink);letter-spacing:0}
h1{font-size:clamp(2.35rem,4.6vw,3.75rem);line-height:1.1}
h2{font-size:clamp(1.9rem,3.2vw,2.6rem);line-height:1.18;margin-bottom:.45em}
h3{font-size:1.35rem;line-height:1.28;margin-bottom:.5em}
p{margin-bottom:1.05em;color:var(--ink-soft)}

/* ---------- NAVBAR ---------- */
.navbar{
  position:sticky;top:0;z-index:100;
  background:rgba(44,62,80,.95);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid rgba(255,255,255,.12);
  box-shadow:0 1px 0 rgba(36,31,24,.06);
  animation:navDrop .65s cubic-bezier(.2,.72,.22,1) both;
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--container);margin:0 auto;padding:18px 28px;
}
.brand{
  display:flex;
  align-items:center;
  width:275px;
}
.brand img{
  width:100%;
  height:auto;
  max-height:104px;
  object-fit:contain;
  transition:transform .35s ease, filter .35s ease;
}
.brand:hover img{transform:translateY(-1px);filter:brightness(1.04)}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{
  font-size:.95rem;font-weight:500;color:#ecf0f1;
  position:relative;padding:6px 0;
  transition:color .25s ease, transform .25s ease;
}
.nav-links a:hover{transform:translateY(-1px)}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--accent);transition:width .3s ease;
}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-toggle{display:none;background:none;border:0;font-size:1.6rem;color:#ecf0f1;cursor:pointer}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-block;padding:13px 28px;
  font-family:var(--sans);font-size:.92rem;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;
  border-radius:1px;cursor:pointer;transition:all .25s ease;
  border:1px solid var(--ink);
  position:relative;
  overflow:hidden;
  will-change:transform;
}
.btn::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg, transparent 0%, rgba(255,255,255,.24) 38%, transparent 72%);
  transform:translateX(-120%);
  transition:transform .55s ease;
}
.btn:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 24px rgba(32,29,24,.13);
}
.btn:disabled{
  cursor:not-allowed;
  opacity:.65;
  transform:none;
  box-shadow:none;
}
.btn:hover::after{transform:translateX(120%)}
.btn-primary{background:var(--ink);color:#f7f1e6}
.btn-primary:hover{background:#3a3328;border-color:#3a3328;color:#fff}
.btn-outline{background:transparent;color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--bg)}
.btn-gold{background:var(--accent-deep);border-color:var(--accent-deep);color:#fff}
.btn-gold:hover{background:var(--ink);border-color:var(--ink)}
.pdf-links-toggle[hidden]{display:none !important}

/* ---------- HERO ---------- */
.hero{
  padding:118px 0 126px;
  background:
    linear-gradient(180deg, var(--bg) 0%, var(--bg-alt) 100%);
  text-align:center;
  border-bottom:1px solid rgba(111,86,31,.24);
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(105deg, transparent 0 24%, rgba(255,253,247,.18) 38%, transparent 54%),
    radial-gradient(circle at 50% 18%, rgba(255,253,247,.22), transparent 34%);
  transform:translateX(-18%);
  animation:researchSweep 8s ease-in-out infinite;
  pointer-events:none;
}
.hero .container{position:relative;z-index:1}
.hero .kicker{
  font-family:var(--sans);font-size:.8rem;letter-spacing:.35em;
  text-transform:uppercase;color:var(--accent-deep);margin-bottom:24px;
  animation:fadeLift .7s .12s cubic-bezier(.2,.72,.22,1) both;
}
.hero h1{
  font-weight:600;max-width:900px;margin:-12px auto 18px;
  animation:fadeLift .8s .22s cubic-bezier(.2,.72,.22,1) both;
}
.hero .motto{
  font-family:var(--sans);font-size:1.18rem;font-weight:400;
  color:var(--ink-soft);line-height:1.65;margin:18px auto 40px;max-width:640px;
  animation:fadeLift .8s .42s cubic-bezier(.2,.72,.22,1) both;
}
.hero-contact{
  display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;
  margin-top:52px;
  animation:fadeLift .75s .56s cubic-bezier(.2,.72,.22,1) both;
}
.contact-toggle{
  max-width:100%;
  overflow-wrap:anywhere;
  white-space:normal;
}
.contact-email{
  display:inline-block;
  max-width:min(100%, 320px);
  font-size:1rem;
  font-weight:600;
  line-height:1.35;
  color:var(--ink);
  overflow-wrap:anywhere;
  word-break:break-word;
  text-align:left;
}
.contact-email[hidden]{display:none !important}
.contact-email:hover{color:var(--accent-deep)}
.hero-divider{
  width:72px;height:1px;background:rgba(111,86,31,.62);margin:30px auto;
  transform-origin:center;
  animation:lineGrow .8s .36s cubic-bezier(.2,.72,.22,1) both;
}

/* ---------- CONTACT MODAL ---------- */
.contact-modal{
  position:fixed;
  inset:0;
  z-index:320;
  display:grid;
  place-items:center;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
.contact-modal.is-open{
  opacity:1;
  pointer-events:auto;
}
.contact-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(22,20,17,.58);
  backdrop-filter:blur(8px);
}
.contact-modal-panel{
  position:relative;
  z-index:1;
  width:min(560px,100%);
  max-height:calc(100vh - 48px);
  overflow:auto;
  padding:36px;
  background:linear-gradient(180deg, rgba(255,253,247,.98), rgba(255,248,232,.96));
  border:1px solid rgba(111,86,31,.24);
  border-radius:10px;
  box-shadow:0 34px 90px rgba(16,14,12,.34);
  transform:translateY(18px) scale(.98);
  transition:transform .28s ease;
}
.contact-modal.is-open .contact-modal-panel{transform:none}
.contact-modal-panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:5px;
  background:linear-gradient(90deg, var(--accent-deep), rgba(155,122,45,.42));
}
.contact-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:36px;
  height:36px;
  border:1px solid rgba(111,86,31,.22);
  border-radius:50%;
  background:rgba(255,253,247,.95);
  color:var(--ink);
  font-size:1.35rem;
  line-height:1;
  cursor:pointer;
  transition:background-color .25s ease, color .25s ease, transform .25s ease;
}
.contact-modal-close:hover{background:var(--ink);color:#fff;transform:rotate(90deg)}
.contact-modal-label{
  display:block;
  margin-bottom:10px;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent-deep);
}
.contact-modal-panel h2{
  margin:0 42px 22px 0;
  font-size:clamp(1.75rem,3vw,2.2rem);
}
.contact-form{
  display:grid;
  gap:10px;
}
.contact-form label{
  font-size:.76rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent-deep);
}
.contact-form input,
.contact-form textarea{
  width:100%;
  border:1px solid rgba(111,86,31,.24);
  border-radius:6px;
  padding:12px 13px;
  font:inherit;
  font-size:1rem;
  color:var(--ink);
  background:rgba(255,255,255,.88);
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.contact-form input:focus,
.contact-form textarea:focus{
  border-color:rgba(111,86,31,.55);
  background:#fff;
  box-shadow:0 0 0 3px rgba(111,86,31,.12);
}
.contact-form textarea{
  min-height:138px;
  resize:vertical;
}
.contact-hp{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.contact-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-top:8px;
}
.contact-actions .btn{
  min-width:150px;
  padding:12px 22px;
}
.contact-actions a{
  font-weight:700;
  overflow-wrap:anywhere;
  color:var(--accent-deep);
}
.contact-status{
  min-height:1.35em;
  margin:2px 0 0;
  font-size:.95rem;
  color:var(--accent-deep);
}
.contact-status.is-error{color:#7f2f1d}

/* ---------- SECTION GENERIC ---------- */
.section{
  position:relative;
  padding:112px 0;
  border-bottom:1px solid rgba(111,86,31,.18);
}
.section::before{
  content:"";
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:min(1124px,calc(100% - 56px));height:1px;
  background:linear-gradient(90deg,transparent,rgba(111,86,31,.32),transparent);
}
.section-label{
  display:inline-block;font-size:.76rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:18px;
}
.section-head{margin-bottom:72px;max-width:760px}
.section-head p{font-size:1.05rem;line-height:1.75;color:var(--muted)}

/* ---------- DAS BUCH ---------- */
.book-grid{
  display:grid;grid-template-columns:minmax(280px,1fr) 1.4fr;
  gap:72px;align-items:start;
}
.book-cover{
  position:relative;background:var(--paper);
  padding:0;box-shadow:var(--shadow);
  border:1px solid var(--border);
  overflow:hidden;
  transition:transform .45s cubic-bezier(.2,.72,.22,1), box-shadow .45s ease;
  will-change:transform;
}
.book-cover:hover{
  transform:translateY(-8px) rotate(-1.2deg);
  box-shadow:0 28px 62px rgba(32,29,24,.16);
}
.book-cover::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(105deg, transparent 0 32%, rgba(255,255,255,.24) 47%, transparent 62%);
  transform:translateX(-130%);
  transition:transform .8s ease;
  pointer-events:none;
}
.book-cover:hover::after{transform:translateX(130%)}
.book-cover-img{
  aspect-ratio:2/3;
  width:100%;
  height:100%;
  object-fit:cover;
  border:0;
}
.book-meta{margin-top:22px;text-align:center}
.book-meta .price{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:14px}
.book-meta .pages{font-size:.85rem;color:var(--muted);letter-spacing:.04em;margin-bottom:18px}
.book-meta .cta-row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
}
.book-meta .cta-row .btn{min-width:180px}
.book-text p{
  font-family:var(--sans);
  font-size:1.05rem;
  line-height:1.9;
  margin-bottom:1.25em;
  color:#332d25;
  text-align:left !important;
  text-align-last:left !important;
}
.book-text p:first-of-type::first-letter{
  font-family:var(--serif);
  font-size:3.6rem;
  float:left;
  line-height:.9;
  padding:6px 12px 0 0;
  color:var(--accent-deep);
}

/* ---------- REZENSIONEN ---------- */
.reviews-section{
  padding:82px 0;
  background:linear-gradient(180deg, rgba(255,253,247,.16), rgba(255,253,247,0));
}
.reviews{
  margin-top:0;
  padding-top:0;
  border-top:none;
}
.reviews-head{
  text-align:center;
  margin:0 auto 28px;
  max-width:650px;
}
.reviews-head p{
  margin-bottom:0;
  font-size:.98rem;
}
.review-card{
  display:grid;
  grid-template-columns:minmax(260px,.92fr) 1fr;
  gap:28px;
  max-width:900px;
  margin:0 auto;
  padding:28px;
  text-align:left;
  background:rgba(255,253,247,.84);
  border:1px solid rgba(111,86,31,.22);
  border-radius:8px;
  box-shadow:0 16px 38px rgba(32,29,24,.08);
}
.review-form{
  display:grid;
  align-content:start;
  gap:8px;
}
.review-form label{
  font-size:.76rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent-deep);
}
.review-form label span{
  color:var(--muted);
  font-weight:600;
  letter-spacing:.08em;
  text-transform:none;
}
.review-hp{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.review-input,
.review-textarea{
  width:100%;
  border:1px solid rgba(111,86,31,.24);
  border-radius:6px;
  padding:11px 12px;
  font:inherit;
  font-size:1rem;
  color:var(--ink);
  background:rgba(255,255,255,.86);
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}
.review-input:focus,
.review-textarea:focus{
  border-color:rgba(111,86,31,.55);
  background:#fff;
  box-shadow:0 0 0 3px rgba(111,86,31,.12);
}
.review-textarea{
  min-height:112px;
  resize:vertical;
}
.review-actions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-top:6px;
}
.review-actions .btn{
  padding:11px 18px;
  font-size:.78rem;
}
.review-status{
  min-height:1.25em;
  margin:2px 0 0;
  font-size:.92rem;
  color:var(--accent-deep);
}
.review-list-wrap{
  min-width:0;
  border-left:1px solid rgba(111,86,31,.16);
  padding-left:28px;
}
.review-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:12px;
}
.review-empty,
.review-item{
  background:rgba(255,255,255,.68);
  border:1px solid rgba(111,86,31,.16);
  border-radius:6px;
  padding:14px 16px;
}
.review-empty{
  color:var(--muted);
  font-size:.96rem;
}
.review-item blockquote{
  margin:0 0 10px;
  font-family:var(--sans);
  font-size:1rem;
  line-height:1.62;
  color:var(--ink);
}
.review-item footer{
  display:flex;
  flex-wrap:wrap;
  gap:8px 12px;
  align-items:center;
  justify-content:space-between;
  color:var(--muted);
  font-size:.9rem;
}
.review-item footer span{
  font-weight:700;
  color:var(--accent-deep);
}

/* ---------- REVIEW ADMIN ---------- */
.admin-page .section{
  padding:72px 0;
}
.admin-panel{
  max-width:900px;
  margin:0 auto;
  padding:30px;
  background:rgba(255,253,247,.9);
  border:1px solid rgba(111,86,31,.22);
  border-radius:8px;
  box-shadow:0 16px 38px rgba(32,29,24,.08);
}
.admin-message{
  margin:0 0 18px;
  padding:12px 14px;
  background:rgba(240,217,165,.34);
  border:1px solid rgba(111,86,31,.18);
  border-radius:6px;
  color:var(--ink);
}
.admin-login-form{
  max-width:420px;
}
.admin-toolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:22px;
}
.admin-toolbar p{
  margin:0;
  font-weight:700;
  color:var(--ink);
}
.admin-toolbar .btn{
  padding:10px 18px;
  font-size:.78rem;
}
.admin-review-list{
  list-style:none;
  display:grid;
  gap:12px;
}
.admin-review-item form{
  margin-top:12px;
}
.admin-delete-btn{
  border:1px solid rgba(111,86,31,.22);
  border-radius:999px;
  padding:7px 13px;
  background:#fff8ec;
  color:var(--accent-deep);
  font:inherit;
  font-size:.84rem;
  font-weight:700;
  cursor:pointer;
}
.admin-delete-btn:hover{
  background:var(--accent-deep);
  color:#fff;
}

/* ---------- PDF OVERLAY ---------- */
.pdf-overlay{
  position:fixed;
  inset:0;
  z-index:300;
  display:grid;
  place-items:center;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
}
.pdf-overlay.is-open{opacity:1;pointer-events:auto}
.pdf-backdrop{
  position:absolute;
  inset:0;
  background:rgba(22,20,17,.58);
  backdrop-filter:blur(8px);
}
.pdf-panel{
  position:relative;
  z-index:1;
  width:min(640px,100%);
  max-height:calc(100vh - 48px);
  overflow:auto;
  padding:36px;
  background:linear-gradient(180deg, rgba(255,253,247,.98), rgba(255,248,232,.96));
  border:1px solid rgba(111,86,31,.22);
  border-radius:10px;
  box-shadow:0 30px 80px rgba(16,14,12,.35);
  transform:translateY(18px) scale(.98);
  transition:transform .28s ease;
}
.pdf-overlay.is-open .pdf-panel{transform:none}
.pdf-close{
  position:absolute;
  top:14px;
  right:14px;
  width:36px;
  height:36px;
  border:1px solid rgba(111,86,31,.22);
  border-radius:50%;
  background:rgba(255,253,247,.95);
  color:var(--ink);
  font-size:1.35rem;
  cursor:pointer;
}
.pdf-intro{margin-top:-4px;margin-bottom:18px}
.pdf-list{list-style:none;display:grid;gap:10px}
.pdf-list a{
  display:block;
  padding:14px 16px;
  border:1px solid rgba(111,86,31,.18);
  border-radius:8px;
  background:rgba(255,253,247,.9);
  color:var(--ink);
  font-weight:600;
}
.pdf-list a:hover{background:var(--paper);color:var(--accent-deep)}
.pdf-links-page{
  max-width:860px;
}
.pdf-links-page .pdf-list{
  margin-top:28px;
}

/* ---------- DOWNLOADS ---------- */
.downloads-toolbar{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-bottom:18px;
}
.scroll-btn{
  border:1px solid rgba(111,86,31,.22);
  background:rgba(255,253,247,.9);
  color:var(--ink);
  width:42px;
  height:42px;
  border-radius:999px;
  cursor:pointer;
  font-size:1rem;
  box-shadow:0 10px 18px rgba(32,29,24,.08);
  transition:transform .25s ease, background-color .25s ease;
}
.scroll-btn:hover{transform:translateY(-2px);background:var(--paper)}
.downloads-rail{
  display:flex;
  gap:18px;
  overflow-x:auto;
  overflow-y:hidden;
  padding-bottom:8px;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;
  scrollbar-color:rgba(111,86,31,.35) transparent;
}
.downloads-rail::-webkit-scrollbar{height:8px}
.downloads-rail::-webkit-scrollbar-thumb{background:rgba(111,86,31,.35);border-radius:999px}
.download-card{
  flex:0 0 min(320px, 82vw);
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:24px;
  border:1px solid rgba(111,86,31,.18);
  border-radius:10px;
  background:linear-gradient(180deg, rgba(255,253,247,.94), rgba(255,248,232,.88));
  box-shadow:0 14px 32px rgba(32,29,24,.08);
  scroll-snap-align:start;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.download-card:hover{
  transform:translateY(-6px);
  border-color:rgba(111,86,31,.32);
  box-shadow:0 18px 42px rgba(32,29,24,.12);
}
.download-tag{
  display:inline-block;
  font-size:.74rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent-deep);
}
.download-card h3{margin-bottom:0}
.download-link{
  font-size:.95rem;
  font-weight:600;
  color:var(--accent-deep);
  word-break:break-word;
}
.download-link:hover{color:var(--ink)}

/* ---------- AUTHORS ---------- */
.authors-hero{
  padding:104px 0 74px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,253,247,.34), transparent 34%),
    linear-gradient(180deg,var(--bg-alt),var(--bg));
}
.authors-hero .container{max-width:900px}
.authors-hero p{
  max-width:650px;
  margin:22px auto 0;
  font-size:1.08rem;
  line-height:1.72;
  color:var(--ink-soft);
}
.authors-page{
  background:
    linear-gradient(180deg, rgba(255,253,247,.22), rgba(255,253,247,0) 220px);
}
.home-authors{
  background:linear-gradient(180deg, rgba(255,253,247,.18), rgba(255,253,247,0) 260px);
}
.home-authors .section-head{
  margin-bottom:48px;
}
.authors-intro{
  text-align:left;
  margin:0 auto 28px;
  max-width:820px;
}
.authors-intro h2{max-width:720px}
.author-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  max-width:var(--container);
  margin:-8px auto 0;
  border-top:0;
}
.author-card{
  display:flex;
  flex-direction:column;
  align-items:center;
  background:
    linear-gradient(180deg, rgba(255,253,247,.96), rgba(255,248,232,.86));
  border:1px solid rgba(111,86,31,.18);
  border-radius:8px;
  padding:30px 26px 28px;
  text-align:left;
  min-height:100%;
  box-shadow:0 14px 38px rgba(32,29,24,.075);
  position:relative;
  overflow:hidden;
  cursor:pointer;
  transition:border-color .35s ease, box-shadow .35s ease, transform .35s cubic-bezier(.2,.72,.22,1), background-color .35s ease;
}
.author-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:4px;
  background:linear-gradient(90deg, var(--accent-deep), rgba(155,122,45,.42));
}
.author-card:hover{
  transform:translateY(-7px);
  border-color:rgba(111,86,31,.30);
  box-shadow:0 22px 46px rgba(32,29,24,.12);
  background:var(--paper);
}
.author-card:focus-visible{
  outline:3px solid rgba(111,86,31,.34);
  outline-offset:4px;
}
.author-photo{
  position:relative;
  width:168px;
  aspect-ratio:4/5;
  border-radius:6px;
  background:
    linear-gradient(180deg, rgba(255,253,247,.72), rgba(229,196,126,.42)),
    #efe1bf;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
  font-family:var(--serif);font-size:1.75rem;color:#fff;font-weight:600;
  border:8px solid #fffaf0;
  outline:1px solid rgba(111,86,31,.30);
  box-shadow:0 12px 24px rgba(32,29,24,.12);
  transition:transform .35s ease, box-shadow .35s ease;
}
.author-card:hover .author-photo{
  transform:translateY(-3px);
  box-shadow:0 16px 30px rgba(32,29,24,.16);
}
.author-photo::after{
  content:"";
  position:absolute;
  inset:0;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.5);
  pointer-events:none;
}
.author-photo img{
  position:relative;
  z-index:1;
  width:100%;height:100%;object-fit:cover;object-position:center 38%;display:block;
}
.author-photo span{
  position:absolute;
  inset:0;
  display:flex;align-items:center;justify-content:center;
  width:100%;height:100%;
  background:linear-gradient(145deg,#4a3a16,#8b6b26);
  letter-spacing:.04em;
}
.author-content{
  width:100%;
  min-width:0;
  text-align:center;
  margin-top:22px;
  padding:20px 18px;
  background:rgba(255,253,247,.82);
  border:1px solid rgba(111,86,31,.16);
  border-radius:7px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72);
}
.author-card h3{margin:0 0 6px;font-size:1.24rem;line-height:1.22}
.author-role{
  display:block;
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent-deep);
}
.author-bio{
  display:none;
  font-family:var(--sans);
  font-size:.92rem;
  line-height:1.66;
  text-align:left;
  padding-top:14px;
  border-top:1px solid rgba(111,86,31,.14);
  margin-bottom:0;
  color:#3f3930;
}
.author-modal-bio{display:block}

.author-modal{
  position:fixed;
  inset:0;
  z-index:300;
  display:grid;
  place-items:center;
  padding:28px;
  opacity:0;
  pointer-events:none;
  transition:opacity .28s ease;
}
.author-modal.is-open{
  opacity:1;
  pointer-events:auto;
}
.author-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(22,20,17,.58);
  backdrop-filter:blur(8px);
}
.author-modal-panel{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:190px 1fr;
  gap:34px;
  width:min(820px,100%);
  max-height:calc(100vh - 56px);
  overflow:auto;
  padding:36px;
  background:
    linear-gradient(180deg, rgba(255,253,247,.98), rgba(255,248,232,.96));
  border:1px solid rgba(111,86,31,.24);
  border-radius:10px;
  box-shadow:0 34px 90px rgba(16,14,12,.34);
  transform:translateY(18px) scale(.98);
  transition:transform .36s cubic-bezier(.2,.72,.22,1);
}
.author-modal.is-open .author-modal-panel{transform:none}
.author-modal-panel::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:5px;
  background:linear-gradient(90deg, var(--accent-deep), rgba(155,122,45,.42));
}
.author-modal-close{
  position:absolute;
  top:14px;
  right:14px;
  width:36px;
  height:36px;
  border:1px solid rgba(111,86,31,.22);
  border-radius:50%;
  background:rgba(255,253,247,.9);
  color:var(--ink);
  font-size:1.35rem;
  line-height:1;
  cursor:pointer;
  transition:background-color .25s ease, color .25s ease, transform .25s ease;
}
.author-modal-close:hover{background:var(--ink);color:#fff;transform:rotate(90deg)}
.author-modal-photo .author-photo{
  width:220px;
  margin:0 auto;
  border-width:10px;
  font-size:2.5rem;
}
.author-modal-text{
  align-self:center;
  padding:24px;
  background:rgba(255,253,247,.82);
  border:1px solid rgba(111,86,31,.16);
  border-radius:8px;
}
.author-modal-role{
  display:block;
  margin-bottom:10px;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent-deep);
}
.author-modal-text h2{
  margin-bottom:16px;
  font-size:clamp(1.85rem,3vw,2.45rem);
}
.author-modal-bio{
  padding-top:18px;
  border-top:1px solid rgba(111,86,31,.16);
  color:#332d25;
  font-family:var(--sans);
  font-size:1.03rem;
  line-height:1.82;
  text-align:left;
}
.author-modal-bio p{
  margin:0 0 1.05em;
  color:#332d25;
  text-align:left;
}
.author-modal-bio p:last-child{margin-bottom:0}
body.modal-open{overflow:hidden}

/* ---------- FÜR AUTOREN ---------- */
.authors-submit-hero{
  padding:104px 0 76px;
  background:
    radial-gradient(circle at 50% 0%, rgba(255,253,247,.32), transparent 34%),
    linear-gradient(180deg,var(--bg-alt),var(--bg));
}
.authors-submit-hero .container{max-width:920px}
.authors-submit-hero p{
  max-width:680px;
  margin:22px auto 0;
  font-size:1.08rem;
  line-height:1.72;
  color:var(--ink-soft);
}
.authors-submit-page{
  background:linear-gradient(180deg, rgba(255,253,247,.22), rgba(255,253,247,0) 240px);
}
.authors-submit-card{
  max-width:900px;
  margin:-24px auto 0;
  padding:48px;
  background:var(--paper);
  border:1px solid rgba(111,86,31,.22);
  border-radius:8px;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden;
  animation:fadeLift .75s .16s cubic-bezier(.2,.72,.22,1) both;
}
.authors-submit-card.fade-in{
  opacity:1;
  transform:none;
}
.privacy-content.fade-in{
  opacity:1;
  transform:none;
}
.authors-submit-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:5px;
  background:linear-gradient(90deg, var(--accent-deep), rgba(155,122,45,.42));
}
.authors-submit-card p{
  font-size:1.06rem;
  line-height:1.88;
  color:#332d25;
  overflow-wrap:anywhere;
  word-break:break-word;
}
.authors-submit-card a{
  overflow-wrap:anywhere;
  word-break:break-word;
}
.authors-submit-card .lead{
  font-family:var(--serif);
  font-size:1.26rem;
  line-height:1.72;
  color:var(--ink);
}
.topic-box,
.submission-note{
  margin:34px 0;
  padding:28px;
  background:rgba(240,217,165,.26);
  border:1px solid rgba(111,86,31,.18);
  border-radius:8px;
  transition:transform .35s ease, background-color .35s ease, border-color .35s ease;
}
.topic-box:hover,
.submission-note:hover{
  transform:translateY(-3px);
  background:rgba(240,217,165,.34);
  border-color:rgba(111,86,31,.28);
}
.topic-box h2,
.submission-note h2{
  margin-bottom:10px;
  font-size:1.45rem;
}
.topic-box p,
.submission-note p{margin-bottom:0}
.highlight-line{
  padding:20px 24px;
  border-left:4px solid var(--accent-deep);
  background:rgba(255,248,232,.72);
  font-weight:600;
}

/* highlighted email */
.highlight-email{
  font-weight:800;
  color:var(--accent-deep);
  background:rgba(255,248,232,.72);
  padding:2px 8px;
  border:1px solid rgba(111,86,31,.25);
  border-radius:999px;
  box-shadow:0 10px 20px rgba(32,29,24,.06);
}

.highlight-email:hover{
  color:var(--ink);
  border-color:rgba(111,86,31,.42);
  background:rgba(255,248,232,.9);
}

.submission-note .btn{margin-top:22px}

/* ---------- PAGE HEADER (für autoren / impressum) ---------- */
.page-header{
  padding:90px 0 60px;
  background:linear-gradient(180deg,var(--bg-alt),var(--bg));
  text-align:center;border-bottom:1px solid rgba(111,86,31,.22);
  position:relative;
  overflow:hidden;
}
.page-header::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%, rgba(255,253,247,.24), transparent 38%);
  animation:softPulse 5s ease-in-out infinite;
  pointer-events:none;
}
.page-header .container{
  position:relative;
  z-index:1;
  animation:fadeLift .72s .12s cubic-bezier(.2,.72,.22,1) both;
}
.page-header h1{font-size:clamp(2rem,4vw,3.2rem);font-weight:600}
.page-header .kicker{
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--accent-deep);margin-bottom:14px;
}

.prose{max-width:760px;margin:0 auto;padding:84px 28px}
.privacy-content{animation:fadeLift .72s .14s cubic-bezier(.2,.72,.22,1) both}
.prose h2{margin-top:2.1em;margin-bottom:.65em}
.prose h3{margin-top:1.7em;color:var(--accent-deep)}
.prose h4{
  margin:1.35em 0 .45em;
  font-family:var(--sans);
  font-size:1rem;
  font-weight:700;
  color:var(--ink);
}
.prose p{font-size:1.05rem;line-height:1.9;margin-bottom:1.25em}
.prose ul{margin:0 0 1.2em 1.4em;color:var(--ink-soft)}

/* ---------- IMPRESSUM ---------- */
.impressum-block{
  background:var(--paper);border:1px solid var(--border);
  padding:42px 48px;margin-bottom:30px;box-shadow:0 14px 36px rgba(32,29,24,.07);
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.impressum-block:hover{
  transform:translateY(-3px);
  border-color:rgba(111,86,31,.32);
  box-shadow:0 20px 44px rgba(32,29,24,.1);
}
.impressum-block h3{
  font-family:var(--sans);font-size:.8rem;font-weight:700;
  text-transform:uppercase;letter-spacing:.22em;color:var(--accent-deep);
  margin-bottom:14px;
}
.impressum-block p{margin-bottom:.4em;color:var(--ink)}

/* ---------- FOOTER ---------- */
.footer{
  background:#2c3e50;color:#c9bea8;padding:76px 0 32px;
  border-top:1px solid rgba(255,255,255,.12);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:54px;margin-bottom:54px;
}
.footer h4{color:#f0e4c8;font-family:var(--serif);font-size:1.4rem;line-height:1.25;margin-bottom:16px}
.footer p,.footer a{color:#d7cbb6;font-size:.92rem;line-height:1.8}
.footer a:hover{color:#f0e4c8}
.footer ul{list-style:none}
.footer li + li{margin-top:8px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.18);padding-top:26px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:.82rem;color:#c5b9a4;
}

/* ---------- ANIMATIONS ---------- */
.fade-in{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .85s ease, transform .85s cubic-bezier(.2,.72,.22,1);
  transition-delay:var(--reveal-delay,0ms);
  will-change:opacity, transform;
}
.fade-in.visible{opacity:1;transform:none}

@keyframes pageIn{
  from{opacity:0}
  to{opacity:1}
}
@keyframes navDrop{
  from{opacity:0;transform:translateY(-16px)}
  to{opacity:1;transform:none}
}
@keyframes fadeLift{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:none}
}
@keyframes lineGrow{
  from{opacity:0;transform:scaleX(.2)}
  to{opacity:1;transform:scaleX(1)}
}
@keyframes researchSweep{
  0%,100%{opacity:.58;transform:translateX(-18%)}
  50%{opacity:1;transform:translateX(18%)}
}
@keyframes softPulse{
  0%,100%{opacity:.55;transform:scale(1)}
  50%{opacity:.9;transform:scale(1.04)}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,
  *::before,
  *::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    scroll-behavior:auto !important;
    transition-duration:.01ms !important;
  }
  .fade-in{opacity:1;transform:none;transition:none}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 900px){
  .book-grid{grid-template-columns:1fr;gap:50px}
  .book-cover{max-width:340px;margin:0 auto}
  .brand{width:200px}
  .downloads-rail{padding-bottom:10px}
  .author-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .author-photo{width:148px}
  .author-modal-panel{grid-template-columns:140px 1fr;gap:24px;padding:30px}
  .author-modal-photo .author-photo{width:160px}
  .authors-submit-card{margin-top:0;padding:36px 30px}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;background:#2c3e50;
    border-bottom:1px solid rgba(255,255,255,.12);padding:24px 28px;gap:18px;
  }
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .section{padding:80px 0}
  .hero{padding:80px 0 90px}
  .review-card{grid-template-columns:1fr}
  .review-list-wrap{
    border-left:0;
    border-top:1px solid rgba(111,86,31,.16);
    padding-left:0;
    padding-top:22px;
  }
}
@media (max-width: 560px){
  .brand{width:168px}
  .downloads-toolbar{justify-content:flex-start}
  .author-grid{grid-template-columns:1fr}
  .author-card{padding:24px 20px}
  .author-photo{width:148px}
  .author-card h3{font-size:1.25rem}
  .author-role{font-size:.7rem;letter-spacing:.14em}
  .author-modal{padding:18px}
  .author-modal-panel{display:block;padding:28px 20px 22px}
  .author-modal-photo .author-photo{width:156px;margin:0 auto 20px}
  .author-modal-text{padding:20px 16px}
  .authors-submit-hero{padding:78px 0 54px}
  .authors-submit-card{padding:30px 22px}
  .topic-box,.submission-note{padding:22px 18px}
  .reviews-section{padding:64px 0}
  .review-card{padding:20px}
  .review-actions{align-items:flex-start;flex-direction:column}
  .review-actions .btn{width:100%;text-align:center}
  .hero-contact .btn{
    width:100%;
    max-width:320px;
    text-align:center;
  }
  .contact-modal{padding:16px}
  .contact-modal-panel{padding:30px 20px 22px}
  .contact-modal-panel h2{margin-right:38px}
  .contact-actions{
    align-items:stretch;
    flex-direction:column;
  }
  .contact-actions .btn{
    width:100%;
    text-align:center;
  }
  .contact-email{
    width:100%;
    max-width:320px;
    text-align:center;
  }
  .admin-panel{padding:22px}
  .admin-toolbar{align-items:flex-start;flex-direction:column}
  .impressum-block{padding:28px 24px}
}
