/*
Theme Name: Dominic Monaghan
Theme URI: https://dominicmonaghan.de/
Author: dominicmonaghan.de Redaktion
Author URI: https://dominicmonaghan.de/
Description: Editorial Porträt-Theme über Dominic Monaghan – Schauspieler, „Herr der Ringe“, „Lost“, Filme & Serien. Ruhige „Misty Forest“-Ästhetik in Tannengrün, Pergament-Creme und Terrakotta. Inkludiert Demo-Importer und Plugin-Empfehlungen (Yoast SEO, Classic Editor, Classic Widgets, WPCode).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
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: dominic-monaghan
Tags: blog, editorial, news, two-columns, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready
*/

:root{
  --forest:#1f3a2e;        /* deep evergreen */
  --forest-deep:#16271f;
  --moss:#3d6249;
  --parchment:#f4ecdc;     /* warm cream */
  --parchment-2:#fbf6ea;
  --paper:#ffffff;
  --ink:#1a1f1c;
  --ink-soft:#5a6258;
  --terracotta:#c25b3f;    /* warm orange-red accent */
  --terracotta-soft:#e89478;
  --gold:#b08a3e;
  --line:#d9d1bd;
  --shadow:0 18px 48px -22px rgba(31,58,46,.32);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;
  font-size:17px; line-height:1.7;
  color:var(--ink); background:var(--parchment);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--terracotta);text-decoration:none;transition:color .2s}
a:hover{color:var(--forest)}

h1,h2,h3,h4{font-family:'Fraunces','Georgia',serif;font-weight:600;color:var(--forest);letter-spacing:-.015em;line-height:1.15;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5.4vw,4.2rem);font-weight:500;font-style:italic}
h2{font-size:clamp(1.8rem,3.2vw,2.4rem)}
h3{font-size:1.25rem;font-weight:600}
p{margin:0 0 1em}

.container{max-width:1180px;margin:0 auto;padding:0 24px}
.eyebrow{display:inline-block;font-family:'Manrope',sans-serif;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--terracotta);font-weight:700;margin-bottom:18px;border-top:1px solid var(--terracotta);padding-top:8px}

.screen-reader-text{position:absolute;clip:rect(1px,1px,1px,1px);overflow:hidden;width:1px;height:1px}

/* ---------- HEADER ---------- */
.site-header{
  background:var(--parchment);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.header-inner{
  max-width:1180px;margin:0 auto;padding:22px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.site-branding .site-title{margin:0;font-family:'Fraunces',serif;font-size:1.7rem;font-weight:600;font-style:italic;letter-spacing:-.02em}
.site-branding .site-title a{color:var(--forest)}
.site-branding .site-title a:hover{color:var(--terracotta)}
.site-branding .site-description{margin:2px 0 0;font-size:.72rem;color:var(--ink-soft);letter-spacing:.18em;text-transform:uppercase;font-weight:600}
.main-nav ul{list-style:none;display:flex;gap:30px;margin:0;padding:0}
.main-nav a{color:var(--forest);font-weight:600;font-size:.88rem;letter-spacing:.04em;position:relative;padding:6px 0}
.main-nav a:hover{color:var(--terracotta)}
.main-nav .current-menu-item > a{color:var(--terracotta)}
.main-nav .current-menu-item > a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--terracotta)}
.menu-toggle{display:none;background:var(--forest);border:0;color:var(--parchment);padding:10px 16px;font-weight:600;cursor:pointer;letter-spacing:.06em;border-radius:2px}

@media(max-width:860px){
  .menu-toggle{display:inline-block}
  .main-nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--parchment);border-bottom:1px solid var(--line);padding:18px 24px}
  .main-nav.is-open{display:block}
  .main-nav ul{flex-direction:column;gap:14px}
}

/* ---------- HERO ---------- */
.dm-hero{
  background:var(--forest);
  color:var(--parchment);
  position:relative; overflow:hidden;
  padding:96px 0 110px;
}
.dm-hero::before{
  content:""; position:absolute; inset:0;
  background-image:
    radial-gradient(ellipse at 80% 20%, rgba(176,138,62,.18) 0, transparent 55%),
    radial-gradient(ellipse at 10% 90%, rgba(194,91,63,.14) 0, transparent 55%);
  pointer-events:none;
}
.dm-hero-grid{
  position:relative;z-index:1;
  max-width:1180px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;
}
.dm-hero-text h1{color:var(--parchment)}
.dm-hero-text h1 em{color:var(--terracotta-soft);font-style:italic}
.dm-hero .eyebrow{color:var(--terracotta-soft);border-color:var(--terracotta-soft)}
.dm-lead{font-size:1.12rem;line-height:1.7;max-width:560px;margin:18px 0 32px;color:#d6d2c2;font-weight:300}
.dm-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}
.dm-btn{
  display:inline-block;padding:14px 28px;background:var(--terracotta);color:var(--parchment);font-weight:600;
  border:1px solid var(--terracotta);letter-spacing:.04em;font-size:.92rem;
  font-family:'Manrope',sans-serif; border-radius:2px;
  transition:transform .2s, background .2s;
}
.dm-btn:hover{background:var(--forest-deep);border-color:var(--parchment);color:var(--parchment);transform:translateY(-2px)}
.dm-btn-outline{background:transparent;color:var(--parchment);border:1px solid var(--parchment)}
.dm-btn-outline:hover{background:var(--parchment);color:var(--forest);border-color:var(--parchment)}
.dm-hero-points{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.dm-hero-points li{position:relative;padding-left:26px;font-size:.96rem;color:#d6d2c2}
.dm-hero-points li::before{content:"";position:absolute;left:0;top:.7em;width:14px;height:1px;background:var(--terracotta-soft)}
.dm-portrait{position:relative}
.dm-portrait::before{
  content:""; position:absolute; inset:-18px -18px 18px 18px;
  border:1px solid var(--terracotta-soft); z-index:0; pointer-events:none;
}
.dm-portrait img{position:relative;z-index:1;aspect-ratio:4/5;object-fit:cover;width:100%;filter:saturate(.9) contrast(1.02)}
.dm-portrait-tag{
  position:absolute; bottom:-22px; left:-22px; z-index:2;
  background:var(--parchment); color:var(--forest);
  font-family:'Fraunces',serif; font-style:italic; font-size:.95rem;
  padding:12px 18px; border:1px solid var(--forest);
}
@media(max-width:860px){.dm-hero{padding:64px 0 90px}.dm-hero-grid{grid-template-columns:1fr;gap:50px}.dm-portrait::before{display:none}}

/* ---------- META RULE STRIP ---------- */
.dm-rule{background:var(--parchment-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.dm-rule-inner{max-width:1180px;margin:0 auto;padding:34px 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.dm-rule-inner > div{text-align:center;border-right:1px dashed var(--line);padding:6px 0}
.dm-rule-inner > div:last-child{border-right:0}
.dm-stat-num{display:block;font-family:'Fraunces',serif;font-size:2.2rem;color:var(--forest);font-weight:600;font-style:italic}
.dm-stat-lbl{display:block;font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px;font-weight:600}
@media(max-width:680px){.dm-rule-inner{grid-template-columns:repeat(2,1fr)}.dm-rule-inner > div:nth-child(2){border-right:0}}

/* ---------- SECTIONS ---------- */
.dm-section{padding:100px 0}
.dm-section-head{text-align:center;max-width:740px;margin:0 auto 60px}
.dm-section-sub{color:var(--ink-soft);font-size:1.05rem;margin-top:12px;font-weight:300}

/* Pillars / cards */
.dm-pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.dm-pillar{
  background:var(--paper);padding:38px 30px;
  border:1px solid var(--line); border-top:3px solid var(--terracotta);
  transition:transform .25s, box-shadow .25s;
}
.dm-pillar:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.dm-pillar .dm-pillar-num{display:block;font-family:'Fraunces',serif;font-style:italic;font-size:.92rem;color:var(--terracotta);margin-bottom:8px;letter-spacing:.04em}
.dm-pillar h3{margin:0 0 12px;color:var(--forest)}
.dm-pillar p{color:var(--ink-soft);margin:0;font-size:.97rem}
@media(max-width:860px){.dm-pillars{grid-template-columns:1fr}.dm-section{padding:64px 0}}

/* Feature band */
.dm-feature{background:var(--forest);color:var(--parchment);padding:100px 0}
.dm-feature h2{color:var(--parchment)}
.dm-feature .eyebrow{color:var(--terracotta-soft);border-color:var(--terracotta-soft)}
.dm-feature-grid{max-width:1180px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.dm-feature img{filter:saturate(.9)}
.dm-feature p{color:#d6d2c2;font-weight:300}
.dm-feature .dm-btn-outline{margin-top:8px}
@media(max-width:860px){.dm-feature{padding:60px 0}.dm-feature-grid{grid-template-columns:1fr;gap:36px}}

/* Quote band */
.dm-quote{
  background:var(--parchment-2); color:var(--forest); padding:96px 24px; text-align:center;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line); position:relative;
}
.dm-quote::before{content:"\201C";position:absolute;left:50%;top:14px;transform:translateX(-50%);font-family:'Fraunces',serif;font-size:7rem;color:var(--terracotta);line-height:1;opacity:.35}
.dm-quote blockquote{font-family:'Fraunces',serif;font-style:italic;font-size:clamp(1.4rem,2.8vw,2rem);max-width:820px;margin:30px auto 18px;line-height:1.4;color:var(--forest);font-weight:400}
.dm-quote cite{font-style:normal;font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--terracotta);font-weight:700}

/* ---------- POST GRID ---------- */
.dm-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.dm-post{
  background:var(--paper); border:1px solid var(--line);
  display:flex;flex-direction:column;transition:transform .25s, box-shadow .25s;
}
.dm-post:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.dm-thumb{display:block;aspect-ratio:3/2;overflow:hidden;background:var(--parchment-2)}
.dm-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s;filter:saturate(.92)}
.dm-post:hover .dm-thumb img{transform:scale(1.04)}
.dm-body{padding:26px 28px 30px}
.post-meta{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);font-weight:700;margin-bottom:10px}
.post-meta a{color:var(--terracotta)}
.dm-post h3{font-size:1.2rem;margin:0 0 10px;line-height:1.3;font-family:'Fraunces',serif}
.dm-post h3 a{color:var(--forest)}
.dm-post h3 a:hover{color:var(--terracotta)}
.dm-post p{color:var(--ink-soft);font-size:.95rem;margin:0 0 14px;font-weight:300}
.read-more{font-weight:700;font-size:.78rem;color:var(--forest);letter-spacing:.16em;text-transform:uppercase;border-bottom:1px solid var(--terracotta);padding-bottom:2px}
.read-more:hover{color:var(--terracotta)}
@media(max-width:860px){.dm-posts{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.dm-faq{max-width:820px;margin:0 auto}
.dm-faq details{
  background:var(--paper); border:1px solid var(--line); padding:20px 26px; margin-bottom:14px;
  transition:border-color .2s;
}
.dm-faq details[open]{border-color:var(--terracotta)}
.dm-faq summary{cursor:pointer;font-family:'Fraunces',serif;font-size:1.08rem;color:var(--forest);list-style:none;display:flex;justify-content:space-between;align-items:center;font-weight:600}
.dm-faq summary::after{content:"+";color:var(--terracotta);font-size:1.6rem;font-weight:300;line-height:1}
.dm-faq details[open] summary::after{content:"–"}
.dm-faq p{margin:14px 0 0;color:var(--ink-soft);font-weight:300}

/* ---------- CTA BAND ---------- */
.dm-cta{background:var(--forest-deep);color:var(--parchment);text-align:center;padding:90px 24px;border-top:1px solid var(--moss)}
.dm-cta h2{color:var(--parchment)}
.dm-cta p{color:#d6d2c2;max-width:620px;margin:0 auto 28px;font-weight:300}

/* ---------- CONTENT GRID ---------- */
.content-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:60px;padding:70px 24px;max-width:1180px;margin:0 auto}
@media(max-width:960px){.content-grid{grid-template-columns:1fr;gap:40px}}
.single-post-content, .page-content{background:var(--paper);border:1px solid var(--line);padding:48px 52px}
.single-post-content h1, .page-content h1{margin-top:0}
.single-post-content .post-meta{margin-bottom:24px}
.featured-image{margin:24px 0 30px;border:1px solid var(--line)}
.single-post-content blockquote, .page-content blockquote{border-left:3px solid var(--terracotta);background:var(--parchment-2);padding:18px 24px;margin:24px 0;font-family:'Fraunces',serif;font-style:italic;font-size:1.18rem;line-height:1.5;color:var(--forest)}
.single-post-content ul, .page-content ul{padding-left:22px}
.single-post-content h2, .page-content h2{margin-top:36px;font-family:'Fraunces',serif}
.single-post-content h3, .page-content h3{margin-top:26px;color:var(--terracotta);font-family:'Fraunces',serif;font-style:italic}
.single-post-content img, .page-content img{margin:18px 0;border:1px solid var(--line)}

.posts-list{display:grid;gap:32px}
.post-card{background:var(--paper);border:1px solid var(--line);overflow:hidden;display:grid;grid-template-columns:280px 1fr}
.post-card .thumb{display:block;background:var(--parchment-2)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;aspect-ratio:1/1}
.post-card .post-body{padding:28px 32px}
.post-card h2{font-size:1.5rem;margin:0 0 10px;font-family:'Fraunces',serif}
.post-card h2 a{color:var(--forest)}
.post-card h2 a:hover{color:var(--terracotta)}
@media(max-width:680px){.post-card{grid-template-columns:1fr}}

.sidebar .widget{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--terracotta);padding:26px 28px;margin-bottom:26px}
.sidebar .widget-title{margin:0 0 14px;font-size:1rem;color:var(--forest);font-family:'Fraunces',serif;font-style:italic}

.search-form{display:flex;gap:0;border:1px solid var(--line);background:var(--paper)}
.search-form input{flex:1;padding:12px 14px;border:0;background:transparent;color:var(--ink);font-family:inherit;font-size:.95rem;outline:none}
.search-form button{background:var(--forest);color:var(--parchment);border:0;padding:0 20px;cursor:pointer;font-weight:600;font-size:1rem}

.pagination{margin-top:36px;text-align:center}
.pagination .page-numbers{display:inline-block;padding:10px 14px;border:1px solid var(--line);margin:0 4px;color:var(--forest);font-weight:600;background:var(--paper)}
.pagination .page-numbers.current,.pagination .page-numbers:hover{background:var(--terracotta);color:var(--parchment);border-color:var(--terracotta)}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--forest-deep);color:#aab1a4;border-top:4px solid var(--terracotta);padding:64px 0 30px;margin-top:0}
.footer-grid{max-width:1180px;margin:0 auto 40px;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.footer-grid h3{color:var(--parchment);font-size:1rem;margin:0 0 14px;font-family:'Fraunces',serif;font-style:italic}
.footer-grid a{color:var(--parchment)}
.footer-grid a:hover{color:var(--terracotta-soft)}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:8px}
.footer-bottom{max-width:1180px;margin:0 auto;padding:22px 24px 0;border-top:1px solid #2a3329;font-size:.82rem;color:#7a8478;text-align:center}
.footer-bottom a{color:#aab1a4}
.footer-bottom a:hover{color:var(--terracotta-soft)}
@media(max-width:680px){.footer-grid{grid-template-columns:1fr;gap:26px}}

/* Comments */
.comments-area{margin-top:40px;background:var(--paper);border:1px solid var(--line);padding:30px 32px}
.comments-area h3{margin-top:0;font-family:'Fraunces',serif;font-style:italic}
.comment-list{list-style:none;padding:0;margin:0 0 20px}
.comment-list li{border-bottom:1px dashed var(--line);padding:14px 0}
.comment-form input[type="text"], .comment-form input[type="email"], .comment-form input[type="url"], .comment-form textarea{
  width:100%;padding:10px 12px;border:1px solid var(--line);background:var(--parchment-2);font-family:inherit;font-size:.95rem;margin-bottom:12px;
}
.comment-form .submit{background:var(--terracotta);color:var(--parchment);border:0;padding:12px 24px;font-weight:600;letter-spacing:.04em;cursor:pointer}
.comment-form .submit:hover{background:var(--forest)}
