/*
Theme Name: SPD Ortsverein
Theme URI: https://www.spd-dienheim.de
Author: SPD-Ortsverein Dienheim
Author URI: https://www.spd-dienheim.de
Description: Bürgernahes Block-Theme (Full Site Editing) für den SPD-Ortsverein Dienheim. Klares Design in SPD-Rot, mit eigenem Bereich für längere Beiträge, wiederverwendbaren Blöcken (Hero-Zitatkarte, Download-Karte) und Mustern für Startseite, Grillplatz, Kontakt, Team und politische Positionen. Für WordPress 7.
Requires at least: 6.6
Tested up to: 7.0
Requires PHP: 7.4
Version: 1.0.17
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: spd-ortsverein
Tags: full-site-editing, block-patterns, blog, news, custom-colors, custom-menu, editor-style, featured-images, translation-ready, sticky-post, one-column, two-columns, right-sidebar
*/

:root{
  --red:#E3000F; --red-dark:#A8000B; --red-deep:#7A0008;
  --ink:#1A1718; --ink-soft:#534D4E;
  --paper:#FCFBF9; --sand:#F3EEE7; --sand-deep:#ECE4D9; --line:#E4DDD3; --white:#fff;
  --display:'Bricolage Grotesque',system-ui,-apple-system,'Segoe UI',sans-serif;
  --body:'Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --r:14px; --shadow:0 1px 2px rgba(26,23,24,.04),0 8px 28px rgba(26,23,24,.06);
}

body{font-family:var(--body);color:var(--ink);background:var(--paper);font-size:18px;line-height:1.65;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,h5{font-family:var(--display);line-height:1.1;letter-spacing:-.01em;}
a{color:var(--red-dark);}

/* Buttons (core block) */
.wp-block-button__link{background:var(--red);color:#fff;border-radius:999px;padding:14px 26px;font-weight:600;font-family:var(--body);border:2px solid var(--red);transition:transform .15s ease,background .2s ease;}
.wp-block-button__link:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px);}
.wp-block-button.is-style-outline .wp-block-button__link{background:transparent;color:var(--ink);border:2px solid var(--ink);}
.wp-block-button.is-style-outline .wp-block-button__link:hover{background:var(--ink);color:#fff;}
.spd-on-dark .wp-block-button__link{background:#fff;color:var(--red-deep);border-color:#fff;}
.spd-on-dark .wp-block-button__link:hover{background:var(--sand);color:var(--red-deep);}
:where(a):focus-visible,:where(button):focus-visible,:where(input):focus-visible,:where(textarea):focus-visible{outline:3px solid var(--red);outline-offset:3px;}

/* Header */
header.wp-block-template-part{position:sticky;top:0;z-index:100;}
.site-header{background:rgba(252,251,249,.96);border-bottom:1px solid var(--line);padding-top:0;padding-bottom:0;}
.site-header .spd-navbar{min-height:74px;align-items:center;padding-left:var(--wp--style--root--padding-left,20px);padding-right:var(--wp--style--root--padding-right,20px);}
.spd-brand{display:flex;align-items:center;gap:12px;}
.spd-brand .wp-block-site-logo{margin:0;line-height:0;}
.spd-brand .wp-block-site-logo img{border-radius:8px;display:block;}
.spd-brand .wp-block-site-title{margin:0;font-family:var(--display);font-weight:800;font-size:1.35rem;letter-spacing:-.02em;line-height:1;}
.spd-brand .wp-block-site-title a{color:var(--ink);text-decoration:none;}
.spd-brand .wp-block-site-title a:hover{color:var(--red-dark);}
.spd-nav .wp-block-navigation-item__content{color:var(--ink);font-weight:500;}
.spd-nav a:hover{color:var(--red-dark);}
.wp-block-navigation .wp-block-navigation-item.current-menu-item .wp-block-navigation-item__content{color:var(--red-dark);font-weight:600;}

/* Mobiles Ausklapp-Menü: Punkte untereinander, ganzflächig & lesbar */
.wp-block-navigation__responsive-container.is-menu-open{position:fixed!important;inset:0!important;width:100%!important;height:100%!important;background:var(--paper)!important;padding:84px 24px 32px!important;overflow-y:auto!important;z-index:100000;}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content{width:100%!important;}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-page-list{display:flex!important;flex-direction:column!important;flex-wrap:nowrap!important;align-items:flex-start!important;gap:4px!important;width:100%!important;}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item{width:100%!important;}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content{display:block;width:100%;font-size:1.35rem;padding:12px 0;color:var(--ink);border-bottom:1px solid var(--line);}
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover{color:var(--red-dark);}

/* Footer */
.site-footer{background:var(--ink);color:rgba(255,255,255,.78);padding:0;}
.spd-footer-wave{background:var(--paper);color:var(--ink);line-height:0;}
.spd-footer-wave .spd-wave{display:block;width:100%;height:60px;}
.site-footer-inner{padding-top:64px;padding-bottom:30px;}
.site-footer h2,.site-footer h3,.site-footer h4{color:#fff;}
.site-footer a{color:rgba(255,255,255,.78);}
.site-footer a:hover{color:#fff;}
.site-footer .foot-brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:800;font-size:1.3rem;color:#fff;}
.site-footer .foot-brand .spd-mark{background:var(--red);color:#fff;padding:5px 11px;border-radius:8px;font-size:1.1rem;line-height:1;}
.site-footer .foot-bottom{border-top:1px solid rgba(255,255,255,.13);padding-top:24px;font-size:.88rem;opacity:.65;}
.spd-footer-nav .wp-block-navigation-item__content{color:rgba(255,255,255,.78);font-weight:400;}
.spd-footer-nav a:hover{color:#fff;}
.site-footer .wp-block-social-links{gap:12px;}
.site-footer .wp-block-social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);margin:0;transition:background .2s ease,transform .15s ease;}
.site-footer .wp-block-social-link:hover{background:var(--red);transform:translateY(-2px);}
.site-footer .wp-block-social-link .wp-block-social-link-anchor{padding:0;display:flex;color:#fff;}
.site-footer .wp-block-social-link .wp-block-social-link-svg{width:20px;height:20px;fill:#fff;}

/* Generic section helpers */
.spd-sand{background:var(--sand);}
.spd-ink{background:var(--ink);color:#fff;}
.spd-ink h1,.spd-ink h2,.spd-ink h3{color:#fff;}
.spd-eyebrow{font-family:var(--body);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--red);}
.spd-ink .spd-eyebrow{color:#fff;}

/* Page header */
.spd-page-header{background:var(--sand);border-bottom:1px solid var(--line);padding-top:64px;padding-bottom:56px;}
.spd-page-header h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:800;}
.spd-crumbs{font-size:.9rem;color:var(--ink-soft);}

/* Hero */
.spd-hero{padding-top:72px;}
.spd-hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:800;}
.spd-hero .has-red-color{color:var(--red);}
.spd-hero .lead{font-size:1.22rem;color:var(--ink-soft);}
.spd-hero-card{background:var(--red);color:#fff;border-radius:22px;padding:38px 34px;box-shadow:var(--shadow);}
.spd-hero-card .quote{font-family:var(--display);font-weight:600;font-size:1.5rem;line-height:1.25;}
.spd-hero-card .sig{border-top:1px solid rgba(255,255,255,.25);padding-top:18px;margin-top:8px;}
.spd-hero-card .avatar{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.18);display:grid;place-items:center;font-family:var(--display);font-weight:700;}
.spd-wave{display:block;width:100%;height:60px;color:var(--ink);}

/* Stat strip */
.spd-strip{background:var(--ink);color:#fff;padding-top:30px;padding-bottom:30px;}
.spd-strip .stat b{font-family:var(--display);font-weight:700;font-size:1.5rem;display:block;}
.spd-strip .stat span{opacity:.7;font-size:.95rem;}

/* Cards */
.spd-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;transition:transform .18s ease,box-shadow .18s ease;height:100%;}
.spd-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.spd-card .num{font-family:var(--display);font-weight:700;color:var(--red);}
.spd-card h3{font-size:1.35rem;font-weight:700;}
.spd-card p{color:var(--ink-soft);}

/* Ortsheft / gradient card */
.spd-ortsheft{background:linear-gradient(135deg,var(--red),var(--red-deep));color:#fff;border-radius:22px;padding:42px;box-shadow:var(--shadow);}
.spd-ortsheft .tag{display:inline-block;background:rgba(255,255,255,.16);padding:6px 14px;border-radius:999px;font-size:.82rem;font-weight:600;}
.spd-ortsheft h3{font-size:1.9rem;font-weight:700;margin:14px 0 8px;color:#fff;}
.spd-ortsheft>p{opacity:.9;margin:0;}
.spd-download-link{display:inline-flex;align-items:center;gap:12px;background:rgba(255,255,255,.12);border-radius:12px;padding:14px 18px;color:#fff;text-decoration:none;margin-top:18px;transition:background .2s ease;}
.spd-download-link:hover{background:rgba(255,255,255,.22);text-decoration:none;}
.spd-download-link .ic{background:#fff;color:var(--red-deep);border-radius:9px;padding:8px 10px;font-weight:700;font-family:var(--display);font-size:.8rem;line-height:1;}
.spd-download-link .meta{font-weight:600;}

/* Grillplatz panel */
.spd-panel{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);padding:32px;}
.spd-note{font-size:.92rem;background:rgba(227,0,15,.18);border-left:3px solid var(--red);padding:14px 16px;border-radius:8px;}

/* Contact */
.spd-alert{background:#fff;border:1px solid var(--line);border-left:4px solid var(--red);border-radius:10px;padding:18px 20px;}
.spd-form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;box-shadow:var(--shadow);}
.spd-form label{display:block;font-weight:600;font-size:.92rem;margin-bottom:7px;}
.spd-form input,.spd-form textarea{box-sizing:border-box;width:100%;max-width:100%;font-family:var(--body);font-size:1rem;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;background:var(--paper);margin-bottom:16px;}
.spd-form input:focus,.spd-form textarea:focus{border-color:var(--red);outline:none;}

/* ---- Contact Form 7 ---- */
.wpcf7-form{font-family:var(--body);}
.wpcf7-form p{margin:0 0 18px;}
.wpcf7-form label{display:block;font-weight:600;font-size:.92rem;margin-bottom:7px;color:var(--ink);}
.wpcf7-form input[type=text],
.wpcf7-form input[type=email],
.wpcf7-form input[type=tel],
.wpcf7-form input[type=url],
.wpcf7-form input[type=number],
.wpcf7-form input[type=date],
.wpcf7-form select,
.wpcf7-form textarea{
  box-sizing:border-box;width:100%;max-width:100%;font-family:var(--body);font-size:1rem;padding:13px 15px;
  border:1.5px solid var(--line);border-radius:10px;background:var(--paper);color:var(--ink);
  transition:border-color .15s ease,box-shadow .15s ease;
}
.wpcf7-form input[type=text]:focus,
.wpcf7-form input[type=email]:focus,
.wpcf7-form input[type=tel]:focus,
.wpcf7-form input[type=url]:focus,
.wpcf7-form input[type=number]:focus,
.wpcf7-form input[type=date]:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus{border-color:var(--red);outline:none;box-shadow:0 0 0 3px rgba(227,0,15,.12);}
.wpcf7-form textarea{min-height:140px;resize:vertical;}
.wpcf7-form ::placeholder{color:#9a9192;}

/* Senden-Button im Stil der Theme-Buttons */
.wpcf7-form input[type=submit],
.wpcf7-form button[type=submit]{
  background:var(--red);color:#fff;border:2px solid var(--red);border-radius:999px;
  padding:14px 30px;font-family:var(--body);font-weight:600;font-size:1rem;cursor:pointer;
  transition:transform .15s ease,background .2s ease;
}
.wpcf7-form input[type=submit]:hover,
.wpcf7-form button[type=submit]:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px);}

/* Checkboxen / Radios / Datenschutz-Einwilligung */
.wpcf7-form .wpcf7-list-item{margin:0 14px 6px 0;}
.wpcf7-form .wpcf7-list-item label,
.wpcf7-form .wpcf7-acceptance label{display:flex;align-items:flex-start;gap:8px;font-weight:400;margin:0;}
.wpcf7-form input[type=checkbox],
.wpcf7-form input[type=radio]{width:auto;accent-color:var(--red);margin-top:3px;}

/* Validierung & Rueckmeldungen */
.wpcf7-form .wpcf7-not-valid{border-color:var(--red)!important;}
.wpcf7-not-valid-tip{color:var(--red-dark);font-size:.85rem;margin-top:5px;}
.wpcf7-response-output{margin:18px 0 0!important;padding:14px 16px!important;border-radius:10px;font-size:.95rem;border:1px solid var(--line);}
.wpcf7 form.sent .wpcf7-response-output{background:#eef7ee;border-color:#bcdfbc;color:#1f5a23;}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.spam .wpcf7-response-output{background:rgba(227,0,15,.08);border-color:rgba(227,0,15,.4);color:var(--red-deep);}
.wpcf7-spinner{background-color:var(--red);}

/* Optionale zweispaltige Zeile (im CF7-Formular: <div class="spd-cf7-row"> … </div>) */
.wpcf7-form .spd-cf7-row{display:grid;grid-template-columns:1fr 1fr;gap:0 16px;}
@media(max-width:600px){.wpcf7-form .spd-cf7-row{grid-template-columns:1fr;}}

/* ---- Aktuelles: Query Loop als Karten-Raster ---- */
.spd-posts .wp-block-post-template{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.spd-posts .wp-block-post{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .18s ease,box-shadow .18s ease;}
.spd-posts .wp-block-post:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.spd-posts .wp-block-post-featured-image{margin:0;}
.spd-posts .wp-block-post-featured-image img{aspect-ratio:16/10;object-fit:cover;width:100%;}
.spd-posts .wp-block-post-featured-image.spd-noimg{aspect-ratio:16/10;background:linear-gradient(135deg,var(--red),var(--red-deep));}
.spd-posts .spd-post-inner{padding:24px;display:flex;flex-direction:column;flex:1;}
.spd-posts .wp-block-post-title{font-size:1.3rem;font-weight:700;line-height:1.15;margin:8px 0 10px;}
.spd-posts .wp-block-post-title a{color:var(--ink);text-decoration:none;}
.spd-posts .wp-block-post-title a:hover{color:var(--red-dark);}
.spd-posts .wp-block-post-excerpt{color:var(--ink-soft);font-size:.98rem;}
.spd-posts .wp-block-post-date,.spd-posts .wp-block-post-terms{font-size:.82rem;color:var(--ink-soft);}
.spd-posts .wp-block-post-terms a{background:var(--sand-deep);color:var(--red-deep);font-weight:600;padding:3px 10px;border-radius:999px;font-size:.75rem;text-decoration:none;}

/* ---- Einzelbeitrag / Seiten-Inhalt ---- */
.spd-article .wp-block-post-title{font-size:clamp(2.1rem,4.5vw,3rem);font-weight:800;line-height:1.1;}
.spd-article .wp-block-post-featured-image img{border-radius:var(--r);}
.spd-meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--ink-soft);font-size:.92rem;}
.spd-meta .wp-block-post-terms a{background:var(--sand-deep);color:var(--red-deep);font-weight:600;padding:3px 10px;border-radius:999px;font-size:.75rem;text-decoration:none;}
.entry-content,.spd-content{font-size:1.12rem;line-height:1.8;}
.entry-content h2{font-size:1.7rem;font-weight:700;margin:42px 0 14px;}
.entry-content h3{font-size:1.3rem;font-weight:700;margin:30px 0 10px;}
.entry-content blockquote{margin:32px 0;padding:8px 0 8px 26px;border-left:4px solid var(--red);font-family:var(--display);font-weight:600;font-size:1.4rem;line-height:1.35;}
.entry-content ul,.entry-content ol{padding-left:1.3rem;}

/* ---- Personen-Raster (Team) ---- */
.spd-person{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:100%;transition:transform .18s ease,box-shadow .18s ease;}
.spd-person:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.spd-person .wp-block-image{margin:0;background:var(--sand);aspect-ratio:4/5;}
.spd-person .wp-block-image img{width:100%;height:100%;object-fit:cover;display:block;}
.spd-person-body{padding:20px 22px;}
.spd-person-body h3{font-size:1.2rem;font-weight:700;margin:0 0 3px;}
.spd-person-body .role{color:var(--red);font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px;}
.spd-person-body p{margin:0;color:var(--ink-soft);font-size:.97rem;line-height:1.55;}

/* ---- Politische Positionen ---- */
.spd-pos-nav{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px;}
.spd-pos-chip{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 18px 9px 11px;text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem;transition:transform .15s ease,border-color .15s ease,color .15s ease;}
.spd-pos-chip:hover{border-color:var(--red);color:var(--red-dark);transform:translateY(-2px);text-decoration:none;}
.spd-pos-chip .ico{width:30px;height:30px;border-radius:50%;background:rgba(227,0,15,.1);color:var(--red);display:grid;place-items:center;flex:0 0 auto;}
.spd-pos-chip .ico svg{width:18px;height:18px;}
.spd-pos-section{scroll-margin-top:90px;}
.spd-pos-badge{display:flex;align-items:center;gap:14px;margin-bottom:12px;flex-wrap:nowrap;}
.spd-pos-badge .ico{width:54px;height:54px;border-radius:14px;background:var(--red);color:#fff;display:grid;place-items:center;flex:0 0 auto;}
.spd-pos-badge .ico svg{width:30px;height:30px;}
.spd-pos-badge .kicker{font-family:var(--display);font-weight:700;color:var(--red);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;margin:0;}
.spd-pos-lead{font-size:1.25rem;font-weight:600;line-height:1.5;color:var(--ink);}

/* ---- 404-Seite ---- */
.spd-404{text-align:center;}
.spd-404-num{font-family:var(--display);font-weight:800;font-size:clamp(5rem,18vw,11rem);line-height:.9;color:var(--red);letter-spacing:-.03em;}
.spd-404-stamp{display:inline-block;transform:rotate(-6deg);border:3px double var(--red);color:var(--red);font-family:var(--display);font-weight:800;text-transform:uppercase;letter-spacing:.18em;font-size:1rem;padding:6px 18px 5px;border-radius:6px;opacity:.85;margin:8px 0 10px;}
.spd-404 h1{font-size:clamp(1.9rem,4vw,2.8rem);font-weight:800;margin:6px 0 14px;}
.spd-404 p{font-size:1.15rem;color:var(--ink-soft);max-width:46ch;margin-left:auto;margin-right:auto;}

/* Responsive */
@media (max-width:900px){
  .spd-posts .wp-block-post-template{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion: reduce){
  .wp-block-button__link:hover,.spd-card:hover,.spd-posts .wp-block-post:hover{transform:none;}
}
