:root{
  --jp:"Noto Serif JP","游明朝",serif;
  --display:"Playfair Display",serif;
  --serif2:"Cormorant",serif;
  --sans:"Outfit",sans-serif;
  --bg:#f3f2ee;
  --mid:#999;
  --divider:#e0dfdb;
  --card:#eceae6;
  --black:#000;
  --ink:#1a1a1a;
  --gray:#555;
  --light:#c0bfba;
  --faint:#d5d3ce;
  --rule:var(--divider);
  --rule-soft:var(--card);
  --white:var(--bg);
  --red:#B5121B;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-power:cubic-bezier(.77,0,.18,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:var(--jp);color:var(--ink);background:var(--bg);
  line-height:1.9;letter-spacing:.04em;overflow-x:hidden;
  cursor:none;
}
body.menu-open{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ============================================
   INTRO LOADER
============================================ */
.intro{
  position:fixed;inset:0;z-index:1000;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  pointer-events:none;
}
.intro.done{
  transform:translateY(-100%);
  transition:transform 1.4s var(--ease-power);
}
.intro-inner{
  text-align:center;position:relative;
}
.intro-formula{
  font-family:var(--serif2);font-size:clamp(2rem,5vw,3.5rem);
  font-weight:300;letter-spacing:.15em;color:var(--ink);
  display:inline-flex;align-items:center;gap:.4em;
}
.intro-formula span{
  display:inline-block;
  opacity:0;transform:translateY(20px);
  animation:introChar .8s var(--ease) forwards;
}
.intro-formula span:nth-child(1){animation-delay:.1s}
.intro-formula span:nth-child(2){animation-delay:.25s}
.intro-formula span:nth-child(3){animation-delay:.4s}
.intro-formula span:nth-child(4){animation-delay:.55s}
.intro-formula span:nth-child(5){animation-delay:.7s}
.intro-formula .red{color:var(--red)}
.intro-label{
  display:block;margin-top:1.5rem;
  font-family:var(--sans);font-size:.6rem;
  letter-spacing:.4em;text-transform:uppercase;color:var(--light);
  opacity:0;animation:introLabel 1s 1s var(--ease) forwards;
}
.intro-bar{
  position:absolute;bottom:-2.5rem;left:50%;
  width:0;height:1px;background:var(--red);
  transform:translateX(-50%);
  animation:introBar 1.6s 1.1s var(--ease-power) forwards;
}
@keyframes introChar{to{opacity:1;transform:translateY(0)}}
@keyframes introLabel{to{opacity:1}}
@keyframes introBar{to{width:120px}}

/* ============================================
   CUSTOM CURSOR
============================================ */
.cursor{
  position:fixed;top:0;left:0;
  width:8px;height:8px;
  background:var(--red);border-radius:50%;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  transition:width .25s var(--ease),height .25s var(--ease),background .25s;
}
.cursor-ring{
  position:fixed;top:0;left:0;
  width:36px;height:36px;
  border:1px solid var(--ink);border-radius:50%;
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform .2s var(--ease),width .25s var(--ease),height .25s var(--ease),opacity .25s;
  opacity:.5;
}
.cursor-label{
  position:fixed;top:0;left:0;
  font-family:var(--sans);font-size:.55rem;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);pointer-events:none;z-index:9998;
  transform:translate(20px,20px);
  opacity:0;transition:opacity .25s;
  white-space:nowrap;
}
body.hovering .cursor{width:4px;height:4px}
body.hovering .cursor-ring{width:60px;height:60px;opacity:.8}
body.hovering .cursor-label{opacity:.7}

/* ============================================
   NAV
============================================ */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.4rem 3.5rem;
  display:flex;justify-content:space-between;align-items:center;
  background:rgba(243,242,238,0);backdrop-filter:blur(0);
  border-bottom:1px solid transparent;
  transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;
}
nav.scrolled{
  background:rgba(243,242,238,.94);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom-color:var(--rule-soft);
  padding:1rem 3.5rem;
}
.nav-logo{
  font-family:var(--display);font-size:1.15rem;font-weight:400;
  letter-spacing:.2em;color:var(--ink);
  display:flex;align-items:center;gap:.4em;
}
.nav-logo .i-mark{color:var(--red);font-style:italic}
.nav-links{display:flex;gap:2.4rem;list-style:none}
.nav-links a{
  font-family:var(--sans);font-size:.65rem;font-weight:300;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--gray);transition:color .3s;position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-6px;left:0;
  width:0;height:1px;background:var(--red);
  transition:width .4s var(--ease);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{width:100%}

/* Hamburger button — hidden on desktop */
.nav-burger{
  display:none;
  background:none;border:none;cursor:pointer;
  width:28px;height:20px;position:relative;z-index:200;
  flex-direction:column;justify-content:space-between;
  padding:0;
}
.nav-burger span{
  display:block;width:100%;height:1.5px;
  background:var(--ink);
  transition:transform .4s var(--ease),opacity .3s;
  transform-origin:center;
}
body.menu-open .nav-burger span:nth-child(1){transform:translateY(9px) rotate(45deg)}
body.menu-open .nav-burger span:nth-child(2){opacity:0}
body.menu-open .nav-burger span:nth-child(3){transform:translateY(-9px) rotate(-45deg)}

/* Mobile menu overlay */
.mobile-menu{
  position:fixed;inset:0;z-index:99;
  background:var(--bg);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .5s var(--ease),visibility .5s;
}
body.menu-open .mobile-menu{opacity:1;visibility:visible}

.mobile-menu-links{
  list-style:none;text-align:center;
  display:flex;flex-direction:column;gap:1.2rem;
}
.mobile-menu-links li{
  opacity:0;transform:translateY(20px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
body.menu-open .mobile-menu-links li{opacity:1;transform:translateY(0)}
body.menu-open .mobile-menu-links li:nth-child(1){transition-delay:.1s}
body.menu-open .mobile-menu-links li:nth-child(2){transition-delay:.15s}
body.menu-open .mobile-menu-links li:nth-child(3){transition-delay:.2s}
body.menu-open .mobile-menu-links li:nth-child(4){transition-delay:.25s}
body.menu-open .mobile-menu-links li:nth-child(5){transition-delay:.3s}

.mobile-menu-links a{
  font-family:var(--display);font-size:1.4rem;font-weight:400;
  letter-spacing:.15em;color:var(--ink);
  transition:color .3s;
}
.mobile-menu-links a:hover{color:var(--red)}

.mobile-menu-footer{
  margin-top:3rem;
  opacity:0;transform:translateY(10px);
  transition:opacity .6s .35s var(--ease),transform .6s .35s var(--ease);
}
body.menu-open .mobile-menu-footer{opacity:1;transform:translateY(0)}
.mobile-menu-formula{
  font-family:var(--serif2);font-size:1rem;font-weight:300;
  letter-spacing:.15em;color:var(--light);
}
.mobile-menu-formula .red{color:var(--red)}

/* ============================================
   HERO
============================================ */
.hero{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:0 3.5rem;position:relative;
  border-bottom:1px solid var(--ink);
  overflow:hidden;
  background:var(--white);
}

/* Subtle grid background */
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right,rgba(26,26,26,.045) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(26,26,26,.045) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black,transparent);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black,transparent);
}

.hero-logo-wrap{
  position:relative;z-index:3;
  text-align:center;
  display:flex;flex-direction:column;align-items:center;
  padding:8rem 0 6rem;
}

/* Giant ï mark */
.hero-mark{
  width:clamp(110px,12vw,160px);
  margin-bottom:1.5rem;
  opacity:0;
}
.hero-mark.in{transition:opacity 1s var(--ease);opacity:1}
.hero-mark svg{width:100%;height:auto;display:block}
.hero-mark .dot{
  transform-origin:center;
  opacity:0;transform:translateY(-30px);
}
.hero-mark.in .dot-l{animation:dotDrop .7s .3s var(--ease-power) forwards}
.hero-mark.in .dot-r{animation:dotDrop .7s .45s var(--ease-power) forwards}
.hero-mark .stem{
  transform-origin:bottom;
  transform:scaleY(0);
}
.hero-mark.in .stem{animation:stemRise 1s .1s var(--ease-power) forwards}

@keyframes dotDrop{to{opacity:1;transform:translateY(0)}}
@keyframes stemRise{to{transform:scaleY(1)}}

.hero-projectname{
  font-family:var(--display);
  font-size:clamp(1rem,1.4vw,1.15rem);
  font-weight:400;color:var(--mid);
  letter-spacing:.04em;
  margin-bottom:4rem;
  opacity:0;
}
.hero-projectname.in{transition:opacity 1s 1s var(--ease);opacity:1}
.hero-projectname .i-italic{font-style:italic;color:var(--red)}

.hero-formula{
  font-family:var(--serif2);font-size:clamp(.95rem,1.4vw,1.15rem);
  font-weight:300;letter-spacing:.6em;color:var(--mid);
  display:flex;align-items:center;justify-content:center;gap:.6em;
  margin-bottom:3.5rem;
  opacity:0;
}
.hero-formula.in{transition:opacity 1s 1.2s var(--ease);opacity:1}
.hero-formula .red{color:var(--red)}

.hero-name{
  font-family:var(--display);font-weight:400;
  font-size:clamp(1.4rem,2.2vw,1.9rem);
  letter-spacing:.45em;color:var(--ink);
  margin-bottom:3rem;
  display:inline-block;
}
.hero-name span{
  display:inline-block;opacity:0;transform:translateY(20px);
}
.hero-name.in span{
  animation:nameChar .7s var(--ease) forwards;
}
.hero-name.in span:nth-child(1){animation-delay:1.4s}
.hero-name.in span:nth-child(2){animation-delay:1.46s}
.hero-name.in span:nth-child(3){animation-delay:1.52s}
.hero-name.in span:nth-child(4){animation-delay:1.58s}
.hero-name.in span:nth-child(6){animation-delay:1.7s}
.hero-name.in span:nth-child(7){animation-delay:1.76s}
.hero-name.in span:nth-child(8){animation-delay:1.82s}
.hero-name.in span:nth-child(9){animation-delay:1.88s}
.hero-name.in span:nth-child(10){animation-delay:1.94s}
.hero-name.in span:nth-child(11){animation-delay:2s}
.hero-name.in span:nth-child(12){animation-delay:2.06s}
.hero-name.in span:nth-child(13){animation-delay:2.12s}
.hero-name.in span:nth-child(14){animation-delay:2.18s}
.hero-name .hero-name-gap{opacity:1;transform:none}
.hero-name.in .hero-name-gap{animation:none}
@keyframes nameChar{to{opacity:1;transform:translateY(0)}}

.hero-rule{
  width:0;height:1px;background:var(--ink);
  margin-bottom:2.5rem;
}
.hero-rule.in{animation:ruleDraw 1.2s 2.3s var(--ease-power) forwards}
@keyframes ruleDraw{to{width:80px}}

.hero-tagline{
  font-family:var(--jp);
  font-size:clamp(1.1rem,1.8vw,1.4rem);
  font-weight:400;letter-spacing:.15em;color:var(--ink);
  opacity:0;transform:translateY(15px);
}
.hero-tagline.in{transition:opacity 1.2s 2.6s var(--ease),transform 1.2s 2.6s var(--ease);opacity:1;transform:translateY(0)}
.hero-tagline .red{color:var(--red);font-style:italic;font-family:var(--display)}

/* Side meta info */
.hero-meta-l,.hero-meta-r{
  position:absolute;top:50%;transform:translateY(-50%);
  font-family:var(--sans);font-size:.55rem;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--mid);line-height:2;z-index:3;
  opacity:0;
}
.hero-meta-l{left:3.5rem;text-align:left}
.hero-meta-r{right:3.5rem;text-align:right}
.hero-meta-l.in,.hero-meta-r.in{transition:opacity 1.2s 2.4s var(--ease);opacity:.8}

.hero-scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.6rem;
  opacity:0;z-index:3;
}
.hero-scroll.in{transition:opacity 1s 2.8s var(--ease);opacity:1}
.hero-scroll-line{
  width:1px;height:40px;background:var(--ink);
  transform-origin:top;
  animation:scrollPulse 2.4s var(--ease-power) infinite;
}
.hero-scroll span{
  font-family:var(--sans);font-size:.55rem;
  letter-spacing:.35em;text-transform:uppercase;color:var(--ink);
}

@keyframes up{to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{
  0%{transform:scaleY(0);transform-origin:top}
  50%{transform:scaleY(1);transform-origin:top}
  51%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes spinR{to{transform:rotate(-360deg)}}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* ============================================
   SECTIONS
============================================ */
.sec{padding:9rem 3.5rem;max-width:1280px;margin:0 auto}

.label{
  font-family:var(--sans);font-size:.58rem;font-weight:400;
  letter-spacing:.4em;text-transform:uppercase;color:var(--gray);
  margin-bottom:2rem;
  display:flex;align-items:center;gap:1rem;
}
.label::before{content:'';width:30px;height:1px;background:var(--red)}

.heading{
  font-family:var(--display);font-size:clamp(1.6rem,3.2vw,2.4rem);
  font-weight:400;letter-spacing:0;line-height:1.4;color:var(--ink);
  margin-bottom:1.5rem;
}
.heading-jp{
  font-family:var(--jp);font-size:clamp(1.4rem,2.8vw,2rem);
  font-weight:400;letter-spacing:.04em;line-height:1.7;color:var(--ink);
  margin-bottom:1.5rem;
}
.body-text{
  font-size:.9rem;font-weight:300;color:var(--gray);
  line-height:2.4;max-width:600px;
}

/* Section number marker */
.sec-num{
  position:absolute;top:3rem;right:3.5rem;
  font-family:var(--serif2);font-size:.85rem;font-weight:400;
  letter-spacing:.2em;color:var(--light);
}
.sec-num span{color:var(--red)}

/* ============================================
   DUAL PILLARS
============================================ */
.dual-sec{position:relative}
.dual-grid{
  display:grid;grid-template-columns:1fr 1fr;
  margin-top:4rem;border:1px solid var(--ink);
}
.dual-card{
  padding:3.5rem;display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:background .5s var(--ease);
}
.dual-card+.dual-card{border-left:1px solid var(--ink)}
.dual-card:hover{background:var(--card)}

.dual-card-marker{
  position:absolute;top:1.5rem;right:1.8rem;
  font-family:var(--serif2);font-size:.8rem;
  letter-spacing:.3em;color:var(--light);
}
.dual-card-marker .red{color:var(--red)}

.dual-card-icon{margin-bottom:2rem}
.dual-card-icon svg{width:48px;height:48px}
.dual-card-label{
  font-family:var(--sans);font-size:.55rem;font-weight:400;
  letter-spacing:.4em;text-transform:uppercase;color:var(--gray);
  margin-bottom:1rem;
}
.dual-card-title{
  font-family:var(--display);font-size:1.6rem;font-weight:400;
  letter-spacing:0;margin-bottom:.3rem;color:var(--ink);
}
.dual-card-jp{font-size:.85rem;font-weight:400;color:var(--gray);margin-bottom:1.5rem}
.dual-card-body{font-size:.82rem;font-weight:300;color:var(--gray);line-height:2.3;flex:1}
.dual-card-link{
  display:inline-flex;align-items:center;gap:.6rem;
  margin-top:2rem;font-family:var(--sans);font-size:.62rem;
  font-weight:400;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink);transition:gap .3s,color .3s;
}
.dual-card-link::after{content:'→';font-family:var(--display);font-size:1rem}
.dual-card-link:hover{color:var(--red);gap:1rem}

.dual-bridge{
  border:1px solid var(--ink);border-top:none;
  padding:1.8rem 2rem;text-align:center;position:relative;
  background:var(--ink);color:var(--white);
}
.dual-bridge::before{
  content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:50px;height:2px;background:var(--red);
}
.dual-bridge p{
  font-family:var(--serif2);font-size:1rem;font-weight:300;
  letter-spacing:.1em;color:var(--white);font-style:italic;
}
.dual-bridge p .red{color:var(--red);font-style:normal}

/* ============================================
   THEORY
============================================ */
.theory-sec{
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:9rem 3.5rem;max-width:none;margin:0;
  position:relative;overflow:hidden;background:var(--card);
}
/* Grid background */
.theory-sec::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(to right,var(--rule-soft) 1px,transparent 1px),
    linear-gradient(to bottom,var(--rule-soft) 1px,transparent 1px);
  background-size:120px 120px;opacity:.5;
}
.theory-inner{max-width:1280px;margin:0 auto;position:relative;z-index:2}
.theory-content{
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;
  align-items:start;margin-top:3rem;
}
.theory-explain{font-size:.82rem;font-weight:300;color:var(--gray);line-height:2.6}
.theory-explain p+p{margin-top:1.6rem}
.theory-explain strong{font-weight:500;color:var(--ink)}
.theory-explain em{font-style:italic;color:var(--red);font-weight:400}

.theory-link{
  display:inline-flex;align-items:center;gap:.6rem;
  margin-top:3rem;font-family:var(--sans);font-size:.65rem;
  font-weight:400;letter-spacing:.3em;text-transform:uppercase;
  color:var(--ink);border-bottom:1px solid var(--ink);
  padding-bottom:4px;transition:color .3s,border-color .3s,gap .3s;
}
.theory-link:hover{color:var(--red);border-color:var(--red);gap:1rem}

.theory-visual{display:flex;flex-direction:column;gap:2rem}
.theory-diagram{
  background:var(--white);border:1px solid var(--ink);
  padding:2.5rem 1.5rem;
}
.theory-diagram svg{width:100%;height:auto}

.theory-insight{
  border:1px solid var(--ink);padding:2.2rem 2.2rem;
  background:var(--ink);color:var(--white);
}
.theory-insight-label{
  font-family:var(--sans);font-size:.52rem;font-weight:500;
  letter-spacing:.4em;text-transform:uppercase;color:var(--red);
  margin-bottom:1rem;
}
.theory-insight-body{
  font-size:.85rem;font-weight:300;color:var(--white);
  line-height:2.3;font-style:italic;
}

/* ============================================
   i.PEACE VISUAL
============================================ */
.ipeace-visual{
  max-width:none;margin:0;padding:0;
  display:grid;grid-template-columns:1fr 1fr;
  min-height:90vh;
  border-bottom:1px solid var(--ink);
  position:relative;
}
.ipeace-image{
  display:flex;align-items:center;justify-content:center;
  padding:5rem 3rem;
  border-right:1px solid var(--ink);
  position:relative;overflow:hidden;
}
.ipeace-image::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(to right,var(--rule-soft) 1px,transparent 1px),
    linear-gradient(to bottom,var(--rule-soft) 1px,transparent 1px);
  background-size:60px 60px;opacity:.6;
}
.ipeace-image img{
  max-height:75vh;width:auto;max-width:100%;
  object-fit:contain;position:relative;z-index:2;
}
.ipeace-corner{
  position:absolute;font-family:var(--sans);font-size:.55rem;
  letter-spacing:.25em;text-transform:uppercase;color:var(--gray);
  z-index:3;
}
.ipeace-corner-tl{top:1.5rem;left:1.5rem}
.ipeace-corner-br{bottom:1.5rem;right:1.5rem;color:var(--red)}

.ipeace-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:5rem 4.5rem;position:relative;
}
.ipeace-text .label{margin-bottom:1.5rem}
.ipeace-text .heading-jp{font-size:clamp(1.8rem,3.2vw,2.4rem);margin-bottom:1.2rem;line-height:1.6}
.ipeace-text .body-text{margin-bottom:2.5rem;max-width:480px}
.ipeace-activities{
  display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem;
}
.ipeace-activities span{
  font-family:var(--sans);font-size:.6rem;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--gray);padding:.5rem 1.1rem;
  border:1px solid var(--rule);
  transition:border-color .3s,color .3s,background .3s;
}
.ipeace-activities span:hover{border-color:var(--ink);color:var(--ink);background:var(--card)}
.ipeace-link{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.65rem;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:4px;
  transition:color .3s,border-color .3s,gap .3s;
}
.ipeace-link::after{content:'→';font-family:var(--display);font-size:1rem}
.ipeace-link:hover{color:var(--red);border-color:var(--red);gap:1rem}

/* ============================================
   PRACTICE PROJECTS
============================================ */
.practice-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  margin-top:3rem;border:1px solid var(--rule);
}
.practice-card{
  padding:2.5rem;display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  transition:background .4s;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  min-height:320px;
}
.practice-card:nth-child(3n){border-right:none}
.practice-card:nth-last-child(-n+2):not(:nth-child(3n+1)){border-bottom:none}
.practice-card:last-child{border-bottom:none;border-right:none}
.practice-card::before{
  content:'';position:absolute;top:0;left:0;
  width:0;height:100%;background:var(--ink);
  transition:width .5s var(--ease-power);z-index:0;
}
.practice-card:is(:hover,:active,:focus-visible){color:var(--white)}
.practice-card:is(:hover,:active,:focus-visible)::before{width:100%}
.practice-card>*{position:relative;z-index:2;transition:color .4s}
.practice-card:is(:hover,:active,:focus-visible) .practice-card-tag,
.practice-card:is(:hover,:active,:focus-visible) .practice-card-jp,
.practice-card:is(:hover,:active,:focus-visible) .practice-card-desc,
.practice-card:is(:hover,:active,:focus-visible) .practice-card-num{color:rgba(243,242,238,.7)}
.practice-card:is(:hover,:active,:focus-visible) .practice-card-name{color:var(--white)}
.practice-card:is(:hover,:active,:focus-visible) .practice-card-arrow{color:var(--red);opacity:1;transform:translateX(4px)}

.practice-card-logo{
  position:relative;z-index:3;
  width:80px;height:80px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1.5rem;flex-shrink:0;
  background:rgba(0,0,0,.08);
  border-radius:8px;
  padding:12px;
  transition:background .4s;
}
.practice-card:is(:hover,:active,:focus-visible) .practice-card-logo{
  background:transparent;
}
.practice-card-logo img{
  max-width:100%;max-height:100%;width:auto;height:auto;
  object-fit:contain;
  position:relative;z-index:1;
}

.practice-card-num{
  font-family:var(--serif2);font-size:.75rem;
  letter-spacing:.2em;color:var(--light);margin-bottom:.8rem;
}
.practice-card-tag{
  font-family:var(--sans);font-size:.55rem;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gray);
  margin-bottom:1rem;
}
.practice-card-name{
  font-family:var(--display);font-size:1.4rem;font-weight:400;
  letter-spacing:0;margin-bottom:.2rem;color:var(--ink);
}
.practice-card-jp{font-size:.78rem;font-weight:400;color:var(--gray);margin-bottom:1rem}
.practice-card-desc{font-size:.78rem;font-weight:300;color:var(--gray);line-height:2;flex:1}
.practice-card-arrow{
  align-self:flex-end;font-family:var(--display);font-size:1.3rem;
  color:var(--ink);opacity:.3;
  transition:opacity .3s,transform .3s,color .3s;
}
.practice-card:not(a){cursor:default}

.practice-all{text-align:center;margin-top:3rem}
.practice-all a{
  display:inline-flex;align-items:center;gap:.8rem;
  font-family:var(--sans);font-size:.65rem;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--ink);
  border:1px solid var(--ink);padding:1.1rem 3rem;
  transition:background .3s,color .3s,gap .3s;
}
.practice-all a::after{content:'→';font-family:var(--display);font-size:1rem}
.practice-all a:hover{background:var(--ink);color:var(--white);gap:1.2rem}

/* ============================================
   MEDIA
============================================ */
.media-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  margin-top:3rem;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
}
.media-card{
  padding:2.5rem 2rem;display:block;transition:background .3s;
  border-left:1px solid var(--rule-soft);
}
.media-card:first-child{border-left:none}
.media-card:hover{background:var(--card)}
.media-card-meta{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.2rem;
}
.media-card-date{
  font-family:var(--sans);font-size:.55rem;font-weight:300;
  letter-spacing:.25em;color:var(--gray);
}
.media-card-tag{
  font-family:var(--sans);font-size:.5rem;font-weight:500;
  letter-spacing:.3em;text-transform:uppercase;color:var(--red);
}
.media-card-title{
  font-size:.92rem;font-weight:400;line-height:2;color:var(--ink);
}

/* ============================================
   FOUNDER
============================================ */
.founder-sec{
  border-top:1px solid var(--ink);
  padding:9rem 3.5rem;max-width:none;margin:0;
  background:var(--ink);color:var(--white);
}
.founder-inner{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1.3fr 1fr;gap:6rem;align-items:center;
}
.founder-sec .label{color:rgba(243,242,238,.5)}
.founder-sec .label::before{background:var(--red)}
.founder-text{max-width:620px}
.founder-name-en{
  font-family:var(--display);font-size:2.4rem;font-weight:400;
  letter-spacing:0;color:var(--white);margin-bottom:.3rem;
}
.founder-name-jp{font-size:1rem;font-weight:400;color:rgba(243,242,238,.7);margin-bottom:.8rem}
.founder-titles{
  font-family:var(--sans);font-size:.58rem;font-weight:300;
  letter-spacing:.3em;text-transform:uppercase;
  color:rgba(243,242,238,.4);margin-bottom:2.5rem;
}
.founder-bio{
  font-size:.85rem;font-weight:300;color:rgba(243,242,238,.75);
  line-height:2.5;margin-bottom:2.5rem;
}
.founder-link{
  display:inline-flex;align-items:center;gap:.6rem;
  font-family:var(--sans);font-size:.62rem;font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;color:var(--white);
  border-bottom:1px solid var(--white);padding-bottom:3px;
  transition:color .3s,border-color .3s,gap .3s;
}
.founder-link::after{content:'→';font-family:var(--display);font-size:1rem}
.founder-link:hover{color:var(--red);border-color:var(--red);gap:1rem}

.founder-portrait{
  position:relative;
}
.founder-portrait img{
  width:100%;height:auto;display:block;
  filter:grayscale(.1);
}
/* Mobile header portrait — hidden on desktop */
.founder-header-mobile-portrait{display:none}
.founder-portrait-caption{
  position:absolute;bottom:-2rem;right:0;
  font-family:var(--sans);font-size:.55rem;font-weight:300;
  letter-spacing:.25em;text-transform:uppercase;
  color:rgba(243,242,238,.4);
}
.founder-portrait-caption .red{
  color:var(--red);font-family:var(--serif2);
  font-style:italic;font-size:1.1em;
}

/* ============================================
   MANIFESTO
============================================ */
.manifesto-sec{
  padding:10rem 3.5rem;max-width:none;margin:0;
  text-align:center;position:relative;
  border-bottom:1px solid var(--ink);
  background:var(--white);
}
.manifesto-inner{max-width:700px;margin:0 auto}
.manifesto-sec .label{margin-bottom:4rem}
.manifesto-body{
  font-family:var(--jp);
  font-size:clamp(1.1rem,1.8vw,1.4rem);
  font-weight:300;line-height:2.6;letter-spacing:.1em;
  color:var(--ink);
}
.manifesto-body p{margin:0}
.manifesto-body .spacer{height:1.5rem;line-height:1.5rem}
.manifesto-body .accent{font-weight:400}
.manifesto-body .red{color:var(--red);font-style:italic;font-family:var(--display);font-weight:400}
.manifesto-sign{
  margin-top:5rem;
  display:flex;flex-direction:column;align-items:center;gap:1.2rem;
}
.manifesto-sign-line{width:40px;height:1px;background:var(--red)}
.manifesto-sign p{
  font-family:var(--display);font-size:.95rem;
  letter-spacing:.3em;color:var(--gray);
}
.manifesto-sign .red{color:var(--red);font-style:italic}

/* ============================================
   PICK UP PROJECT
============================================ */
.pickup-sec{padding-top:7rem;padding-bottom:7rem;border-bottom:1px solid var(--rule)}
.pickup-label{justify-content:center;margin-bottom:3rem}
.pickup-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  border:1px solid var(--rule);
  margin-top:1rem;
}
.pickup-card{
  display:flex;flex-direction:column;
  border-right:1px solid var(--rule);
  transition:background .35s var(--ease);
  min-height:0;
  min-width:0;
}
.pickup-card:nth-child(3n){border-right:none}
.pickup-card:hover{background:var(--card)}
.pickup-card-visual{
  aspect-ratio:3/4;
  background:var(--card);
  border-bottom:1px solid var(--rule);
  position:relative;
  overflow:hidden;
}
.pickup-card-visual img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;
  transform:scale(1.06);
  transition:transform .55s var(--ease-power);
}
.pickup-card:hover .pickup-card-visual img{
  transform:scale(1);
}
/* 枠は縦長（aspect-ratio:3/4）。横長画像は cover で上下基準、左右がトリミングされやすい */
.pickup-card-visual--imedia img{
  object-position:center 42%;
}
/* 白ロゴPNG：縦長枠のまま全体が収まるよう contain＋暗背景 */
.pickup-card-visual--ipeace{
  background:var(--ink);
}
.pickup-card-visual--ipeace img{
  object-fit:contain;
  padding:clamp(1rem,4vw,2.25rem);
  box-sizing:border-box;
}
.pickup-card-title{
  display:block;padding:1.6rem 1.2rem;
  width:100%;
  box-sizing:border-box;
  font-family:var(--display);font-size:clamp(1.15rem,2.3vw,1.55rem);
  font-weight:400;letter-spacing:.06em;text-align:center;color:var(--ink);
  border-bottom:1px solid var(--rule);
}
.pickup-card-note{
  display:block;
  padding:1rem 1rem 1.1rem;
  width:100%;
  box-sizing:border-box;
  font-family:var(--jp);
  /* Manifesto（clamp(1.1rem,1.8vw,1.4rem)）より約1px小さく */
  font-size:calc(clamp(1.1rem,1.8vw,1.4rem) - 1px);
  line-height:1.9;
  letter-spacing:.03em;
  color:var(--gray);
  text-align:center;
  background:rgba(255,255,255,.45);
  min-height:8.2em;
  text-wrap:pretty;
}

/* ============================================
   PRESS — LIST
============================================ */
.press-sec{
  padding:9rem 3.5rem;max-width:none;margin:0;
  border-top:1px solid var(--rule);
}
.press-inner{max-width:1100px;margin:0 auto}
.press-list{
  list-style:none;
  border-top:1px solid var(--ink);
  margin-top:1rem;
}
.press-list li{
  border-bottom:1px solid var(--rule);
}
.press-list a{
  display:flex;align-items:center;gap:2rem;
  padding:1.8rem 1rem;
  transition:background .3s,padding .3s;
}
.press-list a:hover{background:var(--card);padding-left:1.5rem}
.press-list-icon{
  flex-shrink:0;width:120px;height:auto;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;border-radius:4px;
}
.press-list-icon svg{width:100%;height:100%;display:block}
.press-list-icon img{width:100%;height:auto;display:block;object-fit:cover}
.press-list-body{flex:1;min-width:0}
.press-list-meta{
  display:flex;align-items:center;gap:1rem;
  margin-bottom:.5rem;
}
.press-list-source{
  font-family:var(--sans);font-size:.58rem;font-weight:500;
  letter-spacing:.25em;text-transform:uppercase;color:var(--ink);
}
.press-list-date{
  font-family:var(--sans);font-size:.55rem;font-weight:300;
  letter-spacing:.2em;color:var(--gray);
}
.press-list-title{
  font-size:.88rem;font-weight:400;color:var(--ink);
  line-height:1.8;letter-spacing:.02em;
}
.press-list-arrow{
  flex-shrink:0;font-family:var(--display);font-size:1.2rem;
  color:var(--gray);transition:color .3s,transform .3s;
}
.press-list a:hover .press-list-arrow{color:var(--red);transform:translateX(4px)}

/* ============================================
   FOOTER UPDATE
============================================ */
.footer-left,.footer-center,.footer-right{flex:1}
.footer-left{text-align:left}
.footer-center{text-align:center}
.footer-right{text-align:right}
.footer-email{
  font-family:var(--sans);font-size:.62rem;font-weight:400;
  letter-spacing:.25em;color:var(--ink);
  border-bottom:1px solid var(--rule);padding-bottom:3px;
  transition:color .3s,border-color .3s;
}
.footer-email:hover{color:var(--red);border-color:var(--red)}

/* ============================================
   CONNECT / FOOTER
============================================ */
.connect-sec{text-align:center;padding:7rem 2rem;max-width:800px;margin:0 auto}
.connect-links{display:flex;justify-content:center;gap:2.5rem;margin-top:2.5rem;flex-wrap:wrap}
.connect-link{
  font-family:var(--sans);font-size:.65rem;font-weight:300;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gray);
  transition:color .3s;
}
.connect-link:hover{color:var(--red)}

footer{
  text-align:center;padding:3rem 2rem;
  border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;
  padding:2.5rem 3.5rem;
}
.footer-copy{font-family:var(--sans);font-size:.55rem;font-weight:300;letter-spacing:.3em;color:var(--gray)}
.footer-mark{font-family:var(--serif2);font-size:.7rem;letter-spacing:.3em;color:var(--gray)}
.footer-mark .red{color:var(--red);font-style:italic}

/* ============================================
   REVEAL
============================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.rv1{transition-delay:.1s}.rv2{transition-delay:.2s}.rv3{transition-delay:.3s}.rv4{transition-delay:.4s}

.sp-br{display:none}
.pc-br{display:block}

@media(min-width:901px){
  .label{font-size:calc(.58rem + 2px)}
}

/* ============================================
   RESPONSIVE
============================================ */
@media(max-width:1000px){
  body{cursor:auto}
  .cursor,.cursor-ring,.cursor-label{display:none}
}
@media(max-width:900px){
  nav{padding:1rem .8rem}
  nav.scrolled{padding:.8rem .8rem}
  .nav-links{gap:1.4rem}
  .hero{padding:0 .8rem}
  .hero-logo-wrap{padding:7rem 0 5rem}
  .hero-meta-l,.hero-meta-r{display:none}
  .sec,.theory-sec,.founder-sec{padding:5rem .8rem}
  .dual-grid,.practice-grid{grid-template-columns:1fr}
  .dual-card{padding:10px}
  .dual-card+.dual-card{border-left:none;border-top:1px solid var(--divider)}
  .practice-grid{border:none}
  .practice-card{border-right:none!important;border-bottom:1px solid var(--rule)!important;padding:10px 0!important;min-height:auto!important}
  .practice-card-logo{width:100px;height:100px;margin-bottom:1rem}
  .practice-card-num{margin-bottom:.4rem}
  .practice-card-tag{margin-bottom:.6rem}
  .practice-card-name{font-size:1.1rem}
  .practice-card:last-child{border-bottom:none!important}
  /* D案: スマホでも3カラム維持しつつ崩れを抑える */
  .pickup-sec{padding:4rem .8rem}
  .pickup-grid{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:.6rem}
  .pickup-card-title{
    font-size:.52rem;
    letter-spacing:.02em;
    padding:.8rem .2rem;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .pickup-card-note{
    font-size:.44rem;
    line-height:1.55;
    padding:.55rem .3rem .65rem;
    min-height:8.7em;
    letter-spacing:0;
  }
  .pickup-card-visual img{
    object-fit:contain;
    padding:.2rem;
    box-sizing:border-box;
    transform:none;
  }
  .ipeace-visual{grid-template-columns:1fr;min-height:auto}
  .ipeace-image{border-right:none;border-bottom:1px solid var(--ink);padding:3rem 1rem}
  .ipeace-text{padding:4rem .8rem}
  .media-grid{grid-template-columns:1fr}
  .media-card{border-left:none;border-bottom:1px solid var(--rule-soft)}
  .media-card:last-child{border-bottom:none}
  .founder-inner{
    grid-template-columns:1fr;
    gap:0;
  }
  .founder-portrait{display:none}
  .founder-header-mobile-portrait{
    display:block;
    float:none;
    width:100%;
    max-width:240px;
    margin:0 auto 1.5rem;
  }
  .founder-header-mobile-portrait img{
    width:100%;height:auto;display:block;
    filter:grayscale(.1);
  }
  .founder-text{text-align:center}
  .founder-name-en{font-size:1.4rem;margin-bottom:.8rem}
  .founder-name-jp{font-size:.82rem;margin-bottom:.6rem}
  .founder-titles{margin-bottom:1.5rem;font-size:.55rem}
  .founder-bio{text-align:left;padding-top:.5rem}
  .theory-content{grid-template-columns:1fr;gap:3rem}
  .manifesto-sec,.press-sec{padding:5rem .8rem}
  .press-list a{flex-direction:column;align-items:flex-start;gap:.8rem;padding:1.2rem 0}
  .press-list a:hover{padding-left:0}
  .press-list-icon{width:108px;height:auto}
  .press-list-title{font-size:.82rem}
  .practice-all a{padding:.9rem 1.2rem;font-size:.6rem;letter-spacing:.2em}
  .press-list-arrow{align-self:flex-end}
  footer{flex-direction:column;gap:1rem;padding:2rem .8rem}
  .footer-left,.footer-center,.footer-right{text-align:center}
}
@media(max-width:600px){
  html{font-size:24px}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .hero{min-height:100svh}
  .hero-name{font-size:1.1rem;letter-spacing:.3em}
  .hero-name .hero-name-gap{display:block;font-size:0;line-height:0;height:.4em}
  .hero-tagline .red{display:block}
  .sp-br{display:block}
  .pc-br{display:none}
  .manifesto-body{font-size:.75rem}
  .ipeace-text .heading-jp{font-size:1.1rem}
}
