@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: flex; gap: 0; }
.wpbazi-pillar {
  flex: 1; text-align: center; padding: 16px 8px;
  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: 10px; }
.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: .72rem; color: var(--bz-text-muted); margin-bottom: 4px; }
.wpbazi-elem-label { font-size: .72rem; color: var(--bz-text-muted); }
.wpbazi-canggan { display: flex; justify-content: center; gap: 4px; margin-top: 10px; }
.wpbazi-cg-item { font-size: .9rem; font-weight: 600; padding: 2px 5px; background: var(--bz-bg-alt); border-radius: 3px; }
.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; }
}
