/* ===== Phễu Giữ Gìn Hôn Nhân — giao diện chung ===== */
:root{
  --cream:#FBF6EE; --paper:#FFFFFF; --ink:#2C2722; --muted:#6E655B;
  --terra:#C1502E; --terra-d:#A23E20; --wine:#7B2D26; --gold:#D99A4E;
  --line:#EAddCB; --soft:#F4E9DA;
  --maxr:720px; --maxw:1060px;
  --shadow:0 10px 30px rgba(60,40,20,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue",system-ui,sans-serif;
  font-size:18px;line-height:1.75;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--terra-d);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxr);margin:0 auto;padding:0 20px}
.wrap-wide{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* Header / Footer */
.site-header{background:rgba(251,246,238,.92);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:50}
.site-header .bar{max-width:var(--maxw);margin:0 auto;padding:12px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{font-weight:800;color:var(--wine);letter-spacing:.3px;font-size:1.05rem}
.nav a{margin-left:18px;color:var(--ink);font-weight:600;font-size:.95rem}
.nav a:hover{color:var(--terra-d);text-decoration:none}
.site-footer{margin-top:64px;padding:36px 20px;background:var(--soft);
  border-top:1px solid var(--line);color:var(--muted);font-size:.9rem;text-align:center}

/* Hero */
.hero{background:linear-gradient(160deg,#FCEBD9 0%,#F7DCC4 55%,#F0CDb0 100%);
  padding:64px 0 56px;text-align:center}
.hero .eyebrow{color:var(--wine);font-weight:700;letter-spacing:2px;
  text-transform:uppercase;font-size:.8rem;margin-bottom:14px}
.hero h1{font-size:2.4rem;line-height:1.18;margin:.2em 0;color:var(--terra-d);
  letter-spacing:-.5px;font-weight:800}
.hero .sub{font-size:1.15rem;color:#5a4a3a;max-width:620px;margin:18px auto 0}

/* Buttons */
.btn{display:inline-block;background:var(--terra);color:#fff;font-weight:700;
  padding:15px 30px;border-radius:999px;border:none;cursor:pointer;font-size:1.05rem;
  box-shadow:var(--shadow);transition:transform .08s ease,background .2s}
.btn:hover{background:var(--terra-d);text-decoration:none;color:#fff;transform:translateY(-1px)}
.btn-lg{padding:18px 40px;font-size:1.15rem}
.btn-block{display:block;width:100%;text-align:center}
.btn-ghost{background:transparent;color:var(--terra-d);border:2px solid var(--terra);box-shadow:none}
.btn-ghost:hover{background:var(--terra);color:#fff}
.center{text-align:center}

/* Prose (bài viết, salepage) */
.prose{padding:40px 0 8px}
.prose h1{font-size:2rem;line-height:1.25;color:var(--terra-d);margin:.2em 0 .5em}
.prose h2{font-size:1.5rem;margin:1.8em 0 .5em;color:var(--wine);
  border-bottom:2px solid var(--soft);padding-bottom:.2em}
.prose h3{font-size:1.2rem;margin:1.5em 0 .4em;color:var(--ink)}
.prose p{margin:0 0 1.1em}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.3em}
.prose li{margin:.35em 0}
.prose strong{color:var(--wine)}
.prose blockquote{margin:1.4em 0;padding:14px 20px;background:var(--soft);
  border-left:4px solid var(--gold);border-radius:8px;color:#5a4a3a}
.prose img{border-radius:14px;box-shadow:var(--shadow);margin:1.4em auto}
.prose hr{border:none;border-top:1px solid var(--line);margin:2em 0}
.prose table{width:100%;border-collapse:collapse;margin:1.4em 0;font-size:.96rem}
.prose th,.prose td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.prose th{background:var(--soft)}

/* Cards / blog list */
.card{background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:22px 24px;box-shadow:var(--shadow)}
.section{padding:48px 0}
.section h2{font-size:1.6rem;color:var(--wine);text-align:center;margin:0 0 28px}
.cluster h3{color:var(--terra-d);margin:1.6em 0 .4em;font-size:1.1rem}
.post-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.post-list li{background:var(--paper);border:1px solid var(--line);border-radius:12px;
  padding:14px 18px;transition:transform .08s,box-shadow .2s}
.post-list li:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.post-list a{font-weight:600;color:var(--ink)}
.pillar{border-left:4px solid var(--terra)!important}
.post-meta{color:var(--muted);font-size:.85rem;margin:0 0 1.4em}

/* Opt-in form */
.optin{background:var(--paper);border:1px solid var(--line);border-radius:18px;
  padding:26px;box-shadow:var(--shadow);max-width:440px;margin:0 auto}
.optin h3{margin:0 0 8px;color:var(--wine)}
.optin input{width:100%;padding:14px 16px;margin:8px 0;border:1px solid var(--line);
  border-radius:10px;font-size:1rem;background:#fff}
.optin .privacy{font-size:.8rem;color:var(--muted);margin-top:10px;line-height:1.5}

/* Two-column hero for leadpage */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  padding:56px 0}
.split .cover{border-radius:16px;box-shadow:var(--shadow)}

/* Checklist */
.checklist{list-style:none;padding:0;margin:1.2em 0}
.checklist li{position:relative;padding:8px 0 8px 34px;margin:0}
.checklist li::before{content:"✓";position:absolute;left:0;top:8px;color:#fff;
  background:var(--terra);width:22px;height:22px;border-radius:50%;
  display:grid;place-items:center;font-size:.8rem;font-weight:700}

/* Pricing */
.pricetable{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:30px 0}
.price-col{background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:24px;text-align:center}
.price-col.featured{border:2px solid var(--terra);box-shadow:var(--shadow);position:relative}
.price-col.featured::before{content:"Chọn nhiều nhất";position:absolute;top:-12px;left:50%;
  transform:translateX(-50%);background:var(--terra);color:#fff;font-size:.72rem;
  font-weight:700;padding:4px 12px;border-radius:999px;white-space:nowrap}
.price-col h3{margin:.2em 0;color:var(--wine)}
.price-tag{font-size:1.5rem;font-weight:800;color:var(--terra-d);margin:.4em 0}

/* Safety box */
.safety{background:#FBEDE6;border:1px solid #E8B79F;border-left:5px solid var(--terra);
  border-radius:12px;padding:16px 20px;margin:1.6em 0;color:#6a3a28}
.safety strong{color:var(--terra-d)}

/* CTA band */
.cta-band{background:linear-gradient(160deg,var(--wine),#5c1f1a);color:#fff;
  text-align:center;padding:48px 20px;margin-top:48px}
.cta-band h2{color:#fff;margin:0 0 10px;font-size:1.7rem}
.cta-band p{color:#f3d9c9;max-width:560px;margin:0 auto 22px}

.note{color:var(--muted);font-size:.85rem}
.eyebrow{color:var(--wine);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:.78rem}

/* Mobile */
@media(max-width:760px){
  body{font-size:17px}
  .hero h1{font-size:1.85rem}
  .hero{padding:44px 0 40px}
  .split{grid-template-columns:1fr;gap:24px;padding:32px 0}
  .split .cover{max-width:300px;margin:0 auto}
  .pricetable{grid-template-columns:1fr}
  .nav a{margin-left:12px;font-size:.85rem}
  .brand{font-size:.95rem}
  .author-hero h1{font-size:1.5rem}
}

/* ===== Blog cá nhân ===== */
.author-hero{background:linear-gradient(160deg,#FCEBD9,#F5DAC2);padding:50px 0 42px;text-align:center;border-bottom:1px solid var(--line)}
.avatar-lg{width:124px;height:124px;border-radius:50%;object-fit:cover;object-position:top;
  margin:0 auto 16px;border:4px solid #fff;box-shadow:var(--shadow)}
.author-hero h1{margin:.1em 0;color:var(--terra-d);font-size:1.9rem}
.author-hero .role{color:var(--wine);font-weight:600;margin:.2em 0}
.author-hero .bio{max-width:560px;margin:14px auto 0;color:#5a4a3a}
.post-feed{display:grid;gap:22px;max-width:680px;margin:0 auto}
.post-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:24px 26px;box-shadow:var(--shadow);transition:transform .08s}
.post-card:hover{transform:translateY(-2px)}
.post-card h2{margin:0 0 .3em;font-size:1.3rem;line-height:1.35;border:none;padding:0}
.post-card h2 a{color:var(--ink)}
.post-card .excerpt{color:#5a4a3a;margin:.2em 0 .9em}
.post-card .more{font-weight:700}
.byline{display:flex;align-items:center;gap:12px;margin:0 0 24px;padding-bottom:18px;
  border-bottom:1px solid var(--line)}
.byline .avatar{width:50px;height:50px;border-radius:50%;object-fit:cover;object-position:top;
  margin:0;box-shadow:none}
.byinfo{display:flex;flex-direction:column;line-height:1.35}
.byname{font-weight:700;color:var(--ink)}
.bydate{font-size:.85rem;color:var(--muted)}
.prose p.lead{font-size:1.2rem;line-height:1.7;color:#473c30;font-weight:500;margin-bottom:1.2em}
.readmore{margin:40px auto 0;max-width:720px;background:var(--soft);border-radius:16px;padding:22px 28px}
.readmore h2{margin:0 0 .5em;font-size:1.15rem;color:var(--wine);border:none;padding:0}
.readmore ul{margin:0;padding-left:1.1em}
.readmore li{margin:.4em 0}
