/*
Theme Name: Dokima Blog
Theme URI: https://dokima.ai
Author: Dokima.AI
Author URI: https://dokima.ai
Description: Theme WordPress officiel du blog Dokima.AI. Construit sur le design system v2 (warm-brown) : Poppins + Hanken Grotesk + JetBrains Mono, palette creme / brun / orange, degrade signature et texture dot-grid. Les tokens vivent dans assets/css/tokens/.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.7
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: dokima
Tags: blog, two-columns, custom-logo, custom-menu, featured-images, translation-ready
*/

/* =========================================================
   Le design system (tokens) est charge AVANT cette feuille
   via functions.php : colors -> typography -> spacing -> base.
   Ici : uniquement les composants du blog, batis sur les tokens.
   ========================================================= */

/* Variables de layout propres au blog */
:root {
  --container: 1160px;
  --container-narrow: 760px;
  --header-h: 76px;
}

/* =========================================================
   1. Base complementaire (base.css gere body/h1-h3/utilities)
   ========================================================= */
h1, h2, h3, h4, h5, h6 { margin: 0 0 0.5em; }
h4, h5, h6 { font-family: var(--font-display); font-weight: var(--weight-semibold); color: var(--heading); letter-spacing: var(--tracking-display); line-height: var(--leading-tight); }
h1 { font-size: var(--text-5xl); }
h2 { font-size: var(--text-3xl); }
h3 { font-size: var(--text-2xl); }
h4 { font-size: var(--text-xl); }

p { margin: 0 0 1.1em; }
a { color: var(--primary); text-decoration: none; transition: color .15s ease; }
a:hover { color: var(--dk-orange-deep); }
img { max-width: 100%; height: auto; display: block; }
ul, ol { padding-left: 1.4em; }

body { line-height: var(--leading-relaxed); }

blockquote {
  margin: 1.8em 0; padding: var(--space-3) var(--space-6);
  border-left: 3px solid var(--primary);
  background: var(--secondary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  color: var(--heading); font-style: italic;
}

code, pre { font-family: var(--font-mono); font-size: 0.9em; }
code { background: var(--dk-input); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 0.12em 0.4em; color: var(--dk-brown); }
pre { background: var(--dk-brown-deep); color: #f1e9df; padding: var(--space-5) var(--space-6); border-radius: var(--radius-lg); overflow-x: auto; line-height: 1.55; }
pre code { background: none; border: none; padding: 0; color: inherit; }

hr { border: none; border-top: 1px solid var(--border); margin: 2.5em 0; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--space-6); }

.skip-link { position: absolute; left: -9999px; top: 0; z-index: 1000; background: var(--primary); color: #fff; padding: 10px 16px; border-radius: var(--radius-md); }
.skip-link:focus { left: 12px; top: 12px; }
.screen-reader-text { position: absolute !important; width: 1px; height: 1px; overflow: hidden; clip: rect(1px,1px,1px,1px); white-space: nowrap; }

/* =========================================================
   2. Boutons
   ========================================================= */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-semibold);
  line-height: 1; cursor: pointer; white-space: nowrap;
  padding: 13px 22px; border-radius: var(--radius-md);
  border: 1px solid transparent; transition: transform .15s ease, box-shadow .15s ease, filter .15s ease, background .15s ease;
}
.btn-primary { background-image: var(--gradient-orange); color: #fff; box-shadow: var(--shadow-xs); }
.btn-primary:hover { color: #fff; filter: saturate(1.05) brightness(1.03); box-shadow: var(--shadow-glow); transform: translateY(-1px); }
.btn-ghost { background: var(--card); color: var(--heading); border-color: var(--border-strong); }
.btn-ghost:hover { background: var(--secondary); color: var(--heading); }
.btn-dark { background: var(--dk-brown-deep); color: #fff; }
.btn-dark:hover { background: var(--dk-brown); color: #fff; }
.btn-light { background: var(--dk-cream); color: var(--dk-brown-deep); }
.btn-light:hover { background: #fff; color: var(--dk-brown-deep); }

/* =========================================================
   3. Header / navigation
   ========================================================= */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(252, 250, 247, 0.82);
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; height: var(--header-h); }
.site-branding { display: flex; align-items: center; }
.site-branding img, .custom-logo { height: 30px; width: auto; }

.main-nav ul { display: flex; align-items: center; gap: var(--space-8); margin: 0; padding: 0; list-style: none; }
.main-nav a { color: var(--dk-ink-soft); font-size: var(--text-sm); font-weight: var(--weight-medium); }
.main-nav a:hover { color: var(--heading); }
.main-nav .current-menu-item > a, .main-nav .current_page_item > a { color: var(--heading); }

.header-actions { display: flex; align-items: center; gap: var(--space-4); }
.header-actions .login-link { color: var(--dk-ink-soft); font-weight: var(--weight-medium); font-size: var(--text-sm); }
.header-actions .login-link:hover { color: var(--heading); }

.nav-toggle { display: none; background: none; border: none; cursor: pointer; padding: 8px; color: var(--heading); }
.nav-toggle svg { width: 24px; height: 24px; }

/* =========================================================
   4. Hero / page header
   ========================================================= */
.page-hero {
  position: relative; overflow: hidden;
  background: var(--secondary);
  border-bottom: 1px solid var(--border);
  padding: var(--space-16) 0 var(--space-12);
  text-align: center;
}
.page-hero .dk-dotgrid-layer { position: absolute; inset: 0; opacity: 0.6; pointer-events: none;
  background-image: radial-gradient(var(--dk-dot) 1.4px, transparent 1.4px); background-size: 24px 24px;
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 0%, #000 40%, transparent 75%);
  mask-image: radial-gradient(ellipse 70% 80% at 50% 0%, #000 40%, transparent 75%); }
.page-hero > .container { position: relative; z-index: 1; }
.page-hero .eyebrow {
  display: inline-block; font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  color: var(--dk-orange-deep); margin-bottom: var(--space-4);
}
.page-hero h1 { font-size: var(--text-6xl); margin-bottom: var(--space-3); }
.page-hero p { font-size: var(--text-lg); color: var(--dk-ink-soft); max-width: 620px; margin: 0 auto; }

/* =========================================================
   5. Layout (contenu + sidebar)
   ========================================================= */
.site-main { padding: var(--space-16) 0 var(--space-24); }
.content-area { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: var(--space-16); align-items: start; }
.content-area.full { grid-template-columns: minmax(0, 1fr); }

/* =========================================================
   6. Cartes d'articles
   ========================================================= */
.post-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-8); }
.post-card {
  display: flex; flex-direction: column;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-card); overflow: hidden;
  box-shadow: var(--shadow-xs);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.post-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--border-strong); }
.post-card .thumb { display: block; aspect-ratio: 16 / 9; background: var(--secondary); overflow: hidden; }
.post-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s ease; }
.post-card:hover .thumb img { transform: scale(1.03); }
.post-card .card-body { padding: var(--space-5) var(--space-6) var(--space-6); display: flex; flex-direction: column; flex: 1; }
.post-card .cat-badge-wrap { margin-bottom: var(--space-3); }
.post-card h2, .post-card h3 { font-size: var(--text-xl); margin-bottom: var(--space-2); line-height: var(--leading-tight); }
.post-card h2 a, .post-card h3 a { color: var(--heading); }
.post-card h2 a:hover, .post-card h3 a:hover { color: var(--primary); }
.post-card .excerpt { color: var(--dk-ink-soft); font-size: var(--text-sm); margin-bottom: var(--space-5); flex: 1; }
.post-card .card-meta { display: flex; align-items: center; gap: var(--space-2); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--muted-foreground); margin-top: auto; }
.card-meta .dot { width: 3px; height: 3px; border-radius: 50%; background: var(--muted-foreground); }

/* Badge categorie */
.cat-badge {
  display: inline-block; font-family: var(--font-mono); font-size: var(--text-xs); font-weight: var(--weight-medium);
  text-transform: uppercase; letter-spacing: var(--tracking-wide);
  color: var(--dk-orange-deep); background: rgba(255, 90, 9, 0.09);
  padding: 4px 10px; border-radius: var(--radius-pill);
}
.cat-badge:hover { background-image: var(--gradient-orange); color: #fff; }

/* =========================================================
   7. Article seul
   ========================================================= */
.single-article { max-width: var(--container-narrow); margin: 0 auto; }
.single-article .article-header { text-align: center; margin-bottom: var(--space-10); }
.single-article .article-header h1 { font-size: var(--text-5xl); margin: var(--space-4) 0 var(--space-5); }
.single-article .article-meta { display: flex; align-items: center; justify-content: center; gap: var(--space-3); flex-wrap: wrap; font-family: var(--font-mono); color: var(--muted-foreground); font-size: var(--text-sm); }
.single-article .article-meta .author { display: flex; align-items: center; gap: 8px; color: var(--dk-ink-soft); font-weight: var(--weight-medium); font-family: var(--font-sans); }
.single-article .article-meta .author img { width: 28px; height: 28px; border-radius: 50%; }
.single-article .featured-image { margin: 0 -48px var(--space-10); border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-md); }
.single-article .featured-image img { width: 100%; }

.entry-content { font-size: var(--text-lg); color: var(--foreground); }
.entry-content h2 { font-size: var(--text-3xl); margin-top: 1.6em; }
.entry-content h3 { font-size: var(--text-2xl); margin-top: 1.4em; }
.entry-content img { border-radius: var(--radius-lg); margin: 1.6em 0; }
.entry-content figcaption { text-align: center; font-size: var(--text-sm); color: var(--muted-foreground); margin-top: 8px; }
.entry-content > *:first-child { margin-top: 0; }
.entry-content a { text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255,90,9,0.4); }
.entry-content table { width: 100%; border-collapse: collapse; margin: 1.6em 0; font-size: var(--text-sm); }
.entry-content th, .entry-content td { border: 1px solid var(--border); padding: 10px 14px; text-align: left; }
.entry-content th { background: var(--secondary); color: var(--heading); font-weight: var(--weight-semibold); }

.article-footer { margin-top: var(--space-12); padding-top: var(--space-8); border-top: 1px solid var(--border); }
.tag-list { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: var(--space-6); }
.tag-list a { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--dk-ink-soft); background: var(--secondary); border: 1px solid var(--border); padding: 5px 12px; border-radius: var(--radius-pill); }
.tag-list a:hover { background: rgba(255,90,9,0.09); color: var(--dk-orange-deep); border-color: var(--dk-amber); }

.author-box { display: flex; gap: var(--space-5); align-items: flex-start; background: var(--secondary); border: 1px solid var(--border); border-radius: var(--radius-card); padding: var(--space-6); margin-top: var(--space-8); }
.author-box img { width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0; }
.author-box .author-name { font-family: var(--font-display); font-weight: var(--weight-bold); color: var(--heading); margin-bottom: 4px; }
.author-box .author-bio { font-size: var(--text-sm); margin: 0; color: var(--dk-ink-soft); }

.post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); margin-top: var(--space-10); }
.post-nav a { display: block; padding: var(--space-5) var(--space-6); border: 1px solid var(--border); border-radius: var(--radius-card); background: var(--card); transition: all .15s ease; }
.post-nav a:hover { border-color: var(--dk-amber); box-shadow: var(--shadow-sm); }
.post-nav .label { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--muted-foreground); display: block; margin-bottom: 6px; }
.post-nav .title { color: var(--heading); font-weight: var(--weight-semibold); font-size: var(--text-sm); }
.post-nav .next { text-align: right; }

/* =========================================================
   8. Sidebar / widgets
   ========================================================= */
.sidebar .widget { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-card); padding: var(--space-5) var(--space-6); margin-bottom: var(--space-6); box-shadow: var(--shadow-xs); }
.sidebar .widget-title { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--muted-foreground); margin-bottom: var(--space-4); }
.sidebar ul { list-style: none; padding: 0; margin: 0; }
.sidebar li { padding: 8px 0; border-bottom: 1px solid var(--border); }
.sidebar li:last-child { border-bottom: none; }
.sidebar a { color: var(--dk-ink-soft); }
.sidebar a:hover { color: var(--primary); }

.cta-widget { background: var(--dk-brown-deep) !important; border: none !important; color: #f1e9df; text-align: center; }
.cta-widget h4 { color: #fff; font-size: var(--text-lg); }
.cta-widget p { color: #d9c8b6; font-size: var(--text-sm); }
.cta-widget .btn { width: 100%; justify-content: center; margin-top: 8px; }

.search-form { display: flex; gap: 8px; }
.search-form input[type="search"] { flex: 1; min-width: 0; padding: 11px 14px; font-family: var(--font-sans); font-size: var(--text-sm); border: 1px solid var(--border-strong); border-radius: var(--radius-md); color: var(--foreground); background: var(--card); }
.search-form input[type="search"]:focus { outline: none; border-color: var(--primary); box-shadow: var(--shadow-glow); }
.search-form button { background-image: var(--gradient-orange); color: #fff; border: none; border-radius: var(--radius-md); padding: 0 18px; cursor: pointer; font-weight: var(--weight-semibold); }

/* =========================================================
   9. Pagination
   ========================================================= */
.pagination { display: flex; justify-content: center; gap: 8px; margin-top: var(--space-12); flex-wrap: wrap; }
.pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 44px; height: 44px; padding: 0 12px; border: 1px solid var(--border); border-radius: var(--radius-md); color: var(--dk-ink-soft); font-family: var(--font-mono); font-weight: var(--weight-medium); background: var(--card); }
.pagination .page-numbers:hover { border-color: var(--dk-amber); color: var(--dk-orange-deep); }
.pagination .page-numbers.current { background-image: var(--gradient-orange); color: #fff; border-color: transparent; }

/* =========================================================
   10. Bande CTA bas de page
   ========================================================= */
.cta-band { position: relative; overflow: hidden; background: var(--dk-brown-deep); color: #f1e9df; padding: var(--space-24) 0; text-align: center; }
.cta-band::after { content: ""; position: absolute; inset: 0; opacity: 0.10; background-image: radial-gradient(#fff 1.4px, transparent 1.4px); background-size: 26px 26px; pointer-events: none; }
.cta-band > .container { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; font-size: var(--text-4xl); margin-bottom: var(--space-3); }
.cta-band p { color: #d9c8b6; font-size: var(--text-lg); max-width: 560px; margin: 0 auto var(--space-6); }

/* =========================================================
   11. Footer
   ========================================================= */
.site-footer { background: var(--card); border-top: 1px solid var(--border); padding: var(--space-16) 0 var(--space-8); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--space-10); }
.footer-brand img { height: 28px; margin-bottom: var(--space-4); }
.footer-brand .tagline { color: var(--muted-foreground); font-size: var(--text-sm); max-width: 260px; }
.footer-col h5 { font-family: var(--font-mono); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: var(--tracking-wide); color: var(--muted-foreground); margin-bottom: var(--space-4); font-weight: var(--weight-medium); }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { margin-bottom: 10px; }
.footer-col a { color: var(--dk-ink-soft); font-size: var(--text-sm); }
.footer-col a:hover { color: var(--primary); }
.footer-bottom { margin-top: var(--space-12); padding-top: var(--space-6); border-top: 1px solid var(--border); text-align: center; color: var(--muted-foreground); font-family: var(--font-mono); font-size: var(--text-xs); }

/* =========================================================
   12. Etats / commentaires
   ========================================================= */
.no-results { text-align: center; padding: var(--space-16) var(--space-5); }
.no-results h2 { margin-bottom: var(--space-2); }
.no-results p { color: var(--dk-ink-soft); }

.comments-area { max-width: var(--container-narrow); margin: var(--space-16) auto 0; }
.comment-list { list-style: none; padding: 0; }
.comment-list li { border-bottom: 1px solid var(--border); padding: var(--space-5) 0; }
.comment-author { font-weight: var(--weight-semibold); color: var(--heading); }
.comment-meta { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--muted-foreground); margin-bottom: 8px; }
.comment-respond { margin-top: var(--space-8); }
.comment-form label { display: block; font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--heading); margin-bottom: 6px; }
.comment-form input, .comment-form textarea { width: 100%; padding: 11px 14px; font-family: var(--font-sans); font-size: var(--text-sm); border: 1px solid var(--border-strong); border-radius: var(--radius-md); margin-bottom: var(--space-4); background: var(--card); color: var(--foreground); }
.comment-form input:focus, .comment-form textarea:focus { outline: none; border-color: var(--primary); box-shadow: var(--shadow-glow); }

/* =========================================================
   13. Responsive
   ========================================================= */
@media (max-width: 980px) {
  .content-area { grid-template-columns: 1fr; gap: var(--space-10); }
  .sidebar { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--space-6); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); }
  .footer-brand { grid-column: 1 / -1; }
}
@media (max-width: 760px) {
  h1 { font-size: var(--text-4xl); }
  .page-hero h1 { font-size: var(--text-5xl); }
  .single-article .article-header h1 { font-size: var(--text-4xl); }
  .single-article .featured-image { margin: 0 0 var(--space-8); }
  .post-grid { grid-template-columns: 1fr; }
  .post-nav { grid-template-columns: 1fr; }
  .sidebar { grid-template-columns: 1fr; }
  .nav-toggle { display: inline-flex; }
  .main-nav {
    position: fixed; inset: var(--header-h) 0 auto 0;
    background: var(--card); border-bottom: 1px solid var(--border);
    box-shadow: var(--shadow-lg); padding: 8px 0;
    transform: translateY(-12px); opacity: 0; pointer-events: none; transition: all .2s ease;
  }
  .main-nav.open { transform: translateY(0); opacity: 1; pointer-events: auto; }
  .main-nav ul { flex-direction: column; align-items: stretch; gap: 0; width: 100%; }
  .main-nav li { width: 100%; }
  .main-nav a { display: block; padding: 13px 24px; }
  .header-actions .login-link { display: none; }
}
@media (max-width: 480px) {
  .container { padding: 0 var(--space-5); }
  .header-actions .btn { padding: 10px 14px; }
  .footer-grid { grid-template-columns: 1fr; }
}
