/*
Theme Name: PayQin Blog
Theme URI: https://payqin.com
Author: PayQin Team
Author URI: https://payqin.com
Description: Official PayQin Blog Theme — Modern, minimal, bilingual (EN/FR).
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: payqin-blog
*/

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --pq-teal: #0F7A5A;
  --pq-teal-light: #E6F5EF;
  --pq-teal-mid: #1D9E75;
  --pq-dark: #111410;
  --pq-gray: #6B6B68;
  --pq-line: rgba(0,0,0,0.08);
  --pq-bg: #FAFAF8;
}

body {
  font-family: 'DM Sans', system-ui, sans-serif;
  background: var(--pq-bg);
  color: var(--pq-dark);
  font-size: 15px;
  line-height: 1.6;
}

/* ── Nav ── */
.pq-nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(250,250,248,0.95);
  backdrop-filter: blur(12px);
  border-bottom: 0.5px solid var(--pq-line);
  padding: 0 2rem;
  display: flex; align-items: center; justify-content: space-between;
  height: 60px;
}
.pq-nav-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.pq-nav-logo-mark {
  width: 32px; height: 32px; border-radius: 8px;
  background: var(--pq-teal);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-family: 'DM Serif Display', serif; font-size: 16px; font-style: italic;
}
.pq-nav-logo-text { font-size: 17px; font-weight: 500; color: var(--pq-dark); }
.pq-nav-links { display: flex; gap: 24px; align-items: center; }
.pq-nav-links a { font-size: 13px; color: var(--pq-gray); text-decoration: none; transition: color .2s; }
.pq-nav-links a:hover, .pq-nav-links a.active { color: var(--pq-teal); }
.pq-lang-toggle { display: flex; gap: 2px; background: var(--pq-line); border-radius: 20px; padding: 3px; }
.pq-lang-btn {
  border: none; background: none; cursor: pointer;
  font-size: 12px; font-weight: 500;
  padding: 4px 10px; border-radius: 16px;
  color: var(--pq-gray); transition: all .2s;
}
.pq-lang-btn.active { background: #fff; color: var(--pq-dark); box-shadow: 0 1px 4px rgba(0,0,0,0.1); }

/* ── Layout ── */
.pq-container { max-width: 1160px; margin: 0 auto; padding: 0 2rem; }
.pq-section { padding: 3rem 0 0; }
.section-label {
  font-size: 11px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--pq-teal); margin-bottom: 1.5rem;
  display: flex; align-items: center; gap: 8px;
}
.section-label::after { content:''; flex:1; height:0.5px; background: var(--pq-teal); opacity:.3; }

/* ── Featured grid ── */
.featured-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1.5px; background: var(--pq-line);
  border: 0.5px solid var(--pq-line); border-radius: 16px; overflow: hidden;
}
.featured-main { grid-row: 1 / 3; }
.feat-card {
  background: var(--pq-bg); padding: 2rem;
  display: flex; flex-direction: column; gap: 12px;
  cursor: pointer; transition: background .2s; text-decoration: none;
}
.feat-card:hover { background: #fff; }
.feat-card.main {
  padding: 2.5rem; justify-content: flex-end;
  min-height: 360px; position: relative; overflow: hidden;
}
.feat-card.main::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(135deg, var(--pq-teal-light) 0%, transparent 60%);
  pointer-events:none;
}
.feat-card.main .card-inner { position: relative; }
.cat-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 500;
  background: var(--pq-teal-light); color: var(--pq-teal);
  border-radius: 4px; padding: 3px 8px; width: fit-content;
}
.card-title { font-family: 'DM Serif Display', serif; color: var(--pq-dark); line-height: 1.25; }
.feat-card.main .card-title { font-size: 2rem; margin-top: 8px; }
.feat-card:not(.main) .card-title { font-size: 1.1rem; }
.card-excerpt { font-size: 13px; color: var(--pq-gray); line-height: 1.55; }
.card-meta { font-size: 12px; color: var(--pq-gray); display: flex; gap: 12px; margin-top: 4px; }
.read-more { font-size: 12px; font-weight: 500; color: var(--pq-teal); text-decoration: none; margin-top: 4px; }

/* ── Category pills ── */
.categories-bar { display: flex; gap: 8px; flex-wrap: wrap; padding: 2rem 0 0; }
.cat-pill {
  border: 0.5px solid var(--pq-line); background: none; cursor: pointer;
  font-family: inherit; font-size: 13px; color: var(--pq-gray);
  border-radius: 20px; padding: 6px 16px; transition: all .2s;
}
.cat-pill:hover { border-color: var(--pq-teal); color: var(--pq-teal); }
.cat-pill.active { background: var(--pq-teal); color: #fff; border-color: var(--pq-teal); }

/* ── Articles grid ── */
.articles-grid {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 1px; background: var(--pq-line);
  border: 0.5px solid var(--pq-line); border-radius: 12px; overflow: hidden;
  margin-top: 1.5rem;
}
.art-card {
  background: var(--pq-bg); padding: 1.5rem;
  display: flex; flex-direction: column; gap: 10px;
  cursor: pointer; transition: background .2s; text-decoration: none;
}
.art-card:hover { background: #fff; }
.art-img {
  width: 100%; aspect-ratio: 16/9; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; font-size: 2rem;
}
.art-card .card-title { font-size: 1rem; }
.art-card .card-excerpt { font-size: 13px; color: var(--pq-gray); flex: 1; }

/* ── Newsletter ── */
.newsletter-wrap { padding: 3rem 0; }
.newsletter-card {
  background: var(--pq-dark); border-radius: 16px; padding: 3rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center;
}
.nl-title { font-family: 'DM Serif Display', serif; font-size: 1.9rem; color: #fff; line-height: 1.2; margin-bottom: 8px; }
.nl-sub { font-size: 14px; color: rgba(255,255,255,0.55); }
.nl-form { display: flex; gap: 8px; margin-top: 1rem; }
.nl-input {
  flex:1; background: rgba(255,255,255,0.08);
  border: 0.5px solid rgba(255,255,255,0.15); border-radius: 8px;
  padding: 12px 16px; font-family: inherit; font-size: 14px; color: #fff; outline: none;
}
.nl-input::placeholder { color: rgba(255,255,255,0.35); }
.nl-btn {
  background: var(--pq-teal-mid); color: #fff; border: none; border-radius: 8px;
  padding: 12px 20px; font-family: inherit; font-size: 14px; font-weight: 500;
  cursor: pointer; transition: background .2s;
}
.nl-btn:hover { background: var(--pq-teal); }
.nl-note { font-size: 11px; color: rgba(255,255,255,0.35); margin-top: 8px; }

/* ── About strip ── */
.about-strip {
  border-top: 0.5px solid var(--pq-line); padding: 2rem 0 4rem;
  display: flex; gap: 3rem; align-items: center;
}
.about-text { flex: 1; }
.about-text h3 { font-family: 'DM Serif Display', serif; font-size: 1.4rem; margin-bottom: 8px; }
.about-text p { font-size: 13px; color: var(--pq-gray); max-width: 480px; }
.about-links { display: flex; gap: 12px; margin-top: 16px; }
.about-link {
  font-size: 13px; color: var(--pq-teal); text-decoration: none;
  border: 0.5px solid var(--pq-teal); border-radius: 6px; padding: 6px 14px; transition: all .2s;
}
.about-link:hover { background: var(--pq-teal); color: #fff; }
.about-stat { text-align: center; }
.stat-num { font-family: 'DM Serif Display', serif; font-size: 2.2rem; color: var(--pq-teal); }
.stat-lbl { font-size: 12px; color: var(--pq-gray); margin-top: 2px; }

/* ── Footer ── */
.pq-footer {
  border-top: 0.5px solid var(--pq-line);
  padding: 1.5rem 2rem;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12px; color: var(--pq-gray);
}

/* ── Single post ── */
.post-header { padding: 3rem 0 2rem; }
.post-header .cat-badge { margin-bottom: 1rem; }
.post-title { font-family: 'DM Serif Display', serif; font-size: 2.5rem; line-height: 1.15; max-width: 720px; }
.post-meta { font-size: 13px; color: var(--pq-gray); margin-top: 1rem; display: flex; gap: 16px; }
.post-content { max-width: 720px; padding: 2rem 0 4rem; }
.post-content p { margin-bottom: 1.2rem; font-size: 16px; line-height: 1.75; }
.post-content h2 { font-family: 'DM Serif Display', serif; font-size: 1.6rem; margin: 2rem 0 1rem; }
.post-content h3 { font-family: 'DM Serif Display', serif; font-size: 1.25rem; margin: 1.5rem 0 0.75rem; }
.post-content img { width: 100%; border-radius: 12px; margin: 1.5rem 0; }

/* ── Lang toggle ── */
.fr { display: none; }
body.lang-fr .en { display: none; }
body.lang-fr .fr { display: block; }
body.lang-fr span.fr { display: inline; }
body.lang-fr span.en { display: none; }
span.en { display: inline; }

/* Brevo form styling */
form.sib_signup_form {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 1rem;
  flex-wrap: wrap;
}
input.sib-email-area {
  flex: 1 !important;
  background: rgba(255,255,255,0.15) !important;
  border: 1px solid rgba(255,255,255,0.3) !important;
  border-radius: 8px !important;
  padding: 12px 16px !important;
  color: #ffffff !important;
  font-size: 14px !important;
  outline: none !important;
  min-width: 200px !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2) !important;
}
input.sib-email-area::placeholder {
  color: rgba(255,255,255,0.45) !important;
}
input.sib-email-area:focus {
  border-color: rgba(255,255,255,0.6) !important;
  background: rgba(255,255,255,0.2) !important;
}
input.sib-default-btn {
  background: #1D9E75 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 12px 20px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background .2s !important;
}
input.sib-default-btn:hover {
  background: #0F7A5A !important;
}
p.sib-email-area {
  display: none !important;
}
div.sib_signup_form {
  padding: 0 !important;
  background: transparent !important;
}
.sib_signup_form label {
  display: none !important;
}
/* Fix hidden email field */
div.sib_signup_box_inside_2 {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
div.sib_signup_box_inside_2 p.sib-email-area {
  display: flex !important;
  flex: 1 !important;
  margin: 0 !important;
}
div.sib_signup_box_inside_2 p.sib-email-area input {
  width: 100% !important;
  height: 44px !important;
  background: rgba(255,255,255,0.15) !important;
  border: 1px solid rgba(255,255,255,0.4) !important;
  border-radius: 8px !important;
  padding: 0 16px !important;
  color: #ffffff !important;
  font-size: 14px !important;
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}
div.sib_signup_box_inside_2 p:not(.sib-email-area) {
  display: none !important;
}
div.sib_loader { display: none !important; }

/* Fix placeholder and border visibility */
div.sib_signup_box_inside_2 p.sib-email-area input::placeholder {
  color: rgba(255,255,255,0.5) !important;
  content: "your@email.com" !important;
}
div.sib_signup_box_inside_2 p.sib-email-area input:focus {
  border-color: rgba(255,255,255,0.7) !important;
  outline: none !important;
}
/* Success message */
div.sib-alert-message-success {
  display: block !important;
  color: #1D9E75 !important;
  font-size: 13px !important;
  margin-top: 8px !important;
  background: rgba(29,158,117,0.15) !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
}

/* Brevo success & error messages */
.sib-alert-message-success,
.sib_signup_form .entry__error,
.sib_signup_form .entry__success,
#sib-container .success-message,
div[class*="success"],
div[class*="alert-success"],
.sib_signup_form p.success {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  color: #ffffff !important;
  font-size: 13px !important;
  margin-top: 8px !important;
  background: rgba(29,158,117,0.25) !important;
  border-radius: 8px !important;
  padding: 8px 12px !important;
}
p.sib-email-area label {
  display: none !important;
}
/* ── PAYQIN BLOG IMPROVEMENTS ── */

/* Nav links — bolder, more spacing */
.pq-nav-links a {
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.2px !important;
  color: #444441 !important;
}
.pq-nav-links a:hover, .pq-nav-links a.active {
  color: #0F7A5A !important;
}

/* Featured section label — cleaner */
.section-label {
  font-size: 12px !important;
  letter-spacing: 1px !important;
  margin-bottom: 2rem !important;
}

/* Featured grid — remove background gap color */
.featured-grid {
  background: transparent !important;
  gap: 12px !important;
  border: none !important;
  border-radius: 16px !important;
}

/* All cards — more breathing room, no borders */
.feat-card, .art-card {
  border-radius: 12px !important;
  border: none !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.06) !important;
  transition: box-shadow .2s, transform .2s !important;
}
.feat-card:hover, .art-card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.1) !important;
  transform: translateY(-2px) !important;
  background: #fff !important;
}

/* Article grid — remove dividing lines, more padding */
.articles-grid {
  background: transparent !important;
  border: none !important;
  gap: 16px !important;
  margin-top: 2rem !important;
}
.art-card {
  padding: 0 !important;
  overflow: hidden !important;
  background: #fff !important;
}
.art-card .art-img {
  border-radius: 0 !important;
  margin-bottom: 0 !important;
}
.art-card > .cat-badge,
.art-card > .card-title,
.art-card > .card-excerpt,
.art-card > .card-meta {
  padding-left: 1.25rem !important;
  padding-right: 1.25rem !important;
}
.art-card > .cat-badge { padding-top: 1rem !important; }
.art-card > .card-meta { padding-bottom: 1.25rem !important; }

/* Featured main card — fix empty grey space */
.feat-card.main {
  min-height: 0 !important;
  height: 100% !important;
}
.featured-grid {
  align-items: stretch !important;
}
.featured-main {
  display: flex !important;
  flex-direction: column !important;
}
.featured-main .feat-card.main {
  flex: 1 !important;
  min-height: 0 !important;
}
/* Category pills — more refined */
.categories-bar {
  padding: 2rem 0 1rem !important;
  gap: 6px !important;
}
.cat-pill {
  font-size: 13px !important;
  padding: 5px 16px !important;
  border-radius: 20px !important;
  font-weight: 400 !important;
  border: 0.5px solid rgba(0,0,0,0.12) !important;
}
.cat-pill.active {
  font-weight: 500 !important;
  box-shadow: 0 1px 4px rgba(15,122,90,0.2) !important;
}

/* Post content — wider, more readable */
.post-content {
  max-width: 760px !important;
  font-size: 17px !important;
  line-height: 1.85 !important;
}
.post-title {
  font-size: 2.8rem !important;
  max-width: 760px !important;
}

/* Footer — slightly more padding */
.pq-footer {
  padding: 2rem !important;
  margin-top: 1rem !important;
}
/* About stats — center two items */
.about-strip {
  flex-wrap: wrap !important;
}
.about-stat {
  min-width: 120px !important;
  text-align: center !important;
}