@charset "UTF-8";
/* ── WP BaZi Claude — Thème natal ─────────────────────────────────────────── */

:root {
  --bz-accent:    #1a3a5c;
  --bz-accent2:   #c0872a;
  --bz-bg:        #ffffff;
  --bz-bg-alt:    #f8f8f6;
  --bz-border:    #e0ddd5;
  --bz-text:      #1a1a1a;
  --bz-text-muted:#7a7a7a;
  --bz-radius:    6px;
  --bz-bois:      #4a7c59;
  --bz-feu:       #c0392b;
  --bz-terre:     #c8a84b;
  --bz-metal:     #8e8e8e;
  --bz-eau:       #2980b9;
}

.wpbazi-widget {
  font-family: 'Georgia', serif;
  max-width: 860px;
  margin: 0 auto;
  background: var(--bz-bg);
  border: 1px solid var(--bz-border);
  border-radius: var(--bz-radius);
  overflow: hidden;
}

/* ── Header ── */
.wpbazi-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 20px;
  background: var(--bz-accent);
  color: #fff;
}
.wpbazi-title-zh { font-size: 1.2rem; font-weight: bold; margin-right: 6px; }
.wpbazi-title-sep { opacity: .5; margin: 0 6px; }
.wpbazi-title-fr  { font-size: .9rem; opacity: .85; }
.wpbazi-script-toggle { display: flex; gap: 4px; }
.wpbazi-script-btn {
  background: transparent; border: 1px solid rgba(255,255,255,.4);
  color: rgba(255,255,255,.7); padding: 3px 10px; border-radius: 4px; cursor: pointer;
  font-size: .85rem; transition: all .15s;
}
.wpbazi-script-btn.active { background: rgba(255,255,255,.2); color: #fff; border-color: rgba(255,255,255,.7); }

/* ── Formulaire ── */
.wpbazi-form { padding: 20px; border-bottom: 1px solid var(--bz-border); }
.wpbazi-form-row { margin-bottom: 14px; }
.wpbazi-label { display: block; font-size: .78rem; text-transform: uppercase; letter-spacing: .05em; color: var(--bz-text-muted); margin-bottom: 6px; }
.wpbazi-input { width: 100%; padding: 8px 12px; border: 1px solid var(--bz-border); border-radius: var(--bz-radius); font-size: .95rem; }
.wpbazi-input-sm { width: 90px; padding: 6px 8px; border: 1px solid var(--bz-border); border-radius: var(--bz-radius); font-size: .85rem; }

/* Segments */
.wpbazi-seg { display: flex; gap: 6px; flex-wrap: wrap; }
.wpbazi-seg-btn {
  padding: 7px 14px; border: 1px solid var(--bz-border); border-radius: var(--bz-radius);
  background: var(--bz-bg-alt); cursor: pointer; font-size: .85rem; transition: all .15s;
}
.wpbazi-seg-btn.active { background: var(--bz-accent); color: #fff; border-color: var(--bz-accent); }
.wpbazi-seg-main { display: block; font-weight: 600; }
.wpbazi-seg-sub  { display: block; font-size: .72rem; opacity: .7; }

/* Ville */
.wpbazi-city-wrap { position: relative; }
.wpbazi-suggestions {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 100;
  background: #fff; border: 1px solid var(--bz-border); border-radius: var(--bz-radius);
  list-style: none; margin: 0; padding: 0; display: none; max-height: 200px; overflow-y: auto;
}
.wpbazi-suggestions li { padding: 8px 12px; cursor: pointer; border-bottom: 1px solid var(--bz-border); }
.wpbazi-suggestions li:hover { background: var(--bz-bg-alt); }
.wpbazi-sugg-name { font-weight: 600; display: block; }
.wpbazi-sugg-detail { font-size: .8rem; color: var(--bz-text-muted); }
.wpbazi-no-result { color: var(--bz-text-muted); font-style: italic; }
.wpbazi-selected-city { display: flex; align-items: center; gap: 8px; padding: 6px 0; font-size: .9rem; }
.wpbazi-clear-city { background: none; border: none; color: var(--bz-text-muted); cursor: pointer; font-size: 1.1rem; }
.wpbazi-coords-row { display: flex; align-items: center; gap: 12px; margin-top: 8px; font-size: .85rem; flex-wrap: wrap; }
.wpbazi-tz-display { color: var(--bz-accent); font-weight: 600; }

/* Bouton calculer */
.wpbazi-form-actions { margin-top: 16px; }
.wpbazi-btn-calc {
  background: var(--bz-accent); color: #fff; border: none; border-radius: var(--bz-radius);
  padding: 10px 24px; font-size: .95rem; cursor: pointer; font-family: inherit; transition: opacity .15s;
}
.wpbazi-btn-calc:hover { opacity: .85; }
.wpbazi-error { margin-top: 10px; padding: 8px 12px; background: #fdecea; border-left: 3px solid var(--bz-feu); border-radius: var(--bz-radius); font-size: .85rem; color: var(--bz-feu); }

/* ── Résultats ── */
.wpbazi-results { padding: 0; }
.wpbazi-section { padding: 20px; border-bottom: 1px solid var(--bz-border); }
.wpbazi-section:last-child { border-bottom: none; }
.wpbazi-section-title { font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--bz-text-muted); margin: 0 0 16px; }

/* ── Piliers ── */
.wpbazi-pillars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.wpbazi-pillar {
  min-width: 0; text-align: center; padding: 16px 10px;
  border-right: 1px solid var(--bz-border); position: relative;
}
.wpbazi-pillar:last-child { border-right: none; }
.wpbazi-pillar-day { background: var(--bz-bg-alt); }
.wpbazi-pillar-label { font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; color: var(--bz-text-muted); margin-bottom: 8px; }
.wpbazi-gz { display: flex; flex-direction: column; align-items: center; gap: 4px; margin-bottom: 8px; }
.wpbazi-gan, .wpbazi-zhi { font-size: 2rem; font-weight: bold; line-height: 1; }
.wpbazi-big { font-size: 2.8rem; }
.wpbazi-pinyin { font-size: .68rem; color: var(--bz-text-muted); margin-bottom: 4px; word-break: break-word; }
.wpbazi-elem-label { font-size: .68rem; color: var(--bz-text-muted); word-break: break-word; }
.wpbazi-canggan { display: flex; flex-wrap: wrap; justify-content: center; gap: 4px; margin-top: 10px; }
.wpbazi-cg-item { display: inline-flex; flex-direction: column; align-items: center; font-size: .9rem; font-weight: 600; padding: 4px 6px; background: var(--bz-bg-alt); border-radius: 4px; min-width: 32px; }
.wpbazi-rizhu-badge { font-size: .65rem; color: var(--bz-accent2); font-weight: 700; letter-spacing: .05em; margin-top: 6px; }
.wpbazi-kw-strip { width: 100%; text-align: center; padding: 8px; font-size: .8rem; color: var(--bz-text-muted); border-top: 1px dashed var(--bz-border); margin-top: 8px; }
.wpbazi-kw-py { font-size: .72rem; }

/* Couleurs éléments */
.bz-bois  { color: var(--bz-bois); }
.bz-feu   { color: var(--bz-feu); }
.bz-terre { color: var(--bz-terre); }
.bz-metal { color: var(--bz-metal); }
.bz-eau   { color: var(--bz-eau); }

/* ── Jour maître ── */
.wpbazi-rizhu-box { display: flex; gap: 24px; align-items: flex-start; }
.wpbazi-rizhu-gz { text-align: center; min-width: 80px; }
.wpbazi-rizhu-elem { font-size: .8rem; color: var(--bz-text-muted); margin-top: 4px; }
.wpbazi-rizhu-stats { flex: 1; }
.wpbazi-stat-row { display: flex; justify-content: space-between; padding: 5px 0; border-bottom: 1px solid var(--bz-border); font-size: .85rem; }
.wpbazi-stat-row:last-child { border-bottom: none; }
.wpbazi-stat-label { color: var(--bz-text-muted); }
.wpbazi-stat-total .wpbazi-stat-label { font-weight: 600; color: var(--bz-text); }
.wpbazi-strength-label { font-weight: 700; text-transform: uppercase; font-size: .78rem; letter-spacing: .05em; color: var(--bz-accent); }
.wpbazi-strength-bar { height: 6px; background: var(--bz-border); border-radius: 3px; margin-top: 10px; overflow: hidden; }
.wpbazi-strength-fill { height: 100%; border-radius: 3px; transition: width .4s ease; }

/* ── 5 Éléments ── */
.wpbazi-elem-bars { display: flex; flex-direction: column; gap: 10px; margin-bottom: 14px; }
.wpbazi-elem-bar-wrap { display: flex; align-items: center; gap: 10px; }
.wpbazi-elem-bar-label { min-width: 90px; font-size: .82rem; }
.wpbazi-elem-bar-track { flex: 1; height: 14px; background: var(--bz-border); border-radius: 7px; overflow: hidden; }
.wpbazi-elem-bar-fill { height: 100%; border-radius: 7px; transition: width .5s ease; }
.wpbazi-elem-bar-score { min-width: 38px; text-align: right; font-size: .8rem; color: var(--bz-text-muted); }
.wpbazi-elem-summary { font-size: .85rem; padding: 8px 0; }
.wpbazi-elem-dominant { color: var(--bz-accent); }
.wpbazi-elem-missing  { color: var(--bz-feu); }

/* ── Interactions ── */
.wpbazi-ix-group { margin-bottom: 14px; }
.wpbazi-ix-title { font-size: .75rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 700; margin-bottom: 8px; }
.wpbazi-ix-items { display: flex; flex-wrap: wrap; gap: 6px; }
.wpbazi-ix-item { padding: 4px 10px; border-radius: 4px; font-size: .82rem; }
.wpbazi-ix-pos   { font-weight: 600; margin-right: 4px; }
.wpbazi-ix-label { opacity: .8; }
.wpbazi-no-ix    { color: var(--bz-text-muted); font-style: italic; font-size: .85rem; }

.ix-he     { background: #eaf4ed; color: #2d6a4f; }
.ix-chong  { background: #fdecea; color: #922b21; }
.ix-sanhe  { background: #fef9e7; color: #7d6608; }
.ix-xing   { background: #fde8f4; color: #7b2d6d; }
.ix-hai    { background: #ede8fd; color: #4a2d7b; }

/* ── Loading ── */
.wpbazi-loading { padding: 20px; text-align: center; color: var(--bz-text-muted); font-size: .9rem; }
.wpbazi-spinner {
  display: inline-block; width: 16px; height: 16px; border: 2px solid var(--bz-border);
  border-top-color: var(--bz-accent); border-radius: 50%; animation: wpbazi-spin .7s linear infinite; vertical-align: middle; margin-right: 6px;
}
@keyframes wpbazi-spin { to { transform: rotate(360deg); } }

/* ── Responsive ── */
@media (max-width: 600px) {
  .wpbazi-pillars { gap: 0; }
  .wpbazi-pillar  { padding: 10px 4px; }
  .wpbazi-gan, .wpbazi-zhi { font-size: 1.5rem; }
  .wpbazi-rizhu-box { flex-direction: column; }
  .wpbazi-coords-row { gap: 8px; }
}

/* ── DàYùn ────────────────────────────────────────────────────────────────── */

/* Bande natale résumé */
.wpbazi-natal-strip { display: flex; gap: 0; border: 1px solid var(--bz-border); border-radius: var(--bz-radius); overflow: hidden; }
.wpbazi-strip-pillar { flex: 1; text-align: center; padding: 10px 6px; border-right: 1px solid var(--bz-border); }
.wpbazi-strip-pillar:last-child { border-right: none; }
.wpbazi-strip-day { background: var(--bz-bg-alt); }
.wpbazi-strip-label { font-size: .68rem; color: var(--bz-text-muted); margin-bottom: 4px; }

/* Meta */
.wpbazi-dayun-meta-box { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.wpbazi-meta-row { display: flex; flex-direction: column; padding: 8px 12px; background: var(--bz-bg-alt); border-radius: var(--bz-radius); font-size: .82rem; }
.wpbazi-meta-row span { color: var(--bz-text-muted); font-size: .72rem; margin-bottom: 3px; }
.wpbazi-meta-row strong { color: var(--bz-accent); }

/* Timeline cycles */
.wpbazi-timeline { display: flex; gap: 0; overflow-x: auto; padding-bottom: 4px; }
.wpbazi-cycle {
  flex: 0 0 88px; text-align: center; padding: 12px 6px;
  border: 1px solid var(--bz-border); border-right: none; position: relative;
  transition: background .15s;
}
.wpbazi-cycle:last-child { border-right: 1px solid var(--bz-border); }
.wpbazi-cycle-active { background: #fffbf0; border-color: var(--bz-accent2); box-shadow: inset 0 0 0 1px var(--bz-accent2); }
.wpbazi-cycle-ages  { font-size: .68rem; font-weight: 700; color: var(--bz-text-muted); margin-bottom: 2px; }
.wpbazi-cycle-years { font-size: .62rem; color: var(--bz-text-muted); margin-bottom: 8px; }
.wpbazi-cycle-gz    { display: flex; flex-direction: column; align-items: center; gap: 2px; margin-bottom: 4px; }
.wpbazi-cycle-gz .wpbazi-gan,
.wpbazi-cycle-gz .wpbazi-zhi { font-size: 1.5rem; font-weight: bold; line-height: 1.1; }
.wpbazi-cycle-pinyin { font-size: .6rem; color: var(--bz-text-muted); margin-bottom: 6px; }
.wpbazi-cycle-cg    { display: flex; justify-content: center; gap: 3px; font-size: .75rem; font-weight: 600; }
.wpbazi-cycle-badge { position: absolute; bottom: 4px; left: 0; right: 0; text-align: center; font-size: .6rem; font-weight: 700; color: var(--bz-accent2); text-transform: uppercase; letter-spacing: .05em; }

/* 流年 */
.wpbazi-liunian { display: flex; flex-wrap: wrap; gap: 6px; }
.wpbazi-liunian-year {
  min-width: 64px; text-align: center; padding: 8px 6px;
  border: 1px solid var(--bz-border); border-radius: var(--bz-radius);
  background: var(--bz-bg-alt);
}
.wpbazi-liunian-current { background: #fffbf0; border-color: var(--bz-accent2); }
.wpbazi-ly-year { font-size: .72rem; font-weight: 700; color: var(--bz-text-muted); margin-bottom: 3px; }
.wpbazi-ly-age  { font-size: .65rem; color: var(--bz-text-muted); margin-bottom: 4px; }
.wpbazi-ly-gz   { font-size: 1.1rem; font-weight: bold; }

@media (max-width: 600px) {
  .wpbazi-dayun-meta-box { grid-template-columns: 1fr; }
  .wpbazi-cycle { flex: 0 0 72px; }
}

/* ── Onglets ────────────────────────────────────────────────────────────────── */
.wpbazi-tabs { display: flex; border-bottom: 2px solid var(--bz-border); background: var(--bz-bg-alt); }
.wpbazi-tab-btn { flex: 1; padding: 12px 16px; border: none; background: none; cursor: pointer; font-size: .88rem; font-family: inherit; color: var(--bz-text-muted); border-bottom: 2px solid transparent; margin-bottom: -2px; transition: all .15s; }
.wpbazi-tab-btn.active { color: var(--bz-accent); border-bottom-color: var(--bz-accent); font-weight: 600; background: var(--bz-bg); }

/* ── Compat formulaire ──────────────────────────────────────────────────────── */
.wpbazi-compat-form { padding: 20px; border-bottom: 1px solid var(--bz-border); }
.wpbazi-compat-persons { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 16px; }
.wpbazi-person-form { padding: 16px; border: 1px solid var(--bz-border); border-radius: var(--bz-radius); }
.wpbazi-person-title { font-size: .85rem; font-weight: 700; color: var(--bz-accent); margin: 0 0 14px; }
.wpbazi-compat-form-actions { display: flex; align-items: flex-end; gap: 16px; flex-wrap: wrap; }
.wpbazi-btn-compat { background: var(--bz-accent2); color: #fff; border: none; border-radius: var(--bz-radius); padding: 10px 24px; font-size: .95rem; cursor: pointer; font-family: inherit; transition: opacity .15s; }
.wpbazi-btn-compat:hover { opacity: .85; }
.wpbazi-compat-error { margin-top: 10px; padding: 8px 12px; background: #fdecea; border-left: 3px solid var(--bz-feu); border-radius: var(--bz-radius); font-size: .85rem; color: var(--bz-feu); }

/* ── Score ──────────────────────────────────────────────────────────────────── */
.wpbazi-score-box { max-width: 400px; }
.wpbazi-score-gauge { height: 12px; background: var(--bz-border); border-radius: 6px; overflow: hidden; margin-bottom: 10px; }
.wpbazi-score-fill { height: 100%; border-radius: 6px; transition: width .5s ease; }
.wpbazi-score-info { display: flex; align-items: baseline; gap: 12px; margin-bottom: 8px; }
.wpbazi-score-label { font-size: 1.1rem; font-weight: 700; }
.wpbazi-score-pct { font-size: .85rem; color: var(--bz-text-muted); }
.wpbazi-score-detail { display: flex; gap: 16px; font-size: .82rem; }
.wpbazi-score-harmony { color: var(--bz-bois); }
.wpbazi-score-tension { color: var(--bz-feu); }

/* ── Piliers compat ─────────────────────────────────────────────────────────── */
.wpbazi-compat-pillars-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.wpbazi-compat-person-label { font-size: .78rem; font-weight: 700; color: var(--bz-accent); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 10px; }
.wpbazi-compat-strip { display: flex; border: 1px solid var(--bz-border); border-radius: var(--bz-radius); overflow: hidden; }

/* ── Éléments compat ────────────────────────────────────────────────────────── */
.wpbazi-compat-elem-grid { display: flex; flex-direction: column; gap: 10px; }
.wpbazi-compat-elem-row { display: flex; align-items: center; gap: 10px; }
.wpbazi-compat-elem-name { min-width: 90px; font-size: .82rem; }
.wpbazi-compat-bar-wrap { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.wpbazi-compat-bar-a, .wpbazi-compat-bar-b { height: 7px; border-radius: 4px; transition: width .4s; min-width: 2px; }
.wpbazi-compat-elem-vals { min-width: 70px; text-align: right; font-size: .78rem; color: var(--bz-text-muted); }
.wpbazi-compat-complement { margin-top: 12px; padding: 8px 12px; background: #eaf4ed; border-radius: var(--bz-radius); font-size: .85rem; color: #2d6a4f; }

@media (max-width: 600px) {
  .wpbazi-compat-persons { grid-template-columns: 1fr; }
  .wpbazi-compat-pillars-wrap { grid-template-columns: 1fr; }
}

/* ── 12 Stades de Croissance ─────────────────────────────────────────────── */
.wpbazi-cs-toggle { display: flex; gap: 8px; margin-bottom: 14px; }
.wpbazi-cs-btn { padding: 6px 14px; border: 1px solid var(--bz-border); border-radius: var(--bz-radius); background: var(--bz-bg-alt); cursor: pointer; font-size: .82rem; font-family: inherit; transition: all .15s; }
.wpbazi-cs-btn.active { background: var(--bz-accent); color: #fff; border-color: var(--bz-accent); }
.wpbazi-cs-score { font-size: .85rem; margin-bottom: 14px; color: var(--bz-text-muted); }
.wpbazi-cs-score strong { color: var(--bz-accent); font-size: 1rem; }
.wpbazi-cs-grid { display: flex; gap: 0; }
.wpbazi-cs-pillar { flex: 1; text-align: center; padding: 12px 6px; border-right: 1px solid var(--bz-border); }
.wpbazi-cs-pillar:last-child { border-right: none; }
.wpbazi-cs-pos { font-size: .68rem; color: var(--bz-text-muted); text-transform: uppercase; margin-bottom: 6px; }
.wpbazi-cs-zhi { font-size: 1.4rem; font-weight: bold; margin-bottom: 8px; color: var(--bz-text); }
.wpbazi-cs-stade { font-size: 1.1rem; font-weight: 700; margin-bottom: 3px; }
.wpbazi-cs-py { font-size: .68rem; color: var(--bz-text-muted); margin-bottom: 3px; }
.wpbazi-cs-fr { font-size: .72rem; color: var(--bz-text-muted); margin-bottom: 8px; font-style: italic; }
.wpbazi-cs-score-val { display: inline-block; color: #fff; font-weight: 700; font-size: .85rem; padding: 2px 8px; border-radius: 10px; }

@media (max-width: 600px) {
  .wpbazi-cs-py, .wpbazi-cs-fr { display: none; }
  .wpbazi-cs-stade { font-size: .9rem; }
}

/* ── 10 Dieux (十神 Shí Shén) ─────────────────────────────────────────────── */
.wpbazi-shishen-label {
    display: block;
    text-align: center;
    margin-bottom: 6px;
    line-height: 1.3;
}
.wpbazi-cg-item .wpbazi-shishen-label {
    margin-bottom: 2px;
}
.wpbazi-cg-item {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding: 4px 6px;
    background: var(--bz-bg-alt);
    border-radius: 4px;
    font-size: .9rem;
    font-weight: 600;
    min-width: 32px;
}

/* ── Panneau Analyse (格局) ──────────────────────────────────────────────── */
.wpbazi-analyse-placeholder { padding: 24px; text-align: center; color: var(--bz-text-muted); font-size: .9rem; }
.wpbazi-analyse-hint strong { color: var(--bz-accent); }

.wpbazi-geguo-box { padding: 4px 0; }
.wpbazi-gg-name { font-size: 1.2rem; font-weight: 700; margin-bottom: 14px; }
.wpbazi-gg-badges { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.wpbazi-gg-badge { display: inline-block; padding: 4px 12px; border-radius: 20px; font-size: .78rem; font-weight: 600; }
.gg-good   { background: #eaf4ed; color: #2d6a4f; }
.gg-neutral{ background: #f0f0f0; color: #666; }
.gg-warn   { background: #fef3e2; color: #b45309; }
.gg-strong { background: #e8eaf6; color: #3949ab; }
.gg-weak   { background: #fce4ec; color: #c62828; }

.wpbazi-gg-conseil { font-size: .88rem; line-height: 1.6; color: var(--bz-text); background: var(--bz-bg-alt); padding: 12px 16px; border-radius: var(--bz-radius); border-left: 3px solid var(--bz-accent); margin-bottom: 16px; }

.wpbazi-gg-fav-wrap { margin-top: 8px; }
.wpbazi-gg-fav-label { font-size: .78rem; color: var(--bz-text-muted); margin-bottom: 8px; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.wpbazi-gg-fav { display: flex; gap: 8px; flex-wrap: wrap; }
.wpbazi-gg-elem { display: inline-block; padding: 6px 14px; border-radius: 20px; color: #fff; font-size: .85rem; font-weight: 700; }

/* ── Étoiles symboliques & sections analyse ─────────────────────────────── */
.wpbazi-gg-section { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--bz-border); }
.wpbazi-gg-section-title { font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; color: var(--bz-text-muted); margin-bottom: 12px; }
.wpbazi-gg-defav-label { font-size: .75rem; color: var(--bz-text-muted); margin: 8px 0 4px; }
.wpbazi-gg-defav .wpbazi-gg-elem { opacity: .5; }

.wpbazi-stars-list { display: flex; flex-direction: column; gap: 10px; }
.wpbazi-star-item { display: flex; align-items: flex-start; gap: 12px; padding: 10px 14px; background: var(--bz-bg-alt); border-radius: var(--bz-radius); }
.wpbazi-star-icon { font-size: 1.3rem; line-height: 1; flex-shrink: 0; }
.wpbazi-star-body { flex: 1; }
.wpbazi-star-name { font-size: .88rem; font-weight: 700; color: var(--bz-text); }
.wpbazi-star-pos { font-weight: 400; color: var(--bz-text-muted); font-size: .8rem; }
.wpbazi-star-desc { font-size: .8rem; color: var(--bz-text-muted); margin-top: 2px; }
.wpbazi-no-stars { font-size: .82rem; color: var(--bz-text-muted); font-style: italic; margin: 0; }

/* ── Transit 流年 ────────────────────────────────────────────────────────── */
.wpbazi-transit-box { }
.wpbazi-transit-year { font-size: 1.1rem; font-weight: 700; color: var(--bz-accent); margin-bottom: 14px; }
.wpbazi-transit-py { font-size: .8rem; font-weight: 400; color: var(--bz-text-muted); margin-left: 6px; }
.wpbazi-transit-list { display: flex; flex-direction: column; gap: 10px; }
.wpbazi-transit-item { display: flex; gap: 12px; padding: 12px 14px; border-radius: var(--bz-radius); border-left: 3px solid transparent; }
.transit-high     { background: #fdecea; border-color: #c0392b; }
.transit-medium   { background: #fef3e2; border-color: #c8a84b; }
.transit-positive { background: #eaf4ed; border-color: #4a7c59; }
.wpbazi-transit-icon { font-size: 1.2rem; flex-shrink: 0; line-height: 1.3; }
.wpbazi-transit-body { flex: 1; }
.wpbazi-transit-title { font-size: .88rem; font-weight: 700; color: var(--bz-text); }
.wpbazi-transit-on { font-weight: 400; }
.wpbazi-transit-scope { font-size: .75rem; color: var(--bz-text-muted); font-weight: 400; }
.wpbazi-transit-domain { font-size: .78rem; color: var(--bz-accent); font-weight: 600; margin: 2px 0; }
.wpbazi-transit-desc { font-size: .8rem; color: var(--bz-text-muted); line-height: 1.5; }
.wpbazi-transit-calm { display: flex; align-items: center; gap: 10px; padding: 14px; background: var(--bz-bg-alt); border-radius: var(--bz-radius); color: var(--bz-text-muted); font-size: .88rem; }
.wpbazi-transit-calm-icon { font-size: 1.4rem; }

/* ── Transitaire 流年 ────────────────────────────────────────────────────── */
.wpbazi-transit-header { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.wpbazi-transit-gz-pill { display: inline-block; padding: 4px 10px; background: var(--bz-bg-alt); border-radius: 12px; font-size: .78rem; }
.wpbazi-transit-py-sm { color: var(--bz-text-muted); font-size: .72rem; }
.wpbazi-transit-calm { display: flex; align-items: center; gap: 10px; padding: 14px; background: var(--bz-bg-alt); border-radius: var(--bz-radius); font-size: .88rem; color: var(--bz-text-muted); }
.wpbazi-transit-list { display: flex; flex-direction: column; gap: 8px; }
.wpbazi-transit-item { display: flex; align-items: flex-start; gap: 12px; padding: 10px 14px; border-radius: var(--bz-radius); border-left: 3px solid transparent; }
.transit-high     { background: #fdecea; border-left-color: #c0392b; }
.transit-positive { background: #eaf4ed; border-left-color: #4a7c59; }
.transit-medium   { background: #fef3e2; border-left-color: #c8a84b; }
.wpbazi-transit-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.wpbazi-transit-body { flex: 1; }
.wpbazi-transit-title { font-size: .85rem; font-weight: 700; color: var(--bz-text); margin-bottom: 2px; }
.wpbazi-transit-on { font-weight: 400; color: var(--bz-text-muted); }
.wpbazi-transit-gz-tag { font-weight: 700; color: var(--bz-accent); margin: 0 4px; }
.wpbazi-transit-scope { font-size: .72rem; background: var(--bz-bg); padding: 1px 6px; border-radius: 8px; color: var(--bz-text-muted); }
.wpbazi-transit-domain { font-size: .78rem; font-weight: 600; color: var(--bz-accent); margin-bottom: 2px; }
.wpbazi-transit-desc { font-size: .8rem; color: var(--bz-text-muted); }

/* ── Bouton PDF ─────────────────────────────────────────────────────────── */
.wpbazi-btn-pdf { background: #1a3a5c; color: #fff; border: none; border-radius: var(--bz-radius); padding: 10px 20px; font-size: .88rem; cursor: pointer; font-family: inherit; transition: opacity .15s; margin-left: 8px; }
.wpbazi-btn-pdf:hover { opacity: .85; }
.wpbazi-btn-pdf:disabled { opacity: .5; cursor: wait; }
