/* ============================================================
   SIOW THEME — PAGE STYLES  (css/pages.css loaded via functions.php)
   All component & page-level styles beyond style.css base
============================================================ */

/* ── HOME · HERO ─────────────────────────────────────────── */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;overflow:hidden}
.hero-left{
  background:var(--ink);display:flex;flex-direction:column;
  justify-content:center;padding:9rem 5rem 5rem;
  position:relative;overflow:hidden;z-index:1;
}
.hero-left::after{
  content:'西';font-family:var(--zh);font-size:26rem;font-weight:300;
  color:rgba(255,255,255,.04);position:absolute;bottom:-3rem;right:-2rem;
  line-height:1;pointer-events:none;
}
.hero-eyebrow{
  font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.6rem;
  animation:fadeUp .7s .15s both;
}
.hero-h1{
  font-family:var(--serif);font-size:clamp(2.8rem,5vw,5.4rem);
  font-weight:300;line-height:1.08;color:var(--paper);margin-bottom:1.8rem;
  animation:fadeUp .7s .3s both;
}
.hero-h1 em{font-style:italic;color:var(--gold-lt)}
.hero-sub{
  font-size:.94rem;font-weight:300;line-height:1.78;
  color:rgba(247,244,239,.58);max-width:380px;margin-bottom:2.8rem;
  animation:fadeUp .7s .45s both;
}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap;animation:fadeUp .7s .6s both}
.hero-right{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:3rem 3.2rem}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,15,14,.9) 0%,rgba(15,15,14,.28) 42%,transparent 100%);z-index:1}
.hero-badge{position:relative;z-index:2;padding-top:1rem;border-top:1px solid rgba(184,149,58,.38);animation:fadeUp .7s .9s both;opacity:0}
.hero-badge-name{font-family:var(--serif);font-size:1.05rem;font-weight:300;color:var(--paper)}
.hero-badge-role{font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:.18rem}

/* ── HOME · TWO PILLARS ──────────────────────────────────── */
.intro-pillars{display:flex;flex-direction:column;gap:1.5rem}
.pillar-card{
  display:block;background:var(--cream);padding:2.5rem 2.2rem;
  position:relative;overflow:hidden;
  border-left:3px solid transparent;
  transition:border-color .25s,transform .25s,box-shadow .25s;
}
.pillar-card:hover{border-color:var(--gold);transform:translateY(-2px);box-shadow:0 10px 32px rgba(0,0,0,.07)}
.pillar-zh{
  font-family:var(--zh);font-size:7rem;font-weight:300;
  color:rgba(15,15,14,.06);position:absolute;bottom:-.8rem;right:.5rem;line-height:1;
  transition:color .3s;
}
.pillar-card:hover .pillar-zh{color:rgba(184,149,58,.1)}
.pillar-num{font-size:.65rem;letter-spacing:.2em;color:var(--gold);margin-bottom:.7rem;position:relative;z-index:1}
.pillar-title{font-family:var(--serif);font-size:1.35rem;font-weight:300;color:var(--ink);margin-bottom:.5rem;position:relative;z-index:1}
.pillar-desc{font-size:.82rem;font-weight:300;line-height:1.7;color:rgba(15,15,14,.58);position:relative;z-index:1}
.pillar-arrow{position:absolute;bottom:1.4rem;right:1.6rem;font-size:1.1rem;color:var(--gold);z-index:1;transition:transform .2s}
.pillar-card:hover .pillar-arrow{transform:translateX(4px)}

/* ── SHARED · TWO-COL ────────────────────────────────────── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.two-col.reverse{direction:rtl}
.two-col.reverse > *{direction:ltr}

/* ── SHARED · SERVICE VISUAL ─────────────────────────────── */
.service-visual{
  min-height:420px;display:flex;align-items:center;
  justify-content:center;position:relative;overflow:hidden;
  background:rgba(247,244,239,.04);border:1px solid rgba(184,149,58,.12);
}
.service-visual.dark{background:var(--ink);border-color:rgba(184,149,58,.1)}
.service-visual::before{
  content:attr(data-zh);font-family:var(--zh);font-size:18rem;font-weight:300;
  color:rgba(184,149,58,.08);position:absolute;line-height:1;
}
.sv-inner{position:relative;z-index:1;text-align:center}
.sv-num{font-family:var(--serif);font-size:4.5rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:.4rem}
.sv-title{font-family:var(--serif);font-size:1.1rem;font-weight:300;color:rgba(247,244,239,.5);line-height:1.35}

/* ── SHARED · CHECK LIST ─────────────────────────────────── */
.check-list{display:flex;flex-direction:column;gap:.5rem}
.check-item{display:flex;gap:.9rem;font-size:.86rem;font-weight:300;line-height:1.65;color:rgba(15,15,14,.65);align-items:flex-start}
.check-list.light .check-item{color:rgba(247,244,239,.6)}
.check{color:var(--gold);flex-shrink:0;font-weight:500;margin-top:.05rem}

/* ── SHARED · WHY / VALUES CARDS ────────────────────────── */
.four-col{display:grid;grid-template-columns:repeat(4,1fr);gap:1.8rem}
.why-card{padding:2.4rem 2rem;background:rgba(247,244,239,.04);border-top:2px solid var(--gold);transition:background .25s}
.why-card:hover{background:rgba(184,149,58,.07)}
.why-zh{font-family:var(--zh);font-size:3rem;color:var(--gold);margin-bottom:.6rem;line-height:1}
.why-title{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:var(--paper);margin-bottom:.6rem}
.why-desc{font-size:.8rem;font-weight:300;line-height:1.68;color:rgba(247,244,239,.48)}

/* light variant (used on cream bg) */
section:not(.dark) .why-card{background:var(--paper)}
section:not(.dark) .why-title{color:var(--ink)}
section:not(.dark) .why-desc{color:rgba(15,15,14,.55)}

/* ── HOME · CONTACT DETAILS ──────────────────────────────── */
.contact-details{margin-top:1.5rem}
.cd-row{display:flex;gap:1rem;margin-bottom:1.8rem;align-items:flex-start}
.cd-icon{width:32px;height:32px;border:1px solid;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.82rem}
.cd-label{font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;margin-bottom:.18rem}
.cd-val{font-size:.9rem;font-weight:300}
.cd-langs{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1.8rem}
.lang-tag{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border:1px solid rgba(184,149,58,.3);padding:.22rem .65rem}

/* ── BD · DIRECTION VISUAL ───────────────────────────────── */
.dir-visual{min-height:360px;display:flex;align-items:center;justify-content:center}
.dir-flow{display:flex;align-items:center;gap:2.5rem;text-align:center}
.dir-from,.dir-to{font-family:var(--serif);font-size:3rem;font-weight:300;color:var(--ink);line-height:1;display:flex;flex-direction:column;gap:.3rem}
.dir-from span,.dir-to span{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(15,15,14,.4);font-family:var(--sans)}
.dir-arrow{font-size:2rem;color:var(--gold);font-family:var(--sans)}

/* ── BD · PROCESS STEPS ──────────────────────────────────── */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(15,15,14,.08)}
.process-step{background:var(--paper);padding:2.8rem 2.2rem}
.ps-num{font-family:var(--serif);font-size:3.5rem;font-weight:300;color:rgba(184,149,58,.25);line-height:1;margin-bottom:1.2rem}
.ps-title{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:var(--ink);margin-bottom:.7rem}
.ps-desc{font-size:.82rem;font-weight:300;line-height:1.7;color:rgba(15,15,14,.55)}

/* ── CONCIERGE ───────────────────────────────────────────── */
.concierge-features{display:flex;flex-direction:column;gap:1.4rem}
.cf-row{display:flex;gap:1.2rem;align-items:flex-start}
.cf-icon{font-size:1.1rem;flex-shrink:0;width:28px;text-align:center;margin-top:.1rem}
.cf-title{font-size:.86rem;font-weight:500;color:var(--paper);display:block;margin-bottom:.2rem}
section.cream .cf-title{color:var(--ink)}
.cf-desc{font-size:.8rem;font-weight:300;line-height:1.65;color:rgba(247,244,239,.52)}
section.cream .cf-desc{color:rgba(15,15,14,.55)}
.conc-visual{min-height:440px;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden}
.conc-visual::before{content:attr(data-label);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(184,149,58,.4);position:absolute;top:2rem;left:50%;transform:translateX(-50%);white-space:nowrap}
.cv-zh{font-family:var(--zh);font-size:9rem;font-weight:300;color:rgba(255,255,255,.12);line-height:1}
.cv-sub{font-family:var(--serif);font-size:1rem;font-style:italic;color:var(--gold-lt);margin-top:.5rem;letter-spacing:.06em}
.fairs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:1rem}
.fair-card{padding:2.2rem 1.8rem;background:var(--cream);border-bottom:2px solid var(--gold);transition:transform .2s}
.fair-card:hover{transform:translateY(-3px)}
.fair-location{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem}
.fair-name{font-family:var(--serif);font-size:1.2rem;font-weight:300;color:var(--ink);margin-bottom:.6rem}
.fair-desc{font-size:.78rem;font-weight:300;line-height:1.65;color:rgba(15,15,14,.55)}

/* ── ABOUT ───────────────────────────────────────────────── */
.founder-grid{display:grid;grid-template-columns:340px 1fr;gap:6rem;align-items:flex-start}
.founder-img-wrap{background:var(--cream);overflow:hidden;aspect-ratio:3/4}
.founder-img-wrap img{width:100%;height:100%;object-fit:cover;object-position:center top}
.founder-name-block{padding:1.4rem 0;border-bottom:2px solid var(--gold)}
.founder-name{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:var(--ink)}
.founder-title{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:.3rem}
.founder-quote{
  margin-top:2rem;padding:1.5rem 2rem;
  border-left:3px solid var(--gold);background:var(--cream);
  font-family:var(--serif);font-size:1.1rem;font-style:italic;
  font-weight:300;line-height:1.6;color:rgba(15,15,14,.72);
}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:1rem}
.team-card{background:var(--paper);padding:2.4rem 2rem;border-bottom:2px solid transparent;transition:border-color .25s,transform .2s}
.team-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.tc-avatar{width:60px;height:60px;background:var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.3rem;font-weight:300;color:var(--gold);margin-bottom:1rem}
.tc-name{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--ink);margin-bottom:.25rem}
.tc-role{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:.8rem}
.tc-bio{font-size:.8rem;font-weight:300;line-height:1.65;color:rgba(15,15,14,.55)}
.locations-visual{display:flex;flex-direction:column;gap:2rem;padding:3.5rem;background:var(--cream)}
.lv-item{}
.lv-city{font-family:var(--serif);font-size:3.5rem;font-weight:300;color:var(--gold);line-height:1;margin-bottom:.3rem}
.lv-tag{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(15,15,14,.45)}
.lv-divider{height:1px;background:rgba(15,15,14,.12);width:80%}

/* ── CONTACT · FAQ ───────────────────────────────────────── */
.faq-list{max-width:780px;margin:0 auto}
.faq-item{padding:1.8rem 0;border-bottom:1px solid rgba(15,15,14,.08)}
.faq-q{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--ink);margin-bottom:.6rem}
.faq-a{font-size:.88rem;font-weight:300;line-height:1.78;color:rgba(15,15,14,.6)}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1100px){
  .four-col{grid-template-columns:1fr 1fr}
  .process-steps{grid-template-columns:1fr 1fr}
  .fairs-grid{grid-template-columns:1fr 1fr}
  .founder-grid{grid-template-columns:1fr;gap:3rem}
  .founder-img-wrap{max-width:300px;aspect-ratio:1}
}
@media(max-width:900px){
  .hero{grid-template-columns:1fr}
  .hero-right{display:none}
  .hero-left{padding:8rem 2.5rem 5rem}
  .two-col,.two-col.reverse{grid-template-columns:1fr;direction:ltr;gap:3rem}
  .service-visual{min-height:220px}
  .conc-visual{min-height:220px}
  .dir-visual{min-height:200px}
  .team-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .hero-left{padding:7rem 1.5rem 4rem}
  .four-col{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .fairs-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .intro-pillars{gap:1rem}
}
