/*
Theme Name: Nina Rencontre
Theme URI: https://nina-rencontre.fr
Author: Mass
Description: Thème éditorial sur-mesure pour Nina Rencontre — blog de conseils en rencontres et vie sentimentale. Design moderne, chaleureux, incarné par la persona éditoriale Nina. Prêt pour contenu LeechWriter.
Version: 1.6.3
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: nina-rencontre
*/

:root{
  --corail:#e85d4a;
  --corail-fonce:#c9402c;
  --terre:#b8503f;
  --rose:#f4ddd5;
  --rose-clair:#fbf4f0;
  --prune:#3a1f28;
  --prune-soft:#5a3340;
  --creme:#fdfaf7;
  --or:#cf9a5b;
  --gris:#8a7378;
  --gris-clair:#cbbdc0;
  --serif:'Instrument Serif',Georgia,serif;
  --sans:'Sora',system-ui,sans-serif;
  --wrap:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--sans);color:var(--prune);background:var(--creme);line-height:1.65;font-weight:300;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
svg{display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:#fff;padding:10px 16px;z-index:999;border-radius:8px}

/* ---------- Topbar ---------- */
.topbar{background:var(--prune);color:var(--rose);font-size:.8rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:40px}
.topbar-claim{opacity:.92}
.topbar-links a{opacity:.82;font-weight:400}
.topbar-links a:hover{opacity:1;color:var(--corail)}
.topbar-links span[aria-hidden]{opacity:.4;margin:0 6px}

/* ---------- Header ---------- */
header.main{background:rgba(253,250,247,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--rose);position:sticky;top:0;z-index:50}
header.main .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;align-items:center;gap:13px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand .mark{width:46px;height:46px;border-radius:13px;overflow:hidden;flex-shrink:0;background:linear-gradient(140deg,var(--corail),var(--or));display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:1.5rem}
.brand .mark img{width:100%;height:100%;object-fit:cover}
.brand .name{font-family:var(--serif);font-size:1.75rem;color:var(--prune);line-height:.9;letter-spacing:.01em}
.brand .tag{font-size:.64rem;letter-spacing:.22em;text-transform:uppercase;color:var(--corail);font-weight:600;margin-top:3px}
nav.menu ul{list-style:none;display:flex;gap:34px;align-items:center}
nav.menu li{position:relative}
nav.menu a{font-weight:400;font-size:.92rem;position:relative;padding:4px 0;color:var(--prune-soft);display:inline-flex;align-items:center;gap:5px}
nav.menu>ul>li>a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:1.5px;background:var(--corail);transition:width .3s cubic-bezier(.4,0,.2,1)}
nav.menu>ul>li>a:hover::after,nav.menu>ul>li.current-menu-item>a::after{width:100%}
nav.menu a:hover{color:var(--prune)}
/* Caret on parents */
nav.menu li.menu-item-has-children>a::before{content:"";order:2;width:7px;height:7px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);margin-left:3px;opacity:.6;transition:transform .25s}
nav.menu li.menu-item-has-children:hover>a::before{transform:rotate(225deg) translateY(2px)}
/* Submenu */
nav.menu ul ul{position:absolute;top:calc(100% + 14px);left:-18px;flex-direction:column;align-items:stretch;gap:0;min-width:210px;background:#fff;border:1px solid var(--rose);border-radius:14px;padding:8px;box-shadow:0 18px 44px -16px rgba(58,31,40,.28);opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .25s,transform .25s,visibility .25s;z-index:60}
nav.menu ul ul::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
nav.menu li:hover>ul,nav.menu li:focus-within>ul,nav.menu li.nina-open>ul{opacity:1;visibility:visible;transform:translateY(0)}
nav.menu ul ul li a{display:block;padding:9px 14px;border-radius:9px;font-size:.88rem;color:var(--prune-soft);width:100%}
nav.menu ul ul li a::after{display:none}
nav.menu ul ul li a:hover{background:var(--rose-clair);color:var(--corail-fonce)}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
.menu-toggle svg{width:26px;height:26px;color:var(--prune)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:var(--creme)}
.hero::before{content:"";position:absolute;left:50%;top:-300px;width:900px;height:900px;transform:translateX(-50%);background:radial-gradient(circle,rgba(244,221,213,.7),transparent 60%);z-index:0}
.hero .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.25fr .85fr;gap:60px;align-items:center;padding:90px 32px 80px}
.hero .eyebrow{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--corail);font-weight:600;margin-bottom:22px;display:flex;align-items:center;gap:10px}
.hero .eyebrow::before{content:"";width:34px;height:1px;background:var(--corail)}
.hero h1{font-family:var(--serif);font-size:4.1rem;line-height:1.02;color:var(--prune);font-weight:400;margin-bottom:24px;letter-spacing:-.01em}
.hero h1 em{font-style:italic;color:var(--corail-fonce)}
.hero p{font-size:1.08rem;color:var(--gris);max-width:460px;margin-bottom:34px}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--prune);color:var(--creme);padding:15px 30px;border-radius:50px;font-weight:500;font-size:.92rem;transition:.3s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;font-family:inherit}
.btn:hover{background:var(--corail);transform:translateY(-2px)}
.btn svg{width:16px;height:16px}
.nina-card{background:#fff;border-radius:26px;padding:36px 32px;box-shadow:0 30px 70px -20px rgba(58,31,40,.28);text-align:center;border:1px solid rgba(244,221,213,.8)}
.nina-card .portrait{width:150px;height:150px;border-radius:50%;margin:0 auto 18px;overflow:hidden;background:linear-gradient(140deg,var(--rose),var(--corail))}
.nina-card .portrait img{width:100%;height:100%;object-fit:cover}
.nina-card h3{font-family:var(--serif);font-size:1.7rem;color:var(--prune);margin-bottom:2px}
.nina-card .role{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--corail);font-weight:600;margin-bottom:14px}
.nina-card p{font-size:.85rem;color:var(--gris);margin:0}
.nina-card .chip{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:.74rem;background:var(--rose-clair);color:var(--prune-soft);padding:7px 14px;border-radius:30px;font-weight:500}
.nina-card .chip svg{width:13px;height:13px;color:var(--corail)}

/* ---------- Sections ---------- */
.sec{padding:80px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:42px}
.sec-head .t .k{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--corail);font-weight:600;margin-bottom:10px}
.sec-head h2{font-family:var(--serif);font-size:2.6rem;color:var(--prune);font-weight:400;line-height:1}
.sec-head .more{font-size:.85rem;font-weight:500;color:var(--prune-soft);display:inline-flex;align-items:center;gap:8px;padding-bottom:6px;border-bottom:1.5px solid var(--corail)}
.sec-head .more svg{width:15px;height:15px;color:var(--corail)}

/* ---------- Article grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.card{display:flex;flex-direction:column;background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(244,221,213,.7);transition:.35s cubic-bezier(.4,0,.2,1)}
.card:hover{transform:translateY(-6px);box-shadow:0 28px 50px -22px rgba(58,31,40,.3)}
.card .thumb{display:block;height:200px;min-height:200px;position:relative;background:linear-gradient(140deg,var(--rose),var(--corail));overflow:hidden;flex-shrink:0}
.card .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.card .cat{position:absolute;top:16px;left:16px;max-width:calc(100% - 32px);background:rgba(253,250,247,.95);color:var(--corail-fonce);font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding:6px 13px;border-radius:30px;z-index:2;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .body{padding:26px}
.card h3{font-family:var(--serif);font-size:1.5rem;color:var(--prune);line-height:1.12;margin-bottom:12px;font-weight:400}
.card h3 a:hover{color:var(--corail-fonce)}
.card p{font-size:.88rem;color:var(--gris);margin-bottom:18px}
.card .meta{font-size:.76rem;color:var(--prune-soft);font-weight:500;display:flex;align-items:center;gap:9px}
.card .meta .av{width:24px;height:24px;border-radius:50%;overflow:hidden;background:linear-gradient(140deg,var(--corail),var(--or))}
.card .meta .av img{width:100%;height:100%;object-fit:cover}

/* ---------- Promo / affiliation slot ---------- */
.promo{position:relative;overflow:hidden;background:var(--prune);border-radius:28px;padding:52px 56px;display:flex;align-items:center;justify-content:space-between;gap:40px;color:var(--creme)}
.promo::after{content:"";position:absolute;right:-80px;bottom:-120px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(232,93,74,.4),transparent 65%)}
.promo .ct{position:relative;z-index:1}
.promo .label{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;opacity:.55;display:block;margin-bottom:14px}
.promo h3{font-family:var(--serif);font-size:2.2rem;margin-bottom:12px;font-weight:400}
.promo p{opacity:.8;font-size:.95rem;max-width:520px}
.promo .btn{background:var(--corail);position:relative;z-index:1}
.promo .btn:hover{background:var(--creme);color:var(--prune)}

/* ---------- Topics ---------- */
.topics{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.topic{background:#fff;border:1px solid rgba(244,221,213,.8);border-radius:20px;padding:30px 26px;transition:.3s cubic-bezier(.4,0,.2,1)}
.topic:hover{border-color:var(--corail);transform:translateY(-4px);box-shadow:0 20px 40px -24px rgba(58,31,40,.3)}
.topic .ic{width:48px;height:48px;border-radius:14px;background:var(--rose-clair);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.topic .ic svg{width:23px;height:23px;color:var(--corail-fonce)}
.topic h4{font-family:var(--serif);font-size:1.35rem;color:var(--prune);margin-bottom:5px;font-weight:400}
.topic span{font-size:.8rem;color:var(--gris)}

/* ---------- Single / Page content ---------- */
.article-hero{padding:70px 0 40px;text-align:center;position:relative}
.article-hero .cat-link{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--corail);font-weight:600}
.article-hero h1{font-family:var(--serif);font-size:3.2rem;color:var(--prune);font-weight:400;line-height:1.08;max-width:820px;margin:18px auto 22px}
.article-hero .byline{display:inline-flex;align-items:center;gap:11px;font-size:.85rem;color:var(--prune-soft)}
.article-hero .byline .av{width:34px;height:34px;border-radius:50%;overflow:hidden;background:linear-gradient(140deg,var(--corail),var(--or))}
.article-hero .byline .av img{width:100%;height:100%;object-fit:cover}
.featured-wrap{max-width:980px;margin:0 auto 50px;border-radius:24px;overflow:hidden}
.featured-wrap img{width:100%;height:auto}
.entry{max-width:760px;margin:0 auto;font-size:1.08rem;line-height:1.85;color:#43323a;font-weight:300}
.entry p{margin-bottom:1.5em}
.entry h2{font-family:var(--serif);font-size:2rem;color:var(--prune);font-weight:400;margin:1.8em 0 .6em}
.entry h3{font-family:var(--serif);font-size:1.5rem;color:var(--prune);font-weight:400;margin:1.5em 0 .5em}
.entry a{color:var(--corail-fonce);text-decoration:underline;text-underline-offset:3px}
.entry ul,.entry ol{margin:0 0 1.5em 1.4em}
.entry li{margin-bottom:.5em}
.entry blockquote{border-left:3px solid var(--corail);padding:6px 0 6px 24px;margin:1.6em 0;font-family:var(--serif);font-size:1.3rem;font-style:italic;color:var(--prune)}
.entry img{border-radius:16px;margin:1.5em 0}

/* Nina note box (medical redirect / disclaimer in-content) */
.nina-note{background:var(--rose-clair);border:1px solid var(--rose);border-radius:18px;padding:24px 28px;margin:2em 0;display:flex;gap:18px;align-items:flex-start}
.nina-note .ava{width:54px;height:54px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(140deg,var(--corail),var(--or))}
.nina-note .ava img{width:100%;height:100%;object-fit:cover}
.nina-note .txt{font-size:.92rem;color:var(--prune-soft);line-height:1.6}
.nina-note .txt strong{color:var(--prune)}

/* ---------- Archive header ---------- */
.archive-head{background:linear-gradient(160deg,var(--rose-clair),var(--rose));padding:70px 0;text-align:center}
.archive-head .k{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--corail);font-weight:600;margin-bottom:12px}
.archive-head h1{font-family:var(--serif);font-size:3rem;color:var(--prune);font-weight:400}
.archive-head p{color:var(--gris);max-width:560px;margin:14px auto 0}

/* ---------- Pagination ---------- */
.pagination{display:flex;justify-content:center;gap:8px;margin-top:50px}
.pagination .page-numbers{padding:10px 16px;border-radius:12px;border:1px solid var(--rose);color:var(--prune-soft);font-size:.9rem;font-weight:500}
.pagination .page-numbers.current{background:var(--prune);color:#fff;border-color:var(--prune)}
.pagination a.page-numbers:hover{border-color:var(--corail);color:var(--corail)}

/* ---------- Sidebar widgets ---------- */
.layout-sidebar{display:grid;grid-template-columns:1fr 320px;gap:50px;max-width:var(--wrap);margin:0 auto;padding:60px 32px}
.single-main{min-width:0}
.single-main .entry{max-width:none;margin:0}
.single-main .post-extras{max-width:none;margin:60px 0 0;padding:0}
.single-main .related{max-width:none;margin:70px 0 0;padding:0}
.widget{background:#fff;border:1px solid rgba(244,221,213,.8);border-radius:18px;padding:26px;margin-bottom:26px}
.widget-title{font-family:var(--serif);font-size:1.3rem;color:var(--prune);margin-bottom:16px;font-weight:400}
.widget ul{list-style:none}
.widget li{margin-bottom:10px;font-size:.9rem}
.widget a:hover{color:var(--corail-fonce)}

/* ---------- Footer ---------- */
footer.site{background:var(--prune);color:var(--rose);margin-top:40px;padding:70px 0 32px}
.fgrid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1.5fr;gap:48px;margin-bottom:48px}
footer.site h4{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--corail);margin-bottom:20px;font-weight:600}
footer.site .fbrand{font-family:var(--serif);font-size:1.9rem;color:var(--creme);margin-bottom:14px}
footer.site p{font-size:.86rem;opacity:.7;line-height:1.8}
footer.site ul{list-style:none}
footer.site li{margin-bottom:11px}
footer.site li a{font-size:.86rem;opacity:.78}
footer.site li a:hover{opacity:1;color:var(--corail)}
.news input{width:100%;padding:13px 16px;border-radius:12px;border:1px solid var(--prune-soft);background:var(--prune-soft);color:#fff;font-family:inherit;font-size:.86rem;margin-top:6px}
.news input::placeholder{color:var(--gris-clair)}
.disclaimer{border-top:1px solid rgba(244,221,213,.15);padding-top:24px;font-size:.76rem;opacity:.58;line-height:1.7}
.disclaimer strong{color:var(--rose);font-weight:500}

/* ---------- Post extras (author box, nav, related) ---------- */
.post-extras{max-width:760px;margin:60px auto 0;padding:0 32px}
.related{max-width:var(--wrap);margin:70px auto 0;padding:0 32px}

/* Author box */
.author-box{display:flex;gap:22px;align-items:flex-start;background:var(--rose-clair);border:1px solid var(--rose);border-radius:20px;padding:28px 30px}
.author-avatar{width:84px;height:84px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(140deg,var(--corail),var(--or));display:flex;align-items:center;justify-content:center}
.author-avatar img{width:100%;height:100%;object-fit:cover}
.author-avatar span{font-family:var(--serif);font-size:2.2rem;color:#fff}
.author-kicker{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--corail);font-weight:600}
.author-name{font-family:var(--serif);font-size:1.6rem;color:var(--prune);font-weight:400;margin:2px 0 8px}
.author-bio{font-size:.92rem;color:var(--prune-soft);line-height:1.6;margin:0}

/* Prev / Next nav */
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:36px}
.post-nav-link{display:flex;flex-direction:column;gap:8px;padding:20px 22px;border:1px solid var(--rose);border-radius:16px;transition:.25s cubic-bezier(.4,0,.2,1);background:#fff}
.post-nav-link:hover{border-color:var(--corail);transform:translateY(-3px);box-shadow:0 18px 36px -22px rgba(58,31,40,.3)}
.post-nav-link.empty{border:none;background:none;pointer-events:none}
.post-nav-link.next{text-align:right}
.pn-dir{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--corail);font-weight:600}
.post-nav-link.next .pn-dir{justify-content:flex-end}
.pn-dir svg{width:15px;height:15px}
.pn-title{font-family:var(--serif);font-size:1.12rem;color:var(--prune);line-height:1.2}

@media(max-width:920px){
  .post-nav{grid-template-columns:1fr}
  .post-nav-link.empty{display:none}
  .post-nav-link.next{text-align:left}
  .post-nav-link.next .pn-dir{justify-content:flex-start}
  .author-box{flex-direction:column;align-items:center;text-align:center}
}

/* ---------- Scroll to top ---------- */
.scroll-top{position:fixed;right:24px;bottom:24px;width:48px;height:48px;border-radius:50%;border:none;cursor:pointer;background:var(--corail);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 22px -6px rgba(232,93,74,.6);opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .3s,transform .3s,background .25s,visibility .3s;z-index:60}
.scroll-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.scroll-top:hover{background:var(--prune)}
.scroll-top svg{width:22px;height:22px}
@media(max-width:920px){.scroll-top{right:16px;bottom:16px;width:44px;height:44px}}
@media(prefers-reduced-motion:reduce){.scroll-top{transition:opacity .2s,visibility .2s}}

/* Forms (newsletter / contact) */
.nina-hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important}
.newsletter-form{margin-top:6px;display:flex;flex-direction:column;gap:10px}
.newsletter-form .btn{justify-content:center}
.form-msg{font-size:.82rem;padding:9px 13px;border-radius:10px;margin-top:4px}
.form-msg.ok{background:rgba(83,255,69,.12);color:#1f7a16}
.form-msg.err{background:rgba(201,64,44,.12);color:var(--corail-fonce)}
.contact-form{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.contact-form input,.contact-form textarea{width:100%;padding:13px 16px;border-radius:12px;border:1px solid var(--rose);background:#fff;font-family:inherit;font-size:.92rem;color:var(--prune)}
.contact-form textarea{min-height:150px;resize:vertical}

/* ---------- Responsive ---------- */
@media(max-width:920px){
  .hero .wrap{grid-template-columns:1fr;gap:44px;padding:60px 32px}
  .hero h1{font-size:3rem}
  .grid{grid-template-columns:1fr}
  .topics{grid-template-columns:repeat(2,1fr)}
  .fgrid{grid-template-columns:1fr 1fr}
  .promo{flex-direction:column;text-align:center;padding:40px 30px}
  .layout-sidebar{grid-template-columns:1fr}
  .article-hero h1{font-size:2.3rem}
  nav.menu{position:fixed;inset:124px 0 auto 0;background:var(--creme);border-bottom:1px solid var(--rose);transform:translateY(-130%);transition:transform .35s;padding:20px 0;max-height:80vh;overflow-y:auto}
  nav.menu.open{transform:translateY(0)}
  nav.menu ul{flex-direction:column;gap:0;align-items:stretch}
  nav.menu li{padding:0;width:100%}
  nav.menu>ul>li>a{padding:12px 32px}
  nav.menu ul ul{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;border-radius:0;background:var(--rose-clair);padding:0;min-width:0;margin:0}
  nav.menu ul ul li a{padding:10px 48px}
  nav.menu li.menu-item-has-children>a::before{margin-left:auto}
  .menu-toggle{display:block}
}
