/*
Theme Name: GZ Journal
Theme URI: https://www.gz-journal.de/
Author: GZ Journal Redaktion
Author URI: https://www.gz-journal.de/
Description: Modernes News-/Magazin-Theme für GZ Journal. Blau-Weiß mit warmem Orange-Akzent, Grid-Startseite, Top-News, Sidebar mit Autorenbox (EEAT), responsiv und barrierearm.
Version: 1.0.1
Requires at least: 6.0
Tested up to: 6.9
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: gz-journal
Tags: news, blog, magazine, two-columns, right-sidebar, custom-menu, featured-images, threaded-comments, translation-ready
*/

:root{
  --blue-900:#0a1f6b;
  --blue-800:#102a8a;
  --blue-700:#163aa8;
  --blue-600:#1f4fd6;
  --blue-100:#e7edfb;
  --blue-50:#f4f7fe;
  --accent:#f5821f;
  --accent-dark:#d96a0a;
  --accent-soft:#fff1e3;
  --ink:#11141c;
  --ink-soft:#475067;
  --line:#e3e7f0;
  --white:#ffffff;
  --bg:#f7f9fc;
  --radius:14px;
  --shadow:0 2px 14px rgba(16,42,138,.08);
  --shadow-hover:0 10px 30px rgba(16,42,138,.16);
  --maxw:1240px;
  --font:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* Accessibility */
.skip{position:absolute;left:-999px;top:0;background:var(--blue-700);color:#fff;padding:10px 16px;z-index:1000;border-radius:0 0 8px 0}
.skip:focus{left:0}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* Topbar */
.topbar{background:var(--blue-900);color:#cdd7f7;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px}
.topbar .date{letter-spacing:.02em}
.topbar nav a{margin-left:18px;color:#cdd7f7;transition:color .2s}
.topbar nav a:hover{color:#fff}
.topbar .menu{display:flex;list-style:none}
.topbar .menu li{margin-left:18px}

/* Header */
.site-header{background:var(--white);border-bottom:1px solid var(--line);border-top:3px solid var(--accent);position:sticky;top:0;z-index:90}
.header-main{display:flex;align-items:center;gap:24px;height:78px}
.brand{display:flex;align-items:center;gap:12px}
.logo-mark{width:50px;height:50px;border-radius:50%;background:var(--blue-700);display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.5rem;font-style:italic;letter-spacing:-1px;overflow:hidden}
.logo-mark img{width:100%;height:100%;object-fit:cover}
.brand-text strong{display:block;font-size:1.45rem;font-weight:800;color:var(--blue-900);letter-spacing:-.5px;line-height:1}
.brand-text span{font-size:.78rem;color:var(--ink-soft)}
.header-search{margin-left:auto;display:flex;align-items:center;background:var(--blue-50);border:1px solid var(--line);border-radius:30px;padding:8px 16px;width:280px;max-width:34vw}
.header-search input{border:0;background:transparent;outline:none;width:100%;font-size:.9rem;color:var(--ink)}
.header-search button{border:0;background:none;cursor:pointer;color:var(--blue-700);display:flex}
.header-search svg{color:var(--blue-700);flex-shrink:0}
.btn-sub{background:var(--accent);color:#fff;padding:10px 20px;border-radius:30px;font-weight:600;font-size:.88rem;transition:background .2s;border:0;cursor:pointer;display:inline-block}
.btn-sub:hover{background:var(--accent-dark)}
.burger{display:none;background:none;border:0;cursor:pointer;color:var(--blue-900)}

/* Nav */
.mainnav{background:var(--blue-700)}
.mainnav .wrap{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}
.mainnav .wrap::-webkit-scrollbar{display:none}
.mainnav ul{display:flex;list-style:none}
.mainnav a{color:#dbe3fb;padding:13px 16px;font-size:.92rem;font-weight:500;white-space:nowrap;border-bottom:3px solid transparent;transition:.2s;display:block}
.mainnav a:hover,.mainnav .current-menu-item>a,.mainnav a[aria-current]{color:#fff;border-color:var(--accent);background:rgba(255,255,255,.08)}

/* Section heads */
.sec-head{display:flex;align-items:center;gap:14px;margin:38px 0 20px}
.sec-head h2{font-size:1.35rem;font-weight:800;color:var(--blue-900);position:relative;padding-left:14px}
.sec-head h2::before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:5px;background:var(--accent);border-radius:4px}
.sec-head .line{flex:1;height:1px;background:var(--line)}
.sec-head a.more{font-size:.85rem;color:var(--accent-dark);font-weight:600}

/* Cards */
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.cat{display:inline-block;background:var(--accent-soft);color:var(--accent-dark);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:6px}

/* Hero */
.hero{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-top:26px}
.lead{position:relative;height:100%;min-height:440px;color:#fff}
.lead img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.lead .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,31,107,0) 30%,rgba(10,31,107,.92))}
.lead .body{position:absolute;bottom:0;padding:28px;z-index:2}
.lead h3{font-size:1.7rem;font-weight:800;line-height:1.2;margin:12px 0}
.lead .meta{font-size:.82rem;opacity:.92;display:flex;align-items:center;gap:8px}
.lead .cat{background:var(--accent);color:#fff}
.side{display:flex;flex-direction:column;gap:18px}
.mini{display:flex;gap:14px;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.25s}
.mini:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.mini img{width:120px;height:108px;object-fit:cover;flex-shrink:0}
.mini .body{padding:12px 14px 12px 0}
.mini h4{font-size:.98rem;font-weight:700;line-height:1.3;margin:6px 0}
.mini .meta{font-size:.74rem;color:var(--ink-soft)}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.post-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.25s;display:flex;flex-direction:column}
.post-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover)}
.post-card .thumb{aspect-ratio:16/10;overflow:hidden;display:block;background:var(--blue-50)}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-card:hover .thumb img{transform:scale(1.05)}
.post-card .body{padding:16px 18px 18px;display:flex;flex-direction:column;flex:1}
.post-card h3{font-size:1.08rem;font-weight:700;line-height:1.32;margin:10px 0}
.post-card p{font-size:.9rem;color:var(--ink-soft);margin-bottom:14px}
.post-card .foot{margin-top:auto;display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid var(--line)}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--blue-700);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:700;flex-shrink:0;overflow:hidden}
.avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.author-info{font-size:.78rem;line-height:1.3}
.author-info b{color:var(--ink);font-weight:600}
.author-info span{color:var(--ink-soft)}

/* Listenform "Weitere Beiträge" */
.post-list{display:flex;gap:20px;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:.25s;margin-bottom:18px}
.post-list:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.post-list .thumb{flex:0 0 240px;aspect-ratio:16/10;overflow:hidden;display:block;background:var(--blue-50)}
.post-list .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post-list:hover .thumb img{transform:scale(1.05)}
.post-list .body{padding:18px 22px 18px 0;display:flex;flex-direction:column;justify-content:center;flex:1}
.post-list h3{font-size:1.2rem;font-weight:700;line-height:1.3;margin:10px 0 8px}
.post-list p{font-size:.92rem;color:var(--ink-soft);margin-bottom:12px}
.post-list .foot{display:flex;align-items:center;gap:10px;font-size:.8rem;color:var(--ink-soft)}
.post-list .foot .author-info b{color:var(--ink);font-weight:600}
@media(max-width:600px){
  .post-list{flex-direction:column}
  .post-list .thumb{flex:none;width:100%;aspect-ratio:16/9}
  .post-list .body{padding:0 18px 18px}
}

/* Layout w/ sidebar */
.layout{display:grid;grid-template-columns:1fr 320px;gap:32px;margin-top:14px}
aside .widget{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:22px}
aside .widget h3,aside .widget .widget-title{font-size:1.05rem;font-weight:800;color:var(--blue-900);margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--blue-100)}
aside .widget ul{list-style:none}
.cat-list a,aside .widget ul li a{display:flex;justify-content:space-between;padding:9px 0;font-size:.92rem;border-bottom:1px solid var(--line);transition:color .2s}
.cat-list a:last-child,aside .widget ul li:last-child a{border:0}
.cat-list a:hover,aside .widget ul li a:hover{color:var(--blue-700)}
.cat-list span{background:var(--blue-50);color:var(--blue-700);font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:20px}
.trend a{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);align-items:flex-start}
.trend a:last-child{border:0}
.trend .num{color:var(--accent);font-weight:800;font-size:1.2rem;width:26px;flex-shrink:0}
.trend p{font-size:.88rem;font-weight:600;line-height:1.35}

/* Author box */
.authorbox{display:flex;gap:14px;align-items:center}
.authorbox .av{width:54px;height:54px;border-radius:50%;background:var(--blue-700);color:#fff;display:grid;place-items:center;font-size:1.2rem;font-weight:800;flex-shrink:0;overflow:hidden}
.authorbox .av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.authorbox h4{font-size:1rem;color:var(--blue-900)}
.authorbox small{color:var(--ink-soft)}
.author-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin:30px 0;display:flex;gap:18px;align-items:flex-start}
.author-card .av{width:64px;height:64px;border-radius:50%;background:var(--blue-700);color:#fff;display:grid;place-items:center;font-size:1.4rem;font-weight:800;flex-shrink:0;overflow:hidden}
.author-card .av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.author-card h4{font-size:1.1rem;color:var(--blue-900);margin-bottom:3px}
.author-card .role{font-size:.82rem;color:var(--accent-dark);font-weight:600;margin-bottom:8px}
.author-card p{font-size:.9rem;color:var(--ink-soft);line-height:1.5}

/* Newsletter widget */
.nl{background:linear-gradient(135deg,var(--blue-700),var(--blue-900));color:#fff}
.nl h3,.nl .widget-title{color:#fff;border-color:rgba(255,255,255,.2)}
.nl p{font-size:.88rem;opacity:.9;margin-bottom:14px}
.nl input{width:100%;padding:11px 14px;border:0;border-radius:8px;margin-bottom:10px;font-size:.9rem}
.nl button{width:100%;background:var(--accent);color:#fff;font-weight:700;padding:11px;border:0;border-radius:8px;cursor:pointer;transition:.2s}
.nl button:hover{background:var(--accent-dark)}

/* Single post */
.single-article{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.single-article .hero-img{width:100%;max-height:460px;object-fit:cover}
.single-inner{padding:34px 40px 44px}
.single-inner .cat{margin-bottom:14px}
.single-inner h1{font-size:2.1rem;font-weight:800;color:var(--blue-900);line-height:1.2;margin-bottom:16px}
.article-meta{display:flex;align-items:center;gap:12px;padding-bottom:20px;margin-bottom:24px;border-bottom:1px solid var(--line);font-size:.85rem;color:var(--ink-soft)}
.entry-content{font-size:1.05rem;line-height:1.75;color:#1c2233}
.entry-content p{margin:0 0 1.2em}
.entry-content h2{font-size:1.5rem;color:var(--blue-900);margin:1.5em 0 .6em}
.entry-content h3{font-size:1.2rem;color:var(--blue-800);margin:1.3em 0 .5em}
.entry-content a{color:var(--blue-700);text-decoration:underline}
.entry-content img{border-radius:10px;margin:1.2em 0}
.entry-content blockquote{border-left:4px solid var(--accent);background:var(--accent-soft);padding:14px 20px;border-radius:0 8px 8px 0;margin:1.4em 0;font-style:italic}
.entry-content ul,.entry-content ol{margin:0 0 1.2em 1.4em}
.entry-content li{margin-bottom:.4em}

/* Page */
.page-content{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:34px 40px}
.page-content h1{font-size:1.9rem;color:var(--blue-900);margin-bottom:20px}

/* Archive header */
.archive-head{background:linear-gradient(135deg,var(--blue-800),var(--blue-900));color:#fff;border-radius:var(--radius);padding:30px 32px;margin-top:26px}
.archive-head h1{font-size:1.7rem;font-weight:800}
.archive-head p{opacity:.85;margin-top:6px;font-size:.92rem}

/* Pagination */
.pagination,.navigation.pagination{margin:36px 0;width:100%}
.pagination .nav-links,.navigation.pagination .nav-links{display:flex!important;flex-direction:row!important;justify-content:center;gap:8px;flex-wrap:wrap;align-items:center}
.pagination .page-numbers,.navigation.pagination .page-numbers{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 12px;background:#fff;border:1px solid var(--line);border-radius:10px;font-weight:600;color:var(--blue-800);transition:.2s;text-decoration:none}
.pagination .page-numbers:hover,.pagination .page-numbers.current,.navigation.pagination .page-numbers:hover,.navigation.pagination .page-numbers.current{background:var(--accent);border-color:var(--accent);color:#fff}
.pagination .page-numbers.dots{border:0;background:transparent;min-width:auto;padding:0 4px}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* Comments */
.comments-area{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:30px 40px;margin-top:26px}
.comments-area h2{font-size:1.3rem;color:var(--blue-900);margin-bottom:18px}
.comment-list{list-style:none}
.comment-body{padding:16px 0;border-bottom:1px solid var(--line)}
.comment-author{font-weight:600;color:var(--blue-900)}
.comment-form input,.comment-form textarea{width:100%;padding:10px 14px;border:1px solid var(--line);border-radius:8px;margin-bottom:12px;font-family:inherit}
.comment-form input[type=submit]{width:auto;background:var(--accent);color:#fff;border:0;font-weight:700;padding:11px 24px;cursor:pointer}

/* Footer */
.site-footer{background:var(--blue-900);color:#c3cdf0;margin-top:50px;padding:46px 0 0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding-bottom:34px}
.foot-grid h4{color:#fff;font-size:1rem;margin-bottom:14px}
.foot-grid a{display:block;padding:5px 0;color:#c3cdf0;font-size:.88rem;transition:color .2s}
.foot-grid a:hover{color:#fff}
.foot-grid ul{list-style:none}
.foot-brand strong{font-size:1.3rem;color:#fff;font-weight:800}
.foot-brand p{font-size:.88rem;margin-top:10px;opacity:.85;line-height:1.5}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;font-size:.82rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* Responsive */
@media(max-width:980px){
  .layout{grid-template-columns:1fr}
  .grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .single-inner{padding:28px 24px 36px}
}
@media(max-width:720px){
  .hero{grid-template-columns:1fr}
  .lead{min-height:340px}
  .header-search{display:none}
  .header-main .btn-sub{display:none}
  .burger{display:block;margin-left:auto}
  .grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .topbar nav,.topbar .menu{display:none}
  .lead h3{font-size:1.35rem}
  .single-inner h1{font-size:1.6rem}
  .author-card{flex-direction:column}
}

/* WP core alignment helpers */
.aligncenter{margin-left:auto;margin-right:auto}
.alignleft{float:left;margin:0 20px 14px 0}
.alignright{float:right;margin:0 0 14px 20px}
.wp-caption-text{font-size:.82rem;color:var(--ink-soft);text-align:center}
.sticky,.gallery-caption,.bypostauthor{}
