/*
Theme Name: TwoDayTimes
Theme URI: https://2daytimes.co.uk
Author: 2DayTimes Editorial
Author URI: https://2daytimes.co.uk/about/
Description: A fast, SEO-first news and magazine theme built for 2daytimes.co.uk. Built-in NewsArticle, Organization and Breadcrumb schema, real author bylines, related posts, trust-signal footer, and zero render-blocking bloat. No external fonts, no jQuery, no page builders.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.8
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: twodaytimes
Tags: news, blog, one-column, custom-logo, custom-menu, featured-images, threaded-comments
*/

/* ---------------------------------------------------------------
   Tokens
--------------------------------------------------------------- */
:root{
  --ink:#15181d;
  --ink-soft:#3c434c;
  --muted:#6b7480;
  --paper:#ffffff;
  --paper-warm:#f7f6f3;
  --rule:#e3e4e6;
  --accent:#ba0c2f;          /* masthead red — overridden by Customizer */
  --accent-dark:#8d0a24;
  --serif:Georgia,"Times New Roman",Times,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1140px;
  --maxw-text:720px;
}

/* ---------------------------------------------------------------
   Base
--------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--sans);
  font-size:1.0625rem;
  line-height:1.7;
  color:var(--ink);
  background:var(--paper);
}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);line-height:1.2;color:var(--ink);margin:0 0 .5em}
h1{font-size:clamp(1.75rem,4vw,2.6rem)}
h2{font-size:clamp(1.4rem,3vw,1.9rem)}
h3{font-size:1.25rem}
p{margin:0 0 1.25em}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;
  padding:.6em 1em;z-index:999;
}
.skip-link:focus{left:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---------------------------------------------------------------
   Top bar
--------------------------------------------------------------- */
.topbar{background:var(--ink);color:#cfd3d8;font-size:.8125rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:36px;gap:12px}
.topbar a{color:#fff}
.topbar-social{display:flex;gap:14px;list-style:none;margin:0;padding:0}
.topbar-social a{display:inline-flex;align-items:center}
.topbar-social svg{width:15px;height:15px;fill:currentColor}

/* ---------------------------------------------------------------
   Masthead
--------------------------------------------------------------- */
.masthead{padding:26px 0 18px;text-align:center;background:var(--paper)}
.masthead .custom-logo{margin:0 auto;max-height:72px;width:auto}
.site-title{
  font-family:var(--serif);font-weight:700;letter-spacing:.01em;
  font-size:clamp(2rem,6vw,3.2rem);margin:0;line-height:1.05;
}
.site-title a{color:var(--ink)}
.site-title a:hover{text-decoration:none}
.site-tagline{
  margin:.4em 0 0;color:var(--muted);font-size:.85rem;
  text-transform:uppercase;letter-spacing:.18em;
}

/* double rule — broadsheet signature */
.masthead-rule{border:0;border-top:3px solid var(--ink);margin:14px auto 0;max-width:var(--maxw)}
.masthead-rule + .masthead-rule{border-top:1px solid var(--ink);margin-top:3px}

/* ---------------------------------------------------------------
   Navigation
--------------------------------------------------------------- */
.site-nav{background:var(--paper);border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:50}
.site-nav .wrap{display:flex;align-items:center;justify-content:center}
.nav-toggle{
  display:none;background:none;border:1px solid var(--rule);border-radius:4px;
  padding:.45em .9em;font:inherit;font-size:.9rem;cursor:pointer;margin:8px 0;
}
.nav-menu{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;margin:0;padding:0}
.nav-menu li{position:relative}
.nav-menu a{
  display:block;padding:.85em 1em;color:var(--ink);font-weight:600;font-size:.9rem;
  text-transform:uppercase;letter-spacing:.06em;border-bottom:3px solid transparent;
}
.nav-menu a:hover,
.nav-menu .current-menu-item > a,
.nav-menu .current_page_item > a{border-bottom-color:var(--accent);text-decoration:none}
.nav-menu .sub-menu{
  display:none;position:absolute;left:0;top:100%;background:var(--paper);
  border:1px solid var(--rule);min-width:200px;list-style:none;margin:0;padding:0;z-index:60;
}
.nav-menu li:hover > .sub-menu,
.nav-menu li:focus-within > .sub-menu{display:block}
.nav-menu .sub-menu a{text-transform:none;letter-spacing:0;border-bottom:0;padding:.6em 1em}

@media (max-width:820px){
  .site-nav .wrap{justify-content:flex-start}
  .nav-toggle{display:inline-block}
  .nav-menu{display:none;flex-direction:column;width:100%;padding-bottom:10px}
  .nav-menu.open{display:flex}
  .nav-menu a{border-bottom:0;padding:.6em .4em}
  .nav-menu .sub-menu{display:block;position:static;border:0;padding-left:1em}
}

/* ---------------------------------------------------------------
   Layout sections
--------------------------------------------------------------- */
.site-main{padding:34px 0 56px}
.section-label{
  font-family:var(--sans);font-size:.8rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;color:var(--accent-dark);
  border-bottom:2px solid var(--ink);padding-bottom:.5em;margin:0 0 22px;
  display:flex;align-items:center;gap:.6em;
}

/* Hero: lead story + secondary list */
.hero{display:grid;grid-template-columns:1.6fr 1fr;gap:34px;margin-bottom:44px}
.lead-story .lead-thumb{margin-bottom:14px}
.lead-story .lead-thumb img{width:100%;aspect-ratio:16/9;object-fit:cover}
.lead-story h2{font-size:clamp(1.5rem,3.4vw,2.2rem);margin-bottom:.35em}
.lead-story h2 a{color:var(--ink)}
.lead-excerpt{color:var(--ink-soft)}
.secondary-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.secondary-list li{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--rule)}
.secondary-list li:first-child{padding-top:0}
.secondary-list img{width:96px;height:96px;object-fit:cover;flex:none}
.secondary-list h3{font-size:1.02rem;margin:0 0 .3em}
.secondary-list h3 a{color:var(--ink)}
@media (max-width:820px){.hero{grid-template-columns:1fr}}

/* Card grid */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media (max-width:900px){.card-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.card-grid{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column}
.post-card .card-thumb img{width:100%;aspect-ratio:3/2;object-fit:cover;margin-bottom:12px}
.post-card h3{font-size:1.12rem;margin-bottom:.4em}
.post-card h3 a{color:var(--ink)}
.post-card .card-excerpt{color:var(--ink-soft);font-size:.94rem;margin:0 0 .6em}

/* Meta */
.eyebrow{
  display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.12em;color:var(--accent-dark);margin-bottom:.5em;
}
.eyebrow a{color:inherit}
.byline{font-size:.82rem;color:var(--muted)}
.byline a{color:var(--ink-soft);font-weight:600}
.byline .sep{margin:0 .45em}

/* ---------------------------------------------------------------
   Single article
--------------------------------------------------------------- */
.breadcrumbs{font-size:.8rem;color:var(--muted);margin-bottom:18px}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs .sep{margin:0 .5em;color:var(--rule)}

.article-header{max-width:var(--maxw-text);margin:0 auto 26px}
.article-header h1{margin-bottom:.4em}
.article-header .byline{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.byline-avatar img{border-radius:50%;width:40px;height:40px}

.article-hero{max-width:880px;margin:0 auto 30px}
.article-hero img{width:100%}
.article-hero figcaption{font-size:.8rem;color:var(--muted);margin-top:.5em}

.entry-content{max-width:var(--maxw-text);margin:0 auto;font-size:1.0925rem}
.entry-content h2{margin-top:1.6em}
.entry-content h3{margin-top:1.4em}
.entry-content img{margin:1.5em auto}
.entry-content blockquote{
  border-left:4px solid var(--accent);margin:1.5em 0;padding:.5em 0 .5em 1.2em;
  font-family:var(--serif);font-style:italic;color:var(--ink-soft);
}
.entry-content a{text-decoration:underline;text-underline-offset:2px}
.entry-content table{border-collapse:collapse;width:100%;margin:1.5em 0;font-size:.95rem}
.entry-content th,.entry-content td{border:1px solid var(--rule);padding:.6em .8em;text-align:left}
.entry-content th{background:var(--paper-warm)}
.wp-block-image figcaption{font-size:.8rem;color:var(--muted);text-align:center}

.tag-list{max-width:var(--maxw-text);margin:30px auto 0;display:flex;flex-wrap:wrap;gap:8px}
.tag-list a{
  font-size:.78rem;border:1px solid var(--rule);padding:.35em .8em;border-radius:99px;
  color:var(--ink-soft);
}
.tag-list a:hover{border-color:var(--accent);color:var(--accent-dark);text-decoration:none}

/* Author box — E-E-A-T signal */
.author-box{
  max-width:var(--maxw-text);margin:40px auto 0;background:var(--paper-warm);
  border:1px solid var(--rule);border-top:3px solid var(--accent);
  padding:22px;display:flex;gap:18px;align-items:flex-start;
}
.author-box img{border-radius:50%;width:72px;height:72px;flex:none}
.author-box-name{font-family:var(--sans);font-size:1rem;font-weight:700;margin:0 0 .25em}
.author-box-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.author-box p{margin:.4em 0 0;font-size:.92rem;color:var(--ink-soft)}
.author-box .author-links{margin-top:.5em;font-size:.85rem}
@media (max-width:600px){.author-box{flex-direction:column}}

/* Related posts */
.related-posts{max-width:var(--maxw);margin:52px auto 0}

/* ---------------------------------------------------------------
   Archives, pages, search
--------------------------------------------------------------- */
.archive-header{margin-bottom:30px;border-bottom:2px solid var(--ink);padding-bottom:16px}
.archive-header h1{margin-bottom:.2em}
.archive-description{color:var(--ink-soft);max-width:var(--maxw-text)}

.page-content{max-width:var(--maxw-text);margin:0 auto}

.search-form{display:flex;gap:8px;max-width:480px}
.search-form input[type="search"]{
  flex:1;padding:.6em .9em;border:1px solid var(--rule);border-radius:4px;font:inherit;
}
.search-form button{
  background:var(--accent);color:#fff;border:0;border-radius:4px;
  padding:.6em 1.2em;font:inherit;font-weight:600;cursor:pointer;
}
.search-form button:hover{background:var(--accent-dark)}

/* Pagination */
.pagination{margin-top:44px;text-align:center}
.pagination .nav-links{display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:center}
.pagination .page-numbers{
  padding:.5em .95em;border:1px solid var(--rule);color:var(--ink);font-size:.9rem;
}
.pagination .page-numbers.current{background:var(--ink);color:#fff;border-color:var(--ink)}
.pagination a.page-numbers:hover{border-color:var(--accent);color:var(--accent-dark);text-decoration:none}

/* Comments */
.comments-area{max-width:var(--maxw-text);margin:48px auto 0;border-top:1px solid var(--rule);padding-top:32px}
.comment-list{list-style:none;padding:0}
.comment-list .comment{border-bottom:1px solid var(--rule);padding:18px 0}
.comment-author img{border-radius:50%;margin-right:8px;vertical-align:middle}
.comment-form textarea,.comment-form input[type=text],.comment-form input[type=email],.comment-form input[type=url]{
  width:100%;padding:.6em .8em;border:1px solid var(--rule);border-radius:4px;font:inherit;
}
.comment-form .submit{
  background:var(--accent);color:#fff;border:0;border-radius:4px;
  padding:.65em 1.4em;font:inherit;font-weight:600;cursor:pointer;
}

/* ---------------------------------------------------------------
   Footer — trust signals on every page
--------------------------------------------------------------- */
.site-footer{background:var(--ink);color:#b9bec6;margin-top:64px;font-size:.92rem}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;
  padding:48px 0 36px;
}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr}}
.footer-brand .footer-title{font-family:var(--serif);color:#fff;font-size:1.5rem;margin-bottom:.4em}
.footer-heading{
  color:#fff;font-family:var(--sans);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.14em;margin-bottom:1em;
}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin-bottom:.55em}
.site-footer a{color:#dfe2e7}
.site-footer a:hover{color:#fff}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.14);padding:18px 0;
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;font-size:.8rem;
}

/* 404 */
.error-404{max-width:var(--maxw-text);margin:0 auto;text-align:center;padding:40px 0}
.error-404 .error-code{font-family:var(--serif);font-size:6rem;color:var(--rule);line-height:1;margin:0}

/* Screen reader text (WP standard) */
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);height:1px;width:1px;
  margin:-1px;overflow:hidden;padding:0;position:absolute;word-wrap:normal!important;
}

/* WP core alignment classes */
.alignwide{max-width:880px;margin-left:auto;margin-right:auto}
.alignfull{max-width:100%}
.aligncenter{margin-left:auto;margin-right:auto}
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
@media (max-width:600px){.alignleft,.alignright{float:none;margin:1em auto}}
