/*
Theme Name: KomokoZik TV
Theme URI: https://komokozik.tv
Author: KomokoZik TV
Author URI: https://komokozik.tv
Description: Thème WordPress pour KomokoZik TV — chaîne IPTV H24 dédiée à la musique et à la culture pop des Comores. Lecteur live persistant (HLS), grille des programmes, actualités musicales et commentaires des visiteurs. Couleurs du drapeau comorien.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
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: komokozik-tv
Tags: music, television, streaming, comores, dark, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* =========================================================================
   1. TOKENS — palette drapeau comorien + typographies du brief
   ========================================================================= */
:root{
  --kz-green:#009A44;
  --kz-yellow:#FFD100;
  --kz-red:#D62828;
  --kz-white:#FFFFFF;
  --kz-blue:#0066CC;
  --kz-black:#111111;

  /* surfaces dérivées (ambiance broadcast sombre) */
  --kz-bg:#0b0b0e;
  --kz-bg-2:#0f0f13;
  --kz-surface:#16161c;
  --kz-surface-2:#1e1e26;
  --kz-line:#2a2a33;
  --kz-text:#f4f4f7;
  --kz-muted:#9a9aa6;

  --kz-radius:14px;
  --kz-radius-lg:22px;
  --kz-maxw:1200px;
  --kz-shadow:0 18px 50px rgba(0,0,0,.45);

  /* typographies */
  --kz-display:"Bebas Neue", Impact, sans-serif;   /* titres */
  --kz-sub:"Montserrat", system-ui, sans-serif;     /* sous-titres (700) */
  --kz-body:"Poppins", system-ui, sans-serif;       /* texte */
  --kz-mono:"Orbitron", monospace;                  /* horloge / data */

  /* dégradé signature = drapeau */
  --kz-flag:linear-gradient(90deg,var(--kz-green) 0 25%,var(--kz-yellow) 25% 50%,var(--kz-red) 50% 75%,var(--kz-blue) 75% 100%);
}

/* =========================================================================
   2. BASE
   ========================================================================= */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,154,68,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(214,40,40,.08), transparent 55%),
    var(--kz-bg);
  color:var(--kz-text);
  font-family:var(--kz-body);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:var(--kz-yellow);text-decoration:none;transition:color .15s ease}
a:hover{color:#ffe14d}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--kz-display);font-weight:400;letter-spacing:.02em;line-height:.98;margin:0 0 .35em}
h1{font-size:clamp(2.6rem,6vw,5rem)}
h2{font-size:clamp(2rem,4.2vw,3.4rem)}
h3{font-size:clamp(1.4rem,2.6vw,2rem)}
p{margin:0 0 1rem}
.kz-container{width:min(100% - 2.4rem, var(--kz-maxw));margin-inline:auto}
.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden}

/* étiquette / eyebrow en Montserrat */
.kz-eyebrow{
  font-family:var(--kz-sub);font-weight:800;text-transform:uppercase;
  letter-spacing:.22em;font-size:.74rem;color:var(--kz-muted);
  display:inline-flex;align-items:center;gap:.55rem;margin-bottom:.9rem;
}
.kz-eyebrow::before{content:"";width:26px;height:3px;border-radius:3px;background:var(--kz-flag)}

/* bandeau drapeau réutilisable */
.kz-flagbar{height:4px;width:100%;background:var(--kz-flag);border:0}

/* boutons */
.kz-btn{
  --b:var(--kz-yellow);
  display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;
  font-family:var(--kz-sub);font-weight:800;text-transform:uppercase;
  letter-spacing:.06em;font-size:.86rem;
  padding:.85rem 1.5rem;border-radius:999px;border:0;
  background:var(--b);color:var(--kz-black);
  transition:transform .12s ease, box-shadow .2s ease, filter .2s ease;
}
.kz-btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,209,0,.25);filter:brightness(1.03)}
.kz-btn--ghost{background:transparent;color:var(--kz-text);border:1.5px solid var(--kz-line)}
.kz-btn--ghost:hover{border-color:var(--kz-yellow);color:var(--kz-yellow);box-shadow:none}
.kz-btn--red{--b:var(--kz-red);color:#fff}
.kz-btn--red:hover{box-shadow:0 10px 24px rgba(214,40,40,.3)}

/* =========================================================================
   3. HEADER
   ========================================================================= */
.kz-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(11,11,14,.78);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--kz-line);
}
.kz-header__bar{display:flex;align-items:center;gap:1.2rem;padding:.7rem 0;min-height:72px}
.kz-brand{display:flex;align-items:center;gap:.7rem;margin-right:auto}
.kz-brand img{height:52px;width:auto}
.kz-brand .custom-logo{height:52px}
.kz-brand__name{font-family:var(--kz-display);font-size:1.7rem;line-height:1;letter-spacing:.02em}
.kz-brand__name b{color:var(--kz-green)}
.kz-brand__name span{color:var(--kz-yellow)}
.kz-brand__name em{color:var(--kz-red);font-style:normal}

/* navigation */
.kz-nav{display:flex;align-items:center;gap:.3rem}
.kz-nav ul{list-style:none;display:flex;gap:.2rem;margin:0;padding:0}
.kz-nav a{
  font-family:var(--kz-sub);font-weight:700;text-transform:uppercase;
  letter-spacing:.06em;font-size:.82rem;color:var(--kz-text);
  padding:.55rem .85rem;border-radius:8px;display:block;
}
.kz-nav a:hover,.kz-nav .current-menu-item>a{color:var(--kz-yellow);background:rgba(255,255,255,.04)}

/* horloge + statut antenne */
.kz-status{display:flex;align-items:center;gap:.9rem;padding-left:.6rem;border-left:1px solid var(--kz-line)}
.kz-clock{
  font-family:var(--kz-mono);font-weight:700;font-size:1.05rem;
  color:var(--kz-text);letter-spacing:.06em;font-variant-numeric:tabular-nums;
}
.kz-onair{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--kz-mono);font-weight:700;font-size:.7rem;letter-spacing:.14em;
  color:var(--kz-red);text-transform:uppercase;white-space:nowrap;
}
.kz-onair .dot{width:9px;height:9px;border-radius:50%;background:var(--kz-red);box-shadow:0 0 0 0 rgba(214,40,40,.6);animation:kz-pulse 1.6s infinite}
@keyframes kz-pulse{0%{box-shadow:0 0 0 0 rgba(214,40,40,.55)}70%{box-shadow:0 0 0 9px rgba(214,40,40,0)}100%{box-shadow:0 0 0 0 rgba(214,40,40,0)}}

/* burger */
.kz-burger{display:none;background:none;border:0;cursor:pointer;color:var(--kz-text);padding:.4rem}
.kz-burger svg{width:26px;height:26px}

/* =========================================================================
   4. LECTEUR LIVE (élément signature)
   ========================================================================= */
.kz-player{
  position:relative;border-radius:var(--kz-radius-lg);overflow:hidden;
  background:#000;border:1px solid var(--kz-line);box-shadow:var(--kz-shadow);
  aspect-ratio:16/9;
}
.kz-player video{width:100%;height:100%;object-fit:cover;background:#000;display:block}
.kz-player__poster{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;
  background:radial-gradient(120% 120% at 50% 20%, #1b1b22, #000);text-align:center;padding:1.5rem;
}
.kz-player__poster img{height:96px;width:auto;opacity:.95;filter:drop-shadow(0 8px 24px rgba(0,0,0,.6))}
.kz-player__poster p{color:var(--kz-muted);font-size:.9rem;max-width:30ch}
.kz-player.is-playing .kz-player__poster{display:none}

/* badge EN DIRECT sur le player */
.kz-livebadge{
  position:absolute;top:14px;left:14px;z-index:5;
  display:inline-flex;align-items:center;gap:.45rem;
  background:var(--kz-red);color:#fff;
  font-family:var(--kz-mono);font-weight:700;font-size:.7rem;letter-spacing:.14em;
  padding:.4rem .7rem;border-radius:8px;text-transform:uppercase;
}
.kz-livebadge .dot{width:8px;height:8px;border-radius:50%;background:#fff;animation:kz-blink 1.4s steps(1) infinite}
@keyframes kz-blink{50%{opacity:.25}}

/* horloge H24 sur le player */
.kz-player__clock{
  position:absolute;top:14px;right:14px;z-index:5;
  font-family:var(--kz-mono);font-weight:700;font-size:.82rem;letter-spacing:.08em;
  color:#fff;background:rgba(0,0,0,.45);backdrop-filter:blur(6px);
  padding:.4rem .7rem;border-radius:8px;font-variant-numeric:tabular-nums;
}

/* contrôles */
.kz-controls{
  position:absolute;left:0;right:0;bottom:0;z-index:6;
  display:flex;align-items:center;gap:.7rem;padding:.8rem 1rem;
  background:linear-gradient(to top, rgba(0,0,0,.85), transparent);
  opacity:0;transform:translateY(8px);transition:.2s ease;
}
.kz-player:hover .kz-controls,.kz-player:focus-within .kz-controls{opacity:1;transform:none}
.kz-ctrl{
  background:rgba(255,255,255,.1);border:0;color:#fff;cursor:pointer;
  width:42px;height:42px;border-radius:10px;display:grid;place-items:center;transition:.15s ease;
}
.kz-ctrl:hover{background:var(--kz-yellow);color:var(--kz-black)}
.kz-ctrl svg{width:20px;height:20px}
.kz-volume{accent-color:var(--kz-yellow);width:90px}
.kz-controls .kz-live-anchor{
  margin-left:auto;font-family:var(--kz-sub);font-weight:700;font-size:.74rem;
  text-transform:uppercase;letter-spacing:.08em;color:#fff;background:var(--kz-red);
  border:0;border-radius:8px;padding:.45rem .7rem;cursor:pointer;
}

/* égaliseur signature (couleurs drapeau) */
.kz-eq{display:flex;align-items:flex-end;gap:3px;height:22px}
.kz-eq span{width:4px;border-radius:2px;background:var(--kz-green);animation:kz-bounce 1s ease-in-out infinite}
.kz-eq span:nth-child(2){background:var(--kz-yellow);animation-delay:.15s;height:60%}
.kz-eq span:nth-child(3){background:var(--kz-red);animation-delay:.3s;height:90%}
.kz-eq span:nth-child(4){background:var(--kz-blue);animation-delay:.45s;height:45%}
.kz-eq span:nth-child(5){background:var(--kz-yellow);animation-delay:.6s;height:75%}
@keyframes kz-bounce{0%,100%{height:25%}50%{height:100%}}

/* =========================================================================
   5. HERO (front-page)
   ========================================================================= */
.kz-hero{position:relative;padding:2.6rem 0 1rem}
.kz-hero__grid{display:grid;grid-template-columns:1.55fr 1fr;gap:2.2rem;align-items:center}
.kz-hero__title{margin:.2rem 0 .3rem;font-size:clamp(3rem,7vw,6rem)}
.kz-hero__title .l1{display:block;color:var(--kz-white)}
.kz-hero__title .l2{display:block;background:var(--kz-flag);-webkit-background-clip:text;background-clip:text;color:transparent}
.kz-hero__sub{font-family:var(--kz-sub);font-weight:700;font-size:1.05rem;color:var(--kz-text);margin-bottom:.4rem}
.kz-hero__desc{color:var(--kz-muted);max-width:46ch}
.kz-hero__cta{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem}
.kz-hero__meta{display:flex;align-items:center;gap:1.4rem;margin-top:1.6rem;flex-wrap:wrap}
.kz-hero__meta .item{display:flex;flex-direction:column;gap:.1rem}
.kz-hero__meta .k{font-family:var(--kz-mono);font-weight:700;font-size:1.5rem;color:var(--kz-yellow);font-variant-numeric:tabular-nums}
.kz-hero__meta .v{font-family:var(--kz-sub);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--kz-muted)}

/* =========================================================================
   6. SECTIONS
   ========================================================================= */
.kz-section{padding:3.2rem 0}
.kz-section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.8rem;flex-wrap:wrap}
.kz-section__head h2{margin:0}
.kz-section--alt{background:var(--kz-bg-2);border-block:1px solid var(--kz-line)}

/* grille d'articles */
.kz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.kz-grid--2{grid-template-columns:repeat(2,1fr)}

.kz-card{
  background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:var(--kz-radius);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease, border-color .18s ease;
}
.kz-card:hover{transform:translateY(-4px);border-color:rgba(255,209,0,.5)}
.kz-card__thumb{aspect-ratio:16/10;overflow:hidden;background:var(--kz-surface-2);position:relative}
.kz-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.kz-card:hover .kz-card__thumb img{transform:scale(1.05)}
.kz-card__thumb--empty{display:grid;place-items:center}
.kz-card__thumb--empty span{font-family:var(--kz-display);font-size:2.4rem;color:var(--kz-line)}
.kz-card__cat{
  position:absolute;top:10px;left:10px;font-family:var(--kz-sub);font-weight:800;
  text-transform:uppercase;letter-spacing:.08em;font-size:.64rem;color:var(--kz-black);
  background:var(--kz-yellow);padding:.28rem .55rem;border-radius:6px;
}
.kz-card__body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.kz-card__date{font-family:var(--kz-mono);font-size:.7rem;color:var(--kz-muted);letter-spacing:.06em}
.kz-card__title{font-family:var(--kz-sub);font-weight:700;font-size:1.12rem;line-height:1.25;color:var(--kz-text)}
.kz-card a.kz-card__title:hover{color:var(--kz-yellow)}
.kz-card__excerpt{color:var(--kz-muted);font-size:.9rem;margin:0}
.kz-card__more{margin-top:auto;font-family:var(--kz-sub);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--kz-yellow)}

/* grille des programmes */
.kz-schedule{display:flex;flex-direction:column;gap:.5rem}
.kz-slot{
  display:grid;grid-template-columns:96px 1fr auto;gap:1rem;align-items:center;
  background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:12px;padding:.85rem 1.1rem;
  transition:border-color .15s ease;
}
.kz-slot:hover{border-color:rgba(0,154,68,.5)}
.kz-slot.is-now{border-color:var(--kz-red);background:linear-gradient(90deg,rgba(214,40,40,.12),transparent)}
.kz-slot__time{font-family:var(--kz-mono);font-weight:700;font-size:1.05rem;color:var(--kz-yellow)}
.kz-slot__name{font-family:var(--kz-sub);font-weight:700;color:var(--kz-text)}
.kz-slot__desc{font-size:.85rem;color:var(--kz-muted)}
.kz-slot__tag{font-family:var(--kz-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--kz-muted)}
.kz-slot.is-now .kz-slot__tag{color:var(--kz-red)}

/* =========================================================================
   7. ARTICLE (single) + commentaires
   ========================================================================= */
.kz-article{max-width:780px;margin-inline:auto;padding:2.4rem 0 1rem}
.kz-article__header{margin-bottom:1.6rem}
.kz-article__title{font-size:clamp(2.2rem,5vw,3.6rem);margin:.3rem 0 .6rem}
.kz-article__meta{display:flex;gap:1rem;flex-wrap:wrap;font-family:var(--kz-mono);font-size:.74rem;color:var(--kz-muted);letter-spacing:.05em}
.kz-article__feat{border-radius:var(--kz-radius);overflow:hidden;margin:1.4rem 0 2rem;border:1px solid var(--kz-line)}
.kz-prose{font-size:1.05rem;line-height:1.8}
.kz-prose h2,.kz-prose h3{font-family:var(--kz-sub);font-weight:800;margin-top:1.8rem;letter-spacing:0}
.kz-prose img{border-radius:12px;margin:1.4rem 0}
.kz-prose blockquote{border-left:4px solid var(--kz-green);margin:1.4rem 0;padding:.4rem 0 .4rem 1.2rem;color:var(--kz-text);font-style:italic}
.kz-prose a{text-decoration:underline}

.kz-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin:2rem 0}
.kz-tags a{font-family:var(--kz-sub);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--kz-text);background:var(--kz-surface-2);border:1px solid var(--kz-line);padding:.35rem .7rem;border-radius:999px}
.kz-tags a:hover{border-color:var(--kz-yellow);color:var(--kz-yellow)}

/* commentaires */
.kz-comments{max-width:780px;margin-inline:auto;padding:1rem 0 3rem}
.kz-comments__title{font-family:var(--kz-sub);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:1.1rem;margin-bottom:1.4rem;display:flex;align-items:center;gap:.6rem}
.kz-comments__title::before{content:"";width:30px;height:3px;border-radius:3px;background:var(--kz-flag)}
.kz-comments ol,.kz-comments ul{list-style:none;margin:0;padding:0}
.kz-comments .comment-body{background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:12px;padding:1rem 1.2rem;margin-bottom:1rem}
.kz-comments .children{margin-left:1.6rem;padding-left:.6rem;border-left:2px solid var(--kz-line)}
.kz-comments .comment-author{font-family:var(--kz-sub);font-weight:700;display:flex;align-items:center;gap:.6rem;margin-bottom:.3rem}
.kz-comments .comment-author .avatar{border-radius:50%}
.kz-comments .comment-metadata{font-family:var(--kz-mono);font-size:.68rem;color:var(--kz-muted);margin-bottom:.5rem}
.kz-comments .comment-metadata a{color:var(--kz-muted)}
.kz-comments .reply a{font-family:var(--kz-sub);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--kz-yellow)}

.kz-respond{background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:var(--kz-radius);padding:1.5rem;margin-top:1.5rem}
.kz-respond .comment-reply-title{font-family:var(--kz-sub);font-weight:800;font-size:1.1rem;margin-bottom:.4rem}
.kz-respond label{display:block;font-family:var(--kz-sub);font-weight:600;font-size:.8rem;margin:.8rem 0 .35rem;color:var(--kz-muted)}
.kz-respond input[type=text],.kz-respond input[type=email],.kz-respond input[type=url],.kz-respond textarea{
  width:100%;background:var(--kz-bg);border:1px solid var(--kz-line);border-radius:10px;
  color:var(--kz-text);font-family:var(--kz-body);font-size:.95rem;padding:.7rem .9rem;
}
.kz-respond input:focus,.kz-respond textarea:focus{outline:2px solid var(--kz-yellow);outline-offset:1px;border-color:transparent}
.kz-respond .form-submit{margin-top:1.1rem}
.kz-respond .submit{
  font-family:var(--kz-sub);font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  background:var(--kz-yellow);color:var(--kz-black);border:0;border-radius:999px;padding:.8rem 1.6rem;cursor:pointer;
}
.kz-respond .submit:hover{filter:brightness(1.05)}
.kz-respond .comment-form-cookies-consent{display:flex;gap:.5rem;align-items:flex-start}
.kz-respond .comment-form-cookies-consent label{margin:0}

/* =========================================================================
   8. MINI-LECTEUR FLOTTANT (persistant sur tout le site)
   ========================================================================= */
.kz-float{
  position:fixed;right:18px;bottom:18px;z-index:1200;width:340px;max-width:calc(100vw - 28px);
  background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:16px;overflow:hidden;
  box-shadow:var(--kz-shadow);transform:translateY(140%);opacity:0;transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .25s ease;
}
.kz-float.is-visible{transform:none;opacity:1}
.kz-float.is-min{width:auto}
.kz-float__bar{
  display:flex;align-items:center;gap:.5rem;padding:.45rem .55rem;background:var(--kz-black);
  border-bottom:1px solid var(--kz-line);cursor:grab;
}
.kz-float__bar:active{cursor:grabbing}
.kz-float__brand{display:flex;align-items:center;gap:.45rem;margin-right:auto;font-family:var(--kz-sub);font-weight:800;font-size:.74rem;letter-spacing:.04em}
.kz-float__brand .dot{width:8px;height:8px;border-radius:50%;background:var(--kz-red);animation:kz-blink 1.4s steps(1) infinite}
.kz-float__btn{background:rgba(255,255,255,.08);border:0;color:#fff;width:30px;height:30px;border-radius:8px;cursor:pointer;display:grid;place-items:center}
.kz-float__btn:hover{background:var(--kz-yellow);color:var(--kz-black)}
.kz-float__btn svg{width:16px;height:16px}
.kz-float__video{aspect-ratio:16/9;background:#000}
.kz-float__video video{width:100%;height:100%;object-fit:cover;display:block}
.kz-float.is-min .kz-float__video{display:none}

/* =========================================================================
   9. PAGINATION / FOOTER / DIVERS
   ========================================================================= */
.kz-pagination{display:flex;gap:.4rem;justify-content:center;margin-top:2.4rem;flex-wrap:wrap}
.kz-pagination .page-numbers{
  font-family:var(--kz-sub);font-weight:700;min-width:42px;height:42px;display:grid;place-items:center;
  border:1px solid var(--kz-line);border-radius:10px;color:var(--kz-text);padding:0 .6rem;
}
.kz-pagination .page-numbers.current{background:var(--kz-yellow);color:var(--kz-black);border-color:var(--kz-yellow)}
.kz-pagination a.page-numbers:hover{border-color:var(--kz-yellow);color:var(--kz-yellow)}

.kz-footer{margin-top:2rem;background:var(--kz-bg-2);border-top:1px solid var(--kz-line)}
.kz-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding:3rem 0 2rem}
.kz-footer__brand img{height:64px;margin-bottom:1rem}
.kz-footer__brand p{color:var(--kz-muted);max-width:42ch;font-size:.92rem}
.kz-footer h4{font-family:var(--kz-sub);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;margin-bottom:1rem}
.kz-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.kz-footer a{color:var(--kz-muted)}
.kz-footer a:hover{color:var(--kz-yellow)}
.kz-social{display:flex;gap:.6rem;margin-top:.4rem}
.kz-social a{width:40px;height:40px;border-radius:10px;border:1px solid var(--kz-line);display:grid;place-items:center;color:var(--kz-text)}
.kz-social a:hover{border-color:var(--kz-yellow);color:var(--kz-yellow)}
.kz-social svg{width:18px;height:18px}
.kz-footer__bottom{border-top:1px solid var(--kz-line);padding:1.1rem 0;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:var(--kz-muted)}
.kz-footer__bottom .kz-mono{font-family:var(--kz-mono);letter-spacing:.05em}

/* page title bar (archives) */
.kz-pagehead{padding:2.6rem 0 1rem}
.kz-pagehead h1{font-size:clamp(2.4rem,5vw,4rem)}
.kz-pagehead p{color:var(--kz-muted);max-width:60ch}

/* =========================================================================
   10. RESPONSIVE
   ========================================================================= */
@media (max-width:980px){
  .kz-hero__grid{grid-template-columns:1fr;gap:1.6rem}
  .kz-grid{grid-template-columns:repeat(2,1fr)}
  .kz-footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
  .kz-nav,.kz-status{display:none}
  .kz-burger{display:inline-flex}
  .kz-header.is-open .kz-nav{
    display:block;position:absolute;top:100%;left:0;right:0;background:var(--kz-bg);
    border-bottom:1px solid var(--kz-line);padding:.6rem 1.2rem 1.2rem;
  }
  .kz-header.is-open .kz-nav ul{flex-direction:column;gap:.1rem}
  .kz-grid,.kz-grid--2{grid-template-columns:1fr}
  .kz-footer__grid{grid-template-columns:1fr}
  .kz-slot{grid-template-columns:72px 1fr;}
  .kz-slot__tag{display:none}
  .kz-float{width:280px}
}

/* accessibilité : mouvement réduit */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto}
  .kz-eq span{height:60%!important}
}

/* focus clavier visible partout */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,.kz-ctrl:focus-visible{
  outline:3px solid var(--kz-yellow);outline-offset:2px;border-radius:6px;
}

/* formulaire de recherche & widgets */
.kz-search{display:flex;gap:.5rem;max-width:520px;margin-top:1.4rem}
.kz-search input[type=search]{flex:1;background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:999px;color:var(--kz-text);padding:.75rem 1.1rem;font-family:var(--kz-body)}
.kz-search input:focus{outline:2px solid var(--kz-yellow);border-color:transparent}
.kz-widget{background:var(--kz-surface);border:1px solid var(--kz-line);border-radius:var(--kz-radius);padding:1.2rem;margin-bottom:1.2rem}
.kz-widget__title{font-family:var(--kz-sub);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.9rem;margin-bottom:.8rem}
.kz-widget ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.kz-widget a{color:var(--kz-text)}
.kz-widget a:hover{color:var(--kz-yellow)}
