/*
Theme Name: Libre ce soir Theme
Theme URI: https://sensulibre.com
Author: Libre ce soir
Description: Theme doux et sensuel (soft) avec page d'accueil + sections prêtes pour la page "Libre ce soir".
Version: 1.0.4
Text Domain: sensulibre-theme
*/

:root{
  /* Un chouia plus clair, tout en restant nocturne/mauve */
  --sl-bg:#171722;
  --sl-bg2:#1f1f2f;
  --sl-card:#24243a;
  --sl-text:#f6f1ff;
  --sl-muted:rgba(246,241,255,.75);
  --sl-accent:#b07bff; /* mauve */
  --sl-accent2:#ff9acb; /* rosé */
  --sl-border:rgba(255,255,255,.10);
}

/* --- Pays / Langues (barre compacte) --- */
.sl-langbar-wrap{ margin-top:10px; }
.sl-langbar{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.sl-langbar__label{ font-weight:800; opacity:.9; margin-right:6px; }
.sl-langbar__list{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.sl-langbar__chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:30px;
  padding:0 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.14);
  text-decoration:none;
  font-weight:800;
  letter-spacing:.3px;
  font-size:12px;
  color:inherit;
}
.sl-langbar__chip.is-active{ border-color: rgba(255,255,255,.30); background: rgba(255,255,255,.08); }

@media (max-width: 780px){
  /* 1 ligne sur mobile, scroll horizontal (pas de gros bloc) */
  .sl-langbar{ flex-wrap:nowrap; }
  .sl-langbar__list{
    flex-wrap:nowrap;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding-bottom:2px;
  }
  .sl-langbar__list::-webkit-scrollbar{ display:none; }
}
*{box-sizing:border-box}
img{max-width:100%;height:auto}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--sl-text);
  background: radial-gradient(1200px 700px at 20% 10%, rgba(176,123,255,.25), transparent 60%),
              radial-gradient(1000px 600px at 80% 20%, rgba(255,154,203,.18), transparent 55%),
              linear-gradient(180deg, var(--sl-bg), #08080b);
}
a{color:inherit;text-decoration:none}
a:hover{opacity:.92}

.sl-wrap{max-width:1100px;margin:0 auto;padding:0 18px}
.sl-topbar{
  position:sticky;top:0;z-index:20;
  background:rgba(10,10,14,.72);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--sl-border);
}
.sl-topbar-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:12px}

/* Bandeau image (Option 4) */
.sl-banner{max-width:1100px;margin:14px auto 0;padding:0 18px}
.sl-banner img{width:100%;height:auto;max-height:320px;object-fit:cover;border-radius:18px;border:1px solid var(--sl-border);display:block}
.sl-logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.2px}
.sl-mark{width:28px;height:28px;border-radius:10px;
  background: linear-gradient(135deg, var(--sl-accent), var(--sl-accent2));
  box-shadow: 0 10px 30px rgba(176,123,255,.25);
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.sl-mark img{width:100%;height:100%;object-fit:cover;display:block}
.sl-nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sl-nav a{padding:8px 10px;border-radius:10px;color:var(--sl-muted)}
.sl-nav a:hover{background:rgba(255,255,255,.06);color:var(--sl-text)}

.sl-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 14px;border-radius:14px;border:1px solid var(--sl-border);
  background:rgba(255,255,255,.06);color:var(--sl-text);
}
.sl-btn:hover{background:rgba(255,255,255,.10)}
.sl-btn--primary{border:none;background:linear-gradient(135deg, var(--sl-accent), var(--sl-accent2));}
.sl-btn--primary:hover{filter:brightness(1.03)}

.sl-hero{padding:46px 0 26px}
.sl-hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:18px;align-items:stretch}
@media (max-width:900px){.sl-hero-grid{grid-template-columns:1fr}}

.sl-hero-card{
  border:1px solid var(--sl-border);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border-radius:22px;
  overflow:hidden;
  position:relative;
}
.sl-hero-media{
  height:240px;
  background-image:
    linear-gradient(135deg, rgba(0,0,0,.25), rgba(0,0,0,.55)),
    url(assets/option4-banner.png);
  background-size: cover;
  background-position: center;
}
.sl-hero-content{position:relative;padding:22px 22px 20px}
.sl-hero-photo{
  width:100%;
  height:170px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--sl-border);
  background:rgba(0,0,0,.10);
  box-shadow: 0 14px 40px rgba(0,0,0,.35);
  margin:0 0 16px;
}
.sl-hero-photo img{opacity:1}
.sl-hero-photo img{width:100%;height:100%;object-fit:cover;display:block;opacity:.95}

/* Mobile: on remonte légèrement le cadrage pour mieux voir les visages/haut de l'image */
@media (max-width: 560px){
  .sl-hero-photo{height:170px}
  .sl-hero-photo img{object-position:50% 25%}
}

@media (max-width: 480px){
  .sl-title{font-size:32px}
  .sl-hero{padding:32px 0 18px}
  .sl-hero-media{height:190px}
  .sl-banner img{max-height:240px}
  .sl-topbar-inner{padding:12px 0}
}
.sl-title{font-size:42px;line-height:1.05;margin:0 0 10px}
.sl-home-banner{
  margin:10px 0 14px;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(255,255,255,.18);
  background: linear-gradient(180deg, rgba(255,140,0,.28), rgba(255,140,0,.14));
  box-shadow: 0 12px 30px rgba(0,0,0,.28);
}
.sl-home-banner__sub{margin-top:6px;font-size:13px;opacity:.92;line-height:1.35}
.sl-subtitle{margin:0 0 18px;color:var(--sl-muted);max-width:58ch}
.sl-cta{display:flex;gap:10px;flex-wrap:wrap}

.sl-side{
  border:1px solid var(--sl-border);
  background:rgba(255,255,255,.04);
  border-radius:22px;
  padding:18px;
}
.sl-kicker{color:var(--sl-muted);font-size:13px;margin:0 0 8px}
.sl-side h3{margin:0 0 10px;font-size:18px}
.sl-side p{margin:0 0 12px;color:var(--sl-muted)}

.sl-section{padding:22px 0}
.sl-section h2{margin:0 0 12px;font-size:22px}
.sl-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:900px){.sl-grid3{grid-template-columns:1fr}}
.sl-tile{border:1px solid var(--sl-border);background:rgba(255,255,255,.04);border-radius:18px;padding:16px}
.sl-tile h4{margin:0 0 8px}
.sl-tile p{margin:0;color:var(--sl-muted)}

.sl-footer{border-top:1px solid var(--sl-border);padding:22px 0;margin-top:28px;color:var(--sl-muted)}

/* Shortcodes (plugin) */
.sl-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media (max-width:900px){.sl-cards{grid-template-columns:1fr}}
.sl-card{border:1px solid var(--sl-border);background:rgba(255,255,255,.04);border-radius:18px;padding:14px;display:flex;gap:12px;align-items:flex-start}
.sl-ava{width:54px;height:54px;border-radius:16px;overflow:hidden;flex:0 0 auto;border:1px solid var(--sl-border);background:rgba(255,255,255,.04)}
.sl-ava img{width:100%;height:100%;object-fit:cover}
.sl-card h5{margin:0 0 4px;font-size:16px}
.sl-meta{margin:0;color:var(--sl-muted);font-size:13px}
.sl-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.sl-badge{font-size:12px;padding:5px 9px;border-radius:999px;border:1px solid var(--sl-border);background:rgba(255,255,255,.05)}
.sl-badge--mauve{border:none;background:rgba(176,123,255,.20)}
.sl-badge--green{border:none;background:rgba(0,255,160,.14)}

.sl-toggle{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:1px solid var(--sl-border);
  background:rgba(255,255,255,.04);
  border-radius:18px;
  padding:14px;
}
.sl-toggle small{color:var(--sl-muted)}
.sl-switch{cursor:pointer;display:inline-flex;align-items:center;gap:10px}
.sl-pill{width:46px;height:26px;border-radius:999px;border:1px solid var(--sl-border);background:rgba(255,255,255,.05);position:relative}
.sl-dot{width:20px;height:20px;border-radius:999px;background:rgba(255,255,255,.70);position:absolute;top:2px;left:2px;transition:all .18s ease}
.sl-pill[data-on="1"]{background:rgba(176,123,255,.20);border-color:rgba(176,123,255,.35)}
.sl-pill[data-on="1"] .sl-dot{left:24px;background:rgba(176,123,255,.95)}

/* Statuts membres */
.sl-status-dots{display:flex;gap:6px;align-items:center;margin-top:6px}
.sl-status-dot{width:10px;height:10px;border-radius:999px;display:inline-block;box-shadow:0 0 0 2px rgba(255,255,255,.08) inset}
.sl-status-dot--green{background:#2ecc71}
.sl-status-dot--purple{background:#b45cff}

/* Actions profil (cadenas / blocage) */
.sl-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.sl-icon-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:inherit;text-decoration:none}
.sl-icon-btn:hover{background:rgba(255,255,255,.10)}
.sl-icon{font-size:18px;line-height:1}









/* Badges & notifications */
.sl-badge{
  display:inline-flex;
  min-width:18px;
  height:18px;
  padding:0 6px;
  border-radius:999px;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:800;
  background:#ff2d2d;
  color:#fff;
  margin-left:6px;
}
.sl-notif-panel{
  position:absolute;
  right:16px;
  top:62px;
  width:min(340px, calc(100vw - 32px));
  background:rgba(15,15,20,.98);
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  box-shadow:0 12px 40px rgba(0,0,0,.45);
  padding:10px;
  z-index:9999;
}
.sl-notif-item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding:8px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  margin:6px 0;
}
.sl-notif-item b{font-size:13px}
.sl-notif-actions{display:flex;gap:8px}
.sl-notif-actions .sl-btn{padding:8px 10px}


/* Libre ce soir toggle (header) */
.sl-free-toggle{display:inline-flex;align-items:center;margin-right:8px}
.sl-mini-light{width:10px;height:10px;border-radius:999px;display:inline-block;background:rgba(180,140,255,.25);box-shadow:none;}
.sl-mini-light.is-on{background:rgba(180,140,255,.95);box-shadow:0 0 10px rgba(180,140,255,.95), 0 0 18px rgba(180,140,255,.45);}

.sl-state{font-size:12px;opacity:.85;margin-left:8px}


/* Langues (sélecteur Google Translate discret) */
.sl-lang{margin-left:auto}
.sl-lang-select{appearance:none;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.08);color:var(--sl-text);padding:8px 12px;min-width:160px;max-width:190px}
.sl-lang-select:focus{outline:2px solid rgba(255,255,255,.35);outline-offset:2px}
.goog-te-banner-frame.skiptranslate{display:none!important}
body{top:0!important}
@media (max-width:780px){.sl-topbar-inner{align-items:flex-start}.sl-lang{order:3;margin-left:0;width:100%}.sl-lang-select{width:100%;max-width:none}}

/* Liens réseaux */
.sl-social-links-wrap{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:14px}
.sl-social-links-title{font-size:12px;letter-spacing:.03em;text-transform:uppercase;opacity:.82;color:#f3bfd6}
.sl-social-links{display:flex;gap:8px;flex-wrap:wrap}
.sl-social-link{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border-radius:999px;background:rgba(255,90,160,.16);border:1px solid rgba(255,150,200,.32);color:#ffd7e8;text-decoration:none;font-size:13px;line-height:1;box-shadow:0 8px 22px rgba(0,0,0,.14)}
.sl-social-link:hover{transform:translateY(-1px);background:rgba(255,90,160,.22)}
.sl-social-link__icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:rgba(255,255,255,.14);font-size:12px;font-weight:700}
.sl-social-link__label{white-space:nowrap}

/* Avis */
.sl-avis-form textarea{width:100%;min-height:78px;resize:vertical;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.12);color:inherit;padding:10px 12px;box-sizing:border-box}
.sl-avis-form .sl-btn{margin-top:8px}
.sl-avis-list{margin-top:10px;max-height:190px;overflow:auto;padding-right:6px}
.sl-avis-item{padding:10px 0;border-top:1px solid rgba(255,255,255,.10)}
.sl-avis-item:first-child{border-top:0;padding-top:0}
.sl-avis-meta{opacity:.75;font-size:12px;margin-bottom:4px}
.sl-avis-text{font-size:14px;line-height:1.35}
.sl-avis-login{opacity:.8;margin:0}
.sl-avis--site-reviews[open] .sl-details__content{display:block}
.sl-avis-note{opacity:.85;margin:0 0 12px}
.sl-site-reviews-summary,.sl-site-reviews-list,.sl-site-reviews-form{margin-top:12px}
.sl-site-reviews-form input:not([type="checkbox"]):not([type="radio"]),.sl-site-reviews-form textarea,.sl-site-reviews-form select{width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.12);color:inherit;padding:10px 12px;box-sizing:border-box}
.sl-site-reviews-form textarea{min-height:110px;resize:vertical}


/* Mobile header compact */
.sl-desktop-nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.sl-mobile-nav{display:none}
.sl-mobile-menu{position:relative}
.sl-mobile-menu summary{list-style:none;cursor:pointer}
.sl-mobile-menu summary::-webkit-details-marker{display:none}
.sl-mobile-menu__panel{position:absolute;left:0;top:calc(100% + 8px);min-width:220px;display:grid;gap:8px;padding:10px;border-radius:18px;border:1px solid rgba(255,255,255,.14);background:rgba(15,15,20,.98);box-shadow:0 12px 40px rgba(0,0,0,.45);z-index:40}

@media (max-width:780px){
  .sl-topbar-inner{display:grid;grid-template-columns:auto 1fr;align-items:center;gap:10px;padding:10px 0}
  .sl-logo{min-width:0;font-size:15px;gap:8px}
  .sl-logo span:last-child{font-size:14px;line-height:1.05}
  .sl-lang{order:2;grid-column:2;justify-self:end;width:auto;max-width:170px;margin-left:0}
  .sl-lang-select{width:auto;min-width:0;max-width:170px;padding:7px 10px;font-size:14px}
  .sl-nav{order:3;grid-column:1 / -1;width:100%}
  .sl-desktop-nav{display:none}
  .sl-mobile-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}
  .sl-mobile-nav > .sl-btn,
  .sl-mobile-menu > .sl-btn{padding:9px 12px;border-radius:12px}
  .sl-mobile-menu__panel{right:auto;width:min(260px,calc(100vw - 36px))}
}
