/*
Theme Name: Maroc Actu
Theme URI: https://maroc-actu.com
Author: Maroc Actu
Description: Theme editorial inspire du style Le Monde.
Version: 3.0.0
Text Domain: maroc-actu
*/

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --black:#2a2a2a;
  --black-pure:#1a1a1a;
  --green:#006233;
  --green-dark:#004d28;
  --blue:#0055a4;
  --red:#d32f2f;
  --white:#fff;
  --bg:#fff;
  --bg-warm:#faf9f7;
  --gray-100:#f5f5f3;
  --gray-200:#eae8e4;
  --gray-300:#d5d3cf;
  --gray-400:#b0ada6;
  --gray-500:#8a8680;
  --gray-600:#6b6762;
  --gray-700:#4a4743;
  --serif:'Libre Baskerville','Georgia','Times New Roman',serif;
  --sans:'Inter','Helvetica Neue','Arial',sans-serif;
  --mono:'JetBrains Mono',monospace;
  --container:1120px;
  --gap:1px;
}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--black);line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--serif);font-weight:700;line-height:1.2}
::selection{background:var(--green);color:var(--black-pure)}

.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* === TOP BAR === */
.top-bar{border-bottom:1px solid var(--gray-200);font-size:.72rem;color:var(--gray-600);letter-spacing:.02em}
.top-bar .container{display:flex;align-items:center;justify-content:space-between;padding-top:8px;padding-bottom:8px}
.top-bar-left{display:flex;align-items:center;gap:20px}
.top-bar-right{display:flex;align-items:center;gap:16px}
.top-bar a{color:var(--gray-500);transition:color .15s}
.top-bar a:hover{color:var(--black)}
.social-icons{display:flex;gap:10px}
.social-icons svg{width:14px;height:14px;fill:var(--gray-500);transition:fill .15s}
.social-icons a:hover svg{fill:var(--black)}

/* === HEADER === */
.site-header{background:var(--white);padding:20px 0 16px;text-align:center;border-bottom:2px solid var(--black-pure)}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.site-logo{text-align:center;flex:1}
.site-logo .logo-text{font-family:var(--serif);font-size:2.6rem;font-weight:700;letter-spacing:-.03em;color:var(--black-pure);line-height:1}
.site-logo .logo-text .accent{color:var(--green)}
.site-logo .logo-tagline{font-family:var(--sans);font-size:.7rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.15em;margin-top:4px;font-weight:400}
.header-left,.header-right{width:160px}
.header-left{text-align:left}
.header-right{text-align:right}

/* Header search */
.header-search{display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:var(--gray-500);font-size:.78rem;transition:color .15s}
.header-search:hover{color:var(--black)}
.header-search svg{width:16px;height:16px;fill:currentColor}
.search-overlay{display:none;position:fixed;inset:0;background:rgba(255,255,255,.97);z-index:9999;align-items:flex-start;justify-content:center;padding-top:120px}
.search-overlay.active{display:flex}
.search-overlay form{width:100%;max-width:600px;position:relative}
.search-overlay input{width:100%;border:none;border-bottom:2px solid var(--black);padding:16px 0;font-size:1.8rem;font-family:var(--serif);outline:none;background:transparent}
.search-overlay .close-search{position:absolute;right:0;top:50%;transform:translateY(-50%);background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-500)}

/* === NAV === */
.main-nav{background:#26374a;position:sticky;top:0;z-index:1000}
.main-nav .container{display:flex;align-items:center;justify-content:center}
.main-nav ul{display:flex;justify-content:center;gap:0}
.main-nav li{position:relative}
.main-nav a{display:block;padding:11px 15px;font-size:.73rem;font-weight:500;text-transform:none;letter-spacing:.01em;color:rgba(255,255,255,.85);transition:all .15s;position:relative;font-family:var(--sans)}
.main-nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.main-nav .current-menu-item>a,.main-nav .current_page_parent>a{color:#fff;background:rgba(255,255,255,.1)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px}
.menu-toggle svg{width:20px;height:20px;fill:#fff}

/* === LIVE BANNER === */
.live-banner{background:var(--bg-warm);border-bottom:1px solid var(--gray-200);padding:10px 0;overflow:hidden}
.live-banner .container{display:flex;align-items:center;gap:14px}
.live-dot{width:8px;height:8px;background:var(--red);border-radius:50%;flex-shrink:0;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.live-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--red);flex-shrink:0}
.live-text{font-family:var(--serif);font-size:.85rem;color:var(--black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.live-text a:hover{color:var(--blue)}

/* === HERO / UNE === */
.une{padding:28px 0 0;border-bottom:1px solid var(--gray-200)}
.une-grid{display:grid;grid-template-columns:1fr 380px;gap:0;min-height:400px}
.une-main{padding-right:32px;border-right:1px solid var(--gray-200)}
.une-main .une-img{margin-bottom:14px;overflow:hidden}
.une-main .une-img img{width:100%;aspect-ratio:16/9;object-fit:cover}
.une-main .cat-label{font-family:var(--sans);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:8px;display:block}
.une-main h2{font-size:1.85rem;line-height:1.2;margin-bottom:10px}
.une-main h2 a:hover{color:var(--gray-700)}
.une-main .excerpt{font-size:.95rem;color:var(--gray-600);line-height:1.6;margin-bottom:10px}
.une-main .meta{font-size:.72rem;color:var(--gray-400);padding-bottom:24px}
.une-main .meta a{color:var(--gray-500)}
.une-main .meta a:hover{color:var(--black)}

.une-side{padding-left:24px}
.une-side-item{padding:16px 0;border-bottom:1px solid var(--gray-200)}
.une-side-item:first-child{padding-top:0}
.une-side-item:last-child{border-bottom:none}
.une-side-item .cat-label{font-family:var(--sans);font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:5px;display:block}
.une-side-item h3{font-size:1.05rem;line-height:1.3;margin-bottom:4px}
.une-side-item h3 a:hover{color:var(--gray-600)}
.une-side-item .excerpt{font-size:.8rem;color:var(--gray-500);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.une-side-item .meta{font-size:.68rem;color:var(--gray-400);margin-top:4px}

/* === SECTION === */
.section{padding:28px 0;border-bottom:1px solid var(--gray-200)}
.section:last-child{border-bottom:none}
.section-title{font-family:var(--sans);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--black-pure);margin-bottom:20px;display:flex;align-items:center;justify-content:space-between}
.section-title::after{content:'';flex:1;height:1px;background:var(--gray-200);margin-left:16px}
.section-title .more{font-weight:400;font-size:.68rem;letter-spacing:.05em;color:var(--gray-500);margin-left:16px;flex-shrink:0}
.section-title .more::after{content:'';display:none}
.section-title .more:hover{color:var(--blue)}

/* === ARTICLE GRID === */
.articles-4{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.articles-4 .article-item{padding:0 18px;border-right:1px solid var(--gray-200)}
.articles-4 .article-item:first-child{padding-left:0}
.articles-4 .article-item:last-child{border-right:none;padding-right:0}
.article-item .thumb{margin-bottom:10px;overflow:hidden}
.article-item .thumb img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:opacity .2s}
.article-item:hover .thumb img{opacity:.85}
.article-item .cat-label{font-family:var(--sans);font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);margin-bottom:5px;display:block}
.article-item h3{font-size:.95rem;line-height:1.3;margin-bottom:5px}
.article-item h3 a:hover{color:var(--gray-600)}
.article-item .excerpt{font-size:.78rem;color:var(--gray-500);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.article-item .meta{font-size:.65rem;color:var(--gray-400);margin-top:6px}

/* === 2-COL CATEGORY === */
.cat-2col{display:grid;grid-template-columns:1fr 1fr;gap:0}
.cat-2col-main{padding-right:24px;border-right:1px solid var(--gray-200)}
.cat-2col-main .thumb{margin-bottom:12px}
.cat-2col-main .thumb img{width:100%;aspect-ratio:16/9;object-fit:cover}
.cat-2col-main h3{font-size:1.3rem;line-height:1.25;margin-bottom:8px}
.cat-2col-main h3 a:hover{color:var(--gray-600)}
.cat-2col-main .excerpt{font-size:.88rem;color:var(--gray-500);line-height:1.6;margin-bottom:6px}
.cat-2col-main .meta{font-size:.7rem;color:var(--gray-400)}
.cat-2col-side{padding-left:24px}

/* Headline list */
.headline-list .hl-item{padding:12px 0;border-bottom:1px solid var(--gray-200)}
.headline-list .hl-item:first-child{padding-top:0}
.headline-list .hl-item:last-child{border-bottom:none}
.headline-list h4{font-size:.92rem;line-height:1.3;margin-bottom:3px}
.headline-list h4 a:hover{color:var(--gray-600)}
.headline-list .excerpt{font-size:.78rem;color:var(--gray-500);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.headline-list .meta{font-size:.65rem;color:var(--gray-400);margin-top:3px}

/* === CONTENT AREA (with sidebar) === */
.content-wrap{display:grid;grid-template-columns:1fr 300px;gap:0;padding:28px 0}
.main-content{padding-right:28px;border-right:1px solid var(--gray-200)}

/* === SIDEBAR === */
.sidebar{padding-left:24px}
.sidebar .widget{margin-bottom:28px}
.sidebar .widget-title{font-family:var(--sans);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--black-pure);padding-bottom:10px;margin-bottom:14px;border-bottom:2px solid var(--black-pure);display:block}
.sidebar .hl-item{padding:10px 0;border-bottom:1px solid var(--gray-200)}
.sidebar .hl-item:last-child{border-bottom:none}
.sidebar .hl-item h4{font-size:.85rem}
.sidebar .hl-item .meta{font-size:.62rem}
.sidebar .hl-number{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--green);color:var(--black-pure);font-family:var(--sans);font-size:.7rem;font-weight:800;border-radius:2px;margin-right:8px;flex-shrink:0}

/* Newsletter */
.newsletter-box{background:var(--bg-warm);border:1px solid var(--gray-200);padding:20px;margin-bottom:28px}
.newsletter-box h3{font-family:var(--serif);font-size:1rem;margin-bottom:4px}
.newsletter-box p{font-size:.78rem;color:var(--gray-500);margin-bottom:12px;line-height:1.5}
.newsletter-box input[type="email"]{width:100%;border:1px solid var(--gray-300);padding:10px 12px;font-size:.82rem;margin-bottom:8px;font-family:var(--sans)}
.newsletter-box input:focus{outline:none;border-color:var(--black)}
.newsletter-box button{width:100%;background:var(--black-pure);color:var(--white);border:none;padding:10px;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;font-family:var(--sans);transition:background .15s}
.newsletter-box button:hover{background:var(--green);color:var(--black-pure)}

/* Categories list */
.cat-list-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--gray-200);font-size:.82rem}
.cat-list-item:last-child{border-bottom:none}
.cat-list-item a{color:var(--black)}
.cat-list-item a:hover{color:var(--blue)}
.cat-list-item .count{font-size:.7rem;color:var(--gray-400);font-family:var(--sans)}

/* === SEARCH FORM === */
.search-form{display:flex;border:1px solid var(--gray-300)}
.search-form input[type="search"]{flex:1;border:none;padding:8px 12px;font-size:.82rem;font-family:var(--sans);outline:none}
.search-form button{background:var(--black-pure);color:var(--white);border:none;padding:8px 14px;cursor:pointer;font-size:.78rem;font-weight:600;font-family:var(--sans)}

/* === CARD GRID (archive/search) === */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.card-grid .article-item{padding:0 18px 24px;border-right:1px solid var(--gray-200);margin-bottom:24px;border-bottom:1px solid var(--gray-200)}
.card-grid .article-item:nth-child(3n){border-right:none;padding-right:0}
.card-grid .article-item:nth-child(3n+1){padding-left:0}

/* === SINGLE POST === */
.single-post{padding:0}
.single-header{max-width:720px;margin:0 auto;padding:32px 0 24px;text-align:center}
.single-header .cat-label{font-family:var(--sans);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--blue);margin-bottom:12px;display:block}
.single-header h1{font-size:2.2rem;line-height:1.2;margin-bottom:14px}
.single-header .standfirst{font-size:1.1rem;color:var(--gray-600);line-height:1.6;font-family:var(--serif);font-style:italic}
.post-meta-bar{max-width:720px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:14px 0;border-top:1px solid var(--gray-200);border-bottom:1px solid var(--gray-200);font-size:.75rem;color:var(--gray-500)}
.post-meta-bar .author-name{font-weight:600;color:var(--black)}
.post-meta-bar .sep{color:var(--gray-300)}
.share-buttons{margin-left:auto;display:flex;gap:8px}
.share-buttons a{width:28px;height:28px;border:1px solid var(--gray-300);display:flex;align-items:center;justify-content:center;transition:all .15s}
.share-buttons a:hover{border-color:var(--black);background:var(--black)}
.share-buttons a:hover svg{fill:var(--white)}
.share-buttons svg{width:13px;height:13px;fill:var(--gray-500)}

.featured-img{max-width:860px;margin:24px auto;overflow:hidden}
.featured-img img{width:100%}
.featured-img figcaption,.featured-img .wp-caption-text{font-size:.72rem;color:var(--gray-500);padding:8px 0;border-bottom:1px solid var(--gray-200);font-family:var(--sans)}

.post-content{max-width:680px;margin:0 auto;padding:24px 0;font-family:var(--serif);font-size:1.05rem;line-height:1.85;color:var(--black)}
.post-content p{margin-bottom:1.3rem}
.post-content h2{font-size:1.5rem;margin:2.5rem 0 1rem;font-family:var(--serif)}
.post-content h3{font-size:1.2rem;margin:2rem 0 .75rem}
.post-content blockquote{border-left:3px solid var(--green);padding:4px 0 4px 24px;margin:2rem 0;font-style:italic;color:var(--gray-600)}
.post-content ul,.post-content ol{margin:1rem 0 1.5rem 1.5rem}
.post-content li{margin-bottom:.5rem}
.post-content ol{list-style:decimal}
.post-content ul{list-style:disc}
.post-content a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}
.post-content img{margin:1.5rem 0}
.post-content figure{margin:2rem 0}
.post-content figcaption{font-family:var(--sans);font-size:.75rem;color:var(--gray-500);margin-top:6px}

/* Breadcrumb */
.breadcrumb{font-family:var(--sans);font-size:.7rem;color:var(--gray-400);padding:12px 0;display:flex;align-items:center;gap:6px}
.breadcrumb a{color:var(--gray-500)}
.breadcrumb a:hover{color:var(--blue)}

/* Tags */
.post-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:24px;padding-top:20px;border-top:1px solid var(--gray-200);max-width:680px;margin-left:auto;margin-right:auto}
.post-tags a{border:1px solid var(--gray-300);padding:4px 14px;font-family:var(--sans);font-size:.7rem;color:var(--gray-600);transition:all .15s;letter-spacing:.02em}
.post-tags a:hover{background:var(--black-pure);color:var(--white);border-color:var(--black-pure)}

/* Related */
.related-posts{max-width:var(--container);margin:32px auto 0;padding:28px 20px 0;border-top:2px solid var(--black-pure)}

/* === ARCHIVE === */
.archive-header{padding:28px 0;border-bottom:1px solid var(--gray-200)}
.archive-header h1{font-size:1.8rem;font-family:var(--serif)}
.archive-header .desc{font-size:.88rem;color:var(--gray-500);margin-top:6px;font-family:var(--serif)}

/* === PAGINATION === */
.pagination{display:flex;justify-content:center;gap:4px;padding:28px 0}
.pagination a,.pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;font-family:var(--sans);font-size:.82rem;font-weight:600;transition:all .15s;border:1px solid var(--gray-300)}
.pagination a:hover{background:var(--black-pure);color:var(--white);border-color:var(--black-pure)}
.pagination .current{background:var(--black-pure);color:var(--white);border-color:var(--black-pure)}

/* === COMMENTS === */
.comments-area{max-width:680px;margin:28px auto 0;padding-top:24px;border-top:1px solid var(--gray-200)}
.comments-area h2{font-size:1.1rem;margin-bottom:16px}
.comment-list .comment{padding:16px 0;border-bottom:1px solid var(--gray-200)}
.comment-author{font-weight:700;font-size:.85rem}
.comment-meta{font-size:.7rem;color:var(--gray-400);margin-bottom:8px}
.comment-respond{margin-top:24px}
.comment-respond .comment-form input,.comment-respond .comment-form textarea{width:100%;border:1px solid var(--gray-300);padding:10px 14px;font-size:.88rem;margin-bottom:10px;font-family:var(--sans)}
.comment-respond .comment-form input:focus,.comment-respond .comment-form textarea:focus{outline:none;border-color:var(--black)}
.comment-respond .submit{background:var(--black-pure);color:var(--white);border:none;padding:12px 28px;font-size:.82rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;font-family:var(--sans)}

/* === FOOTER === */
.site-footer{border-top:3px solid var(--black-pure);margin-top:40px}
.footer-main{padding:36px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px}
.footer-col h3{font-family:var(--sans);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;color:var(--black-pure)}
.footer-col p{font-size:.8rem;line-height:1.7;color:var(--gray-600)}
.footer-col ul li{margin-bottom:6px}
.footer-col a{font-size:.8rem;color:var(--gray-600);transition:color .15s}
.footer-col a:hover{color:var(--blue)}
.footer-social{display:flex;gap:10px;margin-top:14px}
.footer-social a{width:32px;height:32px;border:1px solid var(--gray-300);display:flex;align-items:center;justify-content:center;transition:all .15s}
.footer-social a:hover{background:var(--black-pure);border-color:var(--black-pure)}
.footer-social a:hover svg{fill:var(--white)}
.footer-social svg{width:14px;height:14px;fill:var(--gray-500)}
.footer-bottom{border-top:1px solid var(--gray-200);padding:14px 0;text-align:center}
.footer-bottom p{font-size:.7rem;color:var(--gray-500);font-family:var(--sans)}
.footer-bottom a{color:var(--blue)}

/* === 404 === */
.error-404{text-align:center;padding:80px 20px}
.error-404 h1{font-size:6rem;color:var(--gray-300);font-family:var(--serif);line-height:1}
.error-404 h2{font-size:1.3rem;font-family:var(--serif);margin:12px 0 8px}
.error-404 p{color:var(--gray-500);margin-bottom:24px}
.error-404 .btn{display:inline-block;background:var(--black-pure);color:var(--white);padding:12px 32px;font-family:var(--sans);font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}

/* === RESPONSIVE === */
@media(max-width:1024px){
  .une-grid{grid-template-columns:1fr 320px}
  .articles-4{grid-template-columns:repeat(2,1fr)}
  .articles-4 .article-item:nth-child(2n){border-right:none;padding-right:0}
  .articles-4 .article-item:nth-child(2n+1){padding-left:0}
  .articles-4 .article-item:nth-child(n+3){border-top:1px solid var(--gray-200);padding-top:18px;margin-top:18px}
  .content-wrap{grid-template-columns:1fr 260px}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid .article-item:nth-child(2n){border-right:none;padding-right:0}
  .card-grid .article-item:nth-child(2n+1){padding-left:0}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .top-bar{display:none}
  .site-logo .logo-text{font-size:2rem}
  .header-left,.header-right{display:none}
  .une-grid{grid-template-columns:1fr}
  .une-main{padding-right:0;border-right:none;padding-bottom:20px;border-bottom:1px solid var(--gray-200)}
  .une-side{padding-left:0;padding-top:16px}
  .articles-4{grid-template-columns:1fr 1fr}
  .cat-2col{grid-template-columns:1fr}
  .cat-2col-main{padding-right:0;border-right:none;padding-bottom:18px;border-bottom:1px solid var(--gray-200);margin-bottom:14px}
  .cat-2col-side{padding-left:0}
  .content-wrap{grid-template-columns:1fr}
  .main-content{padding-right:0;border-right:none;padding-bottom:24px;border-bottom:1px solid var(--gray-200)}
  .sidebar{padding-left:0;padding-top:20px}
  .footer-grid{grid-template-columns:1fr}
  .main-nav ul{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:#26374a;box-shadow:0 4px 12px rgba(0,0,0,.2);z-index:999}
  .main-nav ul.active{display:flex}
  .main-nav a{text-align:left;border-bottom:1px solid rgba(255,255,255,.08);padding:12px 20px}
  .menu-toggle{display:block}
  .single-header h1{font-size:1.6rem}
  .post-meta-bar{flex-wrap:wrap;gap:8px}
  .share-buttons{margin-left:0;width:100%;padding-top:8px;border-top:1px solid var(--gray-200)}
}
@media(max-width:480px){
  .articles-4,.card-grid{grid-template-columns:1fr}
  .articles-4 .article-item,.card-grid .article-item{padding:0 0 16px;border-right:none;border-bottom:1px solid var(--gray-200);margin-bottom:16px}
  .site-logo .logo-text{font-size:1.6rem}
  .hero-side{grid-template-columns:1fr}
}
