
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
nav ul { list-style:none; display:flex; gap:40px; align-items:center; }
nav ul li a { font-family:"Playfair Display",serif; font-size:14px; color:var(--text); text-decoration:none; opacity:0.6; }
nav ul li a.active { opacity:1; font-weight:600; }
/* HERO */
.ph-hero { background:var(--dark); padding:160px 52px 100px; display:flex; gap:100px; align-items:flex-start; }
.ph-hero-label { flex-shrink:0; width:120px; padding-top:4px; }
.ph-hero-label-text { font-family:"Playfair Display",serif; font-size:clamp(28px,4.5vw,56px); font-weight:700; line-height:1; letter-spacing:-0.02em; color:rgba(255,255,255,0.2); display:block; }
.ph-hero-right { flex:1; }
.ph-eyebrow { font-family:"Playfair Display",serif; font-size:10px; letter-spacing:0.35em; text-transform:uppercase; color:rgba(255,255,255,0.3); display:block; margin-bottom:32px; margin-top:clamp(28px,4.5vw,56px); }
.ph-quote { font-family:"Noto Serif JP",serif; font-size:clamp(22px,3.2vw,42px); font-weight:300; line-height:1.9; color:var(--white); margin-bottom:32px; }
.ph-quote em { font-style:normal; color:var(--accent); }
.ph-lead { font-size:13px; font-weight:300; line-height:2.4; color:rgba(255,255,255,0.45); max-width:560px; }

/* SECTIONS */
.ph-section { padding:100px 52px; display:flex; gap:100px; align-items:flex-start; border-bottom:1px solid var(--border); }
.ph-section.bg-off { background:var(--off-white); }
.ph-section-label { flex-shrink:0; width:120px; padding-top:4px; }
.ph-label-en { font-family:"Playfair Display",serif; font-size:clamp(20px,3vw,40px); font-weight:700; line-height:1; letter-spacing:-0.02em; color:var(--border); display:block; }
.ph-section-body { flex:1; }
.ph-section-eyebrow { font-family:"Playfair Display",serif; font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:var(--text-soft); display:block; margin-bottom:16px; margin-top:clamp(28px,4.5vw,56px); }
.ph-section-title { font-size:clamp(18px,2vw,26px); font-weight:400; line-height:1.6; margin-bottom:36px; color:var(--text); }
.ph-section-text { font-size:14px; font-weight:300; line-height:2.6; color:var(--text-mid); }
.ph-section-text p { margin-bottom:24px; }
.ph-section-text p:last-child { margin-bottom:0; }

/* MISSION CARDS */
.ph-mission-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); margin-top:52px; }
.ph-mission-card { background:var(--white); padding:32px 28px; }
.ph-mission-card-en { font-family:"Playfair Display",serif; font-size:11px; letter-spacing:0.3em; text-transform:uppercase; color:var(--text-soft); display:block; margin-bottom:12px; }
.ph-mission-card h4 { font-size:14px; font-weight:500; margin-bottom:12px; line-height:1.6; }
.ph-mission-card p { font-size:12px; font-weight:300; line-height:2; color:var(--text-soft); }

/* VALUES */
.ph-values-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px 80px; }
.ph-value-num { font-family:"Playfair Display",serif; font-size:13px; letter-spacing:0.2em; color:var(--text-soft); display:block; margin-bottom:12px; margin-top:clamp(28px,4.5vw,56px); }
.ph-value-item h4 { font-size:15px; font-weight:500; margin-bottom:12px; line-height:1.6; }
.ph-value-item p { font-size:13px; font-weight:300; line-height:2.3; color:var(--text-mid); }

/* STORY ACCENT */
.ph-story-accent { width:3px; min-height:60px; background:var(--accent); flex-shrink:0; margin-top:4px; }

/* TIMELINE */
.ph-timeline { margin-top:52px; }
.ph-timeline-item { display:flex; gap:32px; padding:32px 0; border-top:1px solid var(--border); }
.ph-timeline-year { flex-shrink:0; width:60px; font-family:"Playfair Display",serif; font-size:16px; font-weight:700; color:var(--text); padding-top:2px; }
.ph-timeline-body h4 { font-size:14px; font-weight:500; margin-bottom:8px; }
.ph-timeline-body p { font-size:13px; font-weight:300; line-height:2.2; color:var(--text-soft); }

/* FOUNDER */
.ph-founder-name-row { display:flex; align-items:baseline; gap:20px; margin-bottom:6px; margin-top:clamp(28px,4.5vw,56px); }
.ph-founder-name { font-size:clamp(20px,2.5vw,30px); font-weight:400; }
.ph-founder-roman { font-family:"Playfair Display",serif; font-size:12px; letter-spacing:0.25em; color:var(--text-soft); }
.ph-founder-title { font-family:"Playfair Display",serif; font-size:11px; letter-spacing:0.2em; color:var(--text-soft); display:block; margin-bottom:4px; }
.ph-founder-role { font-size:12px; font-weight:300; color:var(--text-soft); margin-bottom:20px; }
.ph-founder-meta { display:flex; gap:24px; margin-bottom:28px; flex-wrap:wrap; }
.ph-founder-meta span { font-family:"Playfair Display",serif; font-size:11px; color:var(--text-soft); letter-spacing:0.08em; }
.ph-founder-bio { font-size:14px; font-weight:300; line-height:2.6; color:var(--text-mid); margin-bottom:24px; }
.ph-founder-skills { display:flex; flex-wrap:wrap; gap:8px; }
.ph-skill-tag { font-family:"Playfair Display",serif; font-size:11px; letter-spacing:0.1em; border:1px solid var(--border); padding:6px 14px; color:var(--text-mid); }

/* CTA */
.ph-cta { background:var(--dark); padding:100px 52px; text-align:center; }
.ph-cta-quote { font-family:"Noto Serif JP",serif; font-size:clamp(18px,2.5vw,30px); font-weight:300; color:var(--white); line-height:1.9; margin-bottom:16px; }
.ph-cta-sub { font-size:13px; font-weight:300; color:rgba(255,255,255,0.4); line-height:2; margin-bottom:48px; }
.ph-cta-btns { display:flex; justify-content:center; gap:16px; flex-wrap:wrap; }
.btn-primary { display:inline-flex; align-items:center; gap:10px; background:var(--accent); color:var(--text); font-family:"Playfair Display",serif; font-size:13px; letter-spacing:0.2em; padding:18px 44px; text-decoration:none; transition:opacity 0.3s; }
.btn-primary:hover { opacity:0.85; }
.btn-outline-light { display:inline-flex; align-items:center; gap:10px; border:1px solid rgba(255,255,255,0.3); color:rgba(255,255,255,0.6); font-family:"Playfair Display",serif; font-size:13px; letter-spacing:0.2em; padding:18px 44px; text-decoration:none; transition:all 0.3s; }
.btn-outline-light:hover { border-color:rgba(255,255,255,0.7); color:var(--white); }

/* FOOTER */
@media (max-width:1024px) {
  nav { padding:0 32px; }
  .ph-hero,.ph-section { gap:48px; padding:80px 32px; }
  .ph-cta { padding:80px 32px; }
  .ph-mission-cards { grid-template-columns:1fr; }
  footer { padding:48px 32px 32px; }
}
@media (max-width:768px) {
  nav { padding:0 20px; height:60px; }
  nav ul { display:none; }
  .ph-hero { flex-direction:column; gap:20px; padding:100px 20px 64px; }
  .ph-hero-label { width:auto; }
  .ph-section { flex-direction:column; gap:20px; padding:64px 20px; }
  .ph-section-label { width:auto; }
  .ph-values-grid { grid-template-columns:1fr; gap:40px; }
  .ph-cta { padding:64px 20px; }
  .ph-cta-btns { flex-direction:column; align-items:center; }
  footer { padding:48px 20px 28px; }
  .footer-inner { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; gap:8px; }
}
