/* ==========================================================================
   株式会社グリーンリーフ — 竹 (TICK) tier
   配色: 深緑 + セージ + テラコッタアクセント + paper bg
   フォント: Noto Serif JP / Cormorant Garamond / Noto Sans JP / Inter / Caveat
   ========================================================================== */

/* --- reset --- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0;padding:0}
html{scroll-behavior:auto;-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{
  font-family:"Noto Sans JP","Inter",sans-serif;
  font-weight:400;
  font-size:15px;
  line-height:1.85;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
h1,h2,h3,h4{font-weight:500;line-height:1.3;word-break:auto-phrase;line-break:strict;overflow-wrap:break-word}
p,li,dd,blockquote{word-break:auto-phrase;overflow-wrap:break-word}
h1 .phrase,h2 .phrase,h3 .phrase{display:inline-block;max-width:100%}
.meaning-unit{display:inline-block;max-width:100%;white-space:nowrap}

/* --- design tokens --- */
:root{
  --bg:#faf7f0;
  --bg-warm:#f3ede0;
  --bg-deep:#1f261c;
  --text:#1a1f17;
  --text-sub:#5a5e54;
  --text-mute:#8a8678;
  --primary:#2d3a2a;
  --primary-mid:#475a42;
  --secondary:#6b7d5a;
  --accent:#b88a4a;
  --accent-soft:#d4b88a;
  --line:#c9c2b0;
  --line-soft:#e6dfcf;
  --paper:rgba(250,247,240,0.92);
  --shadow:0 1px 0 rgba(26,31,23,0.06);
  --serif-jp:"Noto Serif JP",serif;
  --sans-jp:"Noto Sans JP",sans-serif;
  --serif-en:"Cormorant Garamond",serif;
  --sans-en:"Inter",sans-serif;
  --script:"Caveat",cursive;
  --pad:clamp(20px,4vw,56px);
  --gutter:clamp(16px,3vw,40px);
  --section-y:clamp(60px,7vw,110px);
}

/* --- layout primitives --- */
.wrap{
  width:100%;
  max-width:1320px;
  margin:0 auto;
  padding:0 var(--pad);
}
.wrap-narrow{max-width:880px;margin:0 auto;padding:0 var(--pad)}
.wrap-wide{max-width:1600px;margin:0 auto;padding:0 var(--pad)}
.section{padding:var(--section-y) 0}
.section-tight{padding:calc(var(--section-y) * .55) 0}

/* --- typography scale (大胆な対比 / scale contrast 強) --- */
.display-1{
  font-family:var(--serif-jp);
  font-weight:400;
  font-size:clamp(2.4rem,6.4vw,5.2rem);
  line-height:1.2;
  letter-spacing:0.02em;
}
.display-2{
  font-family:var(--serif-jp);
  font-weight:400;
  font-size:clamp(1.8rem,4.2vw,3rem);
  line-height:1.36;
  letter-spacing:0.02em;
}
.display-3{
  font-family:var(--serif-jp);
  font-weight:400;
  font-size:clamp(1.4rem,2.6vw,2rem);
  line-height:1.5;
}
.eyebrow{
  font-family:var(--sans-en);
  font-weight:500;
  font-size:.74rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--secondary);
}
.eyebrow-jp{
  font-family:var(--sans-jp);
  font-weight:500;
  font-size:.78rem;
  letter-spacing:.18em;
  color:var(--secondary);
}
.script{
  font-family:var(--script);
  font-weight:400;
  font-size:clamp(1.6rem,3vw,2.4rem);
  color:var(--accent);
  letter-spacing:.02em;
}
.lead{
  font-size:clamp(1rem,1.4vw,1.12rem);
  line-height:2.0;
  color:var(--text-sub);
  max-width:48ch;
}

/* --- section head 配置散らし用 modifier --- */
.section-head{margin-bottom:clamp(40px,6vw,80px);display:flex;flex-direction:column;gap:14px;max-width:680px}
.section-head--center{margin-left:auto;margin-right:auto;text-align:center;align-items:center}
.section-head--right{margin-left:auto;text-align:right;align-items:flex-end}
.section-head .title-pair{display:flex;flex-direction:column;gap:6px}

/* --- buttons (variation: outline / filled / arrow / pill / underline) --- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:14px;
  padding:18px 32px;
  font-family:var(--sans-jp);
  font-weight:500;
  font-size:.92rem;
  letter-spacing:.08em;
  border:1px solid currentColor;
  border-radius:0;
  background:transparent;
  color:var(--text);
  cursor:pointer;
  transition:background .35s ease,color .35s ease,transform .35s ease;
  position:relative;
}
.btn:hover{background:var(--text);color:var(--bg)}
.btn--filled{background:var(--primary);color:var(--bg);border-color:var(--primary)}
.btn--filled:hover{background:var(--bg-deep);border-color:var(--bg-deep)}
.btn--ghost{padding:14px 0;border:0;border-bottom:1px solid var(--text)}
.btn--ghost:hover{background:transparent;color:var(--accent);border-bottom-color:var(--accent)}
.btn .arrow{
  width:22px;height:1px;background:currentColor;position:relative;display:inline-block;
}
.btn .arrow::after{
  content:"";position:absolute;right:-1px;top:-3px;width:7px;height:7px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg);
}
.btn:hover .arrow{width:30px;transition:width .35s ease}
.arrow-link{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--sans-jp);font-weight:500;font-size:.88rem;letter-spacing:.12em;
  border-bottom:1px solid var(--text);padding-bottom:6px;
  transition:gap .3s ease,color .3s ease,border-color .3s ease;
}
.arrow-link:hover{gap:18px;color:var(--accent);border-bottom-color:var(--accent)}

/* --- magnetic wrap (JS が translate を当てる) --- */
.magnetic{display:inline-block;will-change:transform}

/* --- header / nav --- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:22px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  background:transparent;
  transition:background .4s ease,padding .4s ease,backdrop-filter .4s ease;
}
.site-header.is-scrolled{
  background:var(--paper);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  padding:14px var(--pad);
  border-bottom:1px solid var(--line-soft);
}
.brand{
  font-family:var(--serif-jp);font-weight:500;font-size:1.18rem;letter-spacing:.08em;
  display:inline-flex;align-items:center;gap:10px;white-space:nowrap;
}
.brand .leaf{
  width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%,var(--secondary),var(--primary) 70%);
  display:inline-block;position:relative;
}
.brand .leaf::after{content:"";position:absolute;inset:5px;border-radius:50%;border:1px solid var(--bg)}
.nav-list{display:flex;gap:24px;align-items:center;flex-wrap:nowrap}
.nav-list a{
  font-family:var(--sans-jp);font-size:.82rem;font-weight:500;letter-spacing:.06em;
  position:relative;padding:6px 0;white-space:nowrap;
  transition:color .3s ease;
}
.nav-list a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:currentColor;
  transform:scaleX(0);transform-origin:right;transition:transform .35s ease;
}
.nav-list a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-cta{
  font-family:var(--sans-jp);font-size:.82rem;font-weight:500;letter-spacing:.08em;
  padding:11px 18px;border:1px solid var(--text);white-space:nowrap;
  transition:background .35s ease,color .35s ease;
}
.nav-cta:hover{background:var(--text);color:var(--bg)}
.menu-toggle{display:none;width:34px;height:34px;border:0;background:transparent;flex-direction:column;justify-content:space-between;padding:8px 4px;cursor:pointer}
.menu-toggle span{display:block;height:1px;background:var(--text);transition:transform .3s ease,opacity .3s ease}

@media(max-width:1080px){
  .nav-list,.nav-cta{display:none}
  .menu-toggle{display:flex}
  .site-header.menu-open .menu-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .site-header.menu-open .menu-toggle span:nth-child(2){opacity:0}
  .site-header.menu-open .menu-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* --- mobile drawer --- */
.drawer{
  position:fixed;inset:0;z-index:40;background:var(--bg-deep);color:var(--bg);
  display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:0 var(--pad);gap:28px;
  transform:translateY(-100%);transition:transform .55s cubic-bezier(.7,0,.2,1),visibility 0s linear .55s;
  visibility:hidden;pointer-events:none;
}
.drawer.is-open{visibility:visible;pointer-events:auto;transition:transform .55s cubic-bezier(.7,0,.2,1),visibility 0s linear 0s}
.drawer.is-open{transform:translateY(0)}
.drawer a{font-family:var(--serif-jp);font-size:1.6rem;letter-spacing:.06em}
.drawer .drawer-meta{margin-top:40px;font-size:.84rem;color:var(--accent-soft);line-height:1.9}

/* smartphone: shrink drawer to ~50% for stylish look */
@media(max-width:760px){
  .drawer{gap:14px;padding:0 var(--pad)}
  .drawer a{font-size:.82rem;letter-spacing:.08em;line-height:1.4}
  .drawer .drawer-meta{margin-top:24px;font-size:.62rem;line-height:1.7}
}
@media(max-width:560px){
  .drawer{gap:12px}
  .drawer a{font-size:.78rem}
}

/* --- hero --- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:flex-end;
  padding:140px var(--pad) clamp(60px,8vw,120px);
  overflow:hidden;
  isolation:isolate;
}
.hero__media{
  position:absolute;inset:0;z-index:0;overflow:hidden;
}
.hero__media{
  background-size:cover;background-position:center;background-color:var(--bg-deep);
}
.hero__media video,
.hero__media .hero__poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.14) contrast(1.04) brightness(0.94) sepia(0.04);
  will-change:transform;
}
.hero__media .hero__poster{
  background-size:cover;background-position:center;
}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(31,38,28,.42) 0%,rgba(31,38,28,.08) 35%,rgba(31,38,28,.22) 70%,rgba(31,38,28,.55) 100%);
  z-index:1;
}
.hero__inner{position:relative;z-index:2;color:var(--bg);width:100%;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:40px;align-items:end}
.hero__copy{max-width:820px}
.hero__copy .eyebrow{color:var(--accent-soft);margin-bottom:16px}
.hero__copy h1{
  font-family:var(--serif-jp);font-weight:400;
  font-size:clamp(2.2rem,5.4vw,4.6rem);
  line-height:1.28;letter-spacing:.02em;
  color:var(--bg);margin-bottom:24px;
}
.hero__copy h1 .phrase{display:inline-block;max-width:100%}
.hero__copy h1 .accent{color:var(--accent-soft);font-style:italic;font-family:var(--serif-en);font-weight:400}
.hero__copy .hero__lead{
  font-size:clamp(1rem,1.3vw,1.12rem);line-height:1.95;color:rgba(250,247,240,.86);max-width:min(100%,520px);margin-bottom:32px;
}
.hero__copy .hero__cta{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.hero__copy .btn{color:var(--bg);border-color:var(--bg)}
.hero__copy .btn:hover{background:var(--bg);color:var(--text)}
.hero__copy .btn--filled{background:var(--accent);border-color:var(--accent);color:var(--bg-deep)}
.hero__copy .btn--filled:hover{background:var(--accent-soft);border-color:var(--accent-soft);color:var(--bg-deep)}
.hero__signature{
  position:absolute;left:var(--pad);bottom:80px;
  font-family:var(--script);font-size:1.6rem;color:var(--accent-soft);transform:rotate(-2deg);
  display:none;/* index 以外は非表示, 後で .hero--top で表示 */
}
.hero--top .hero__signature{display:block;left:auto;right:calc(var(--pad) + 180px);bottom:90px;font-size:2rem}

/* hero floating award badge */
.hero__badge{
  position:absolute;right:calc(var(--pad) + 20px);bottom:40px;
  width:148px;height:148px;border-radius:50%;
  border:1px solid rgba(212,184,138,.7);
  display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--accent-soft);
  font-family:var(--serif-jp);font-size:.74rem;letter-spacing:.06em;line-height:1.7;
  z-index:3;
  background:rgba(31,38,28,.32);backdrop-filter:blur(2px);
}
.hero__badge span{display:block}
.hero__badge .badge-year{font-size:1.5rem;font-family:var(--serif-jp);letter-spacing:.04em;color:var(--bg);margin-bottom:4px}
.hero__badge-text{
  position:absolute;inset:0;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.hero__badge-text svg{width:100%;height:100%}
.hero__badge-text textPath{font-family:var(--serif-en);font-size:7px;letter-spacing:.42em;fill:var(--accent-soft)}

@media(max-width:760px){
  .hero__inner{grid-template-columns:1fr}
  .hero__badge{width:108px;height:108px;font-size:.66rem;right:var(--pad);bottom:24px}
  .hero--top .hero__signature{right:var(--pad);bottom:auto;top:130px;font-size:1.4rem}
}
@media(max-width:600px){
  .hero__copy h1{
    font-size:clamp(1.55rem,6.8vw,2rem);
    line-height:1.38;
  }
  .hero__copy h1 .phrase{display:inline-block}
}

/* hero scroll cue */
.hero__cue{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  font-family:var(--sans-en);font-size:.66rem;letter-spacing:.5em;color:rgba(250,247,240,.7);
  display:flex;flex-direction:column;align-items:center;gap:10px;z-index:3;
}
.hero__cue::after{content:"";width:1px;height:32px;background:rgba(250,247,240,.55);animation:cueLine 1.8s ease-in-out infinite}
@keyframes cueLine{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* --- atmosphere strip (見出しなし全幅 photo band) --- */
.strip{
  width:100%;height:clamp(220px,28vw,360px);
  background-size:cover;background-position:center;
  filter:grayscale(0.18) contrast(1.04) brightness(0.96) sepia(0.06);
  position:relative;
}
.strip::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent,rgba(31,38,28,.18));
}

/* --- intro / about excerpt --- */
.intro{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
  gap:clamp(40px,6vw,100px);
  align-items:start;
}
.intro__media{
  position:relative;aspect-ratio:4/5;overflow:hidden;
}
.intro__media img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.18) contrast(1.04) brightness(0.96) sepia(0.06);
  transition:transform 1.4s cubic-bezier(.2,.6,.2,1);
}
.intro__media:hover img{transform:scale(1.04)}
.intro__copy h2{margin-bottom:20px}
.intro__copy p{font-size:1rem;line-height:2;color:var(--text-sub);margin-bottom:1.2em;max-width:min(100%,46ch)}
.intro__copy .quote{
  margin:32px 0 24px;padding-left:20px;border-left:2px solid var(--accent);
  font-family:var(--serif-jp);font-size:1.16rem;line-height:1.85;color:var(--text);font-style:normal;
}
.intro__copy .quote-byline{font-family:var(--sans-en);font-size:.74rem;letter-spacing:.28em;color:var(--text-mute);margin-bottom:32px;text-transform:uppercase}

@media(max-width:880px){
  .intro{grid-template-columns:1fr}
  .intro__media{aspect-ratio:5/4;max-width:520px}
}

/* --- services 4本: 写真カード化 + asymmetry --- */
.services{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:var(--gutter);
}
.service-card{
  position:relative;display:block;overflow:hidden;
  background:var(--bg);
  transition:transform .6s cubic-bezier(.2,.6,.2,1);
}
.service-card .photo{
  position:relative;aspect-ratio:4/3;overflow:hidden;
}
.service-card .photo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.18) contrast(1.04) brightness(0.96) sepia(0.06);
  transition:transform 1.6s cubic-bezier(.2,.6,.2,1),filter .6s ease;
}
.service-card:hover .photo img{
  transform:scale(1.06);
  filter:grayscale(0) contrast(1.04) brightness(1) sepia(0);
}
.service-card .meta{padding:24px 4px 8px;display:flex;flex-direction:column;gap:6px}
.service-card .meta .num{font-family:var(--serif-en);font-size:.84rem;color:var(--accent);letter-spacing:.18em}
.service-card .meta h3{font-family:var(--serif-jp);font-size:1.32rem;letter-spacing:.04em;font-weight:500}
.service-card .meta .sub{font-family:var(--sans-en);font-size:.72rem;letter-spacing:.28em;color:var(--text-mute);text-transform:uppercase}
.service-card .meta p{font-size:.94rem;line-height:1.95;color:var(--text-sub);margin-top:8px;max-width:min(100%,38ch)}
.service-card .meta .arrow-link{align-self:flex-start;margin-top:18px}

/* asymmetry: 1枚を大きく / 2 枚を中 / 1枚を小 + offset */
.service-card--lg{grid-column:span 7;grid-row:span 2}
.service-card--md{grid-column:span 5}
.service-card--sm{grid-column:span 6}
.service-card--lg .photo{aspect-ratio:1/1}
.service-card--lg .meta h3{font-size:1.7rem}

@media(max-width:880px){
  .services{grid-template-columns:1fr}
  .service-card--lg,.service-card--md,.service-card--sm{grid-column:1/-1;grid-row:auto}
}

/* --- counter (取引先メトリクス) --- */
.metrics{
  display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gutter);
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  padding:clamp(40px,6vw,80px) 0;
}
.metric{display:flex;flex-direction:column;gap:6px;padding:0 8px}
.metric .num{font-family:var(--serif-jp);font-size:clamp(2.4rem,5vw,4rem);font-weight:400;color:var(--primary);line-height:1}
.metric .num .unit{font-family:var(--sans-jp);font-size:1rem;color:var(--text-mute);margin-left:6px}
.metric .label{font-family:var(--sans-jp);font-size:.84rem;color:var(--text-sub);letter-spacing:.12em}
.metric .desc{font-size:.86rem;color:var(--text-mute);line-height:1.7;margin-top:8px;max-width:min(100%,24ch)}
.metric:nth-child(2){border-left:1px solid var(--line-soft);border-right:1px solid var(--line-soft);padding-left:32px;padding-right:32px}
@media(max-width:760px){
  .metrics{grid-template-columns:1fr}
  .metric:nth-child(2){border:0;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:32px 0}
}

/* --- works gallery (asymmetric grid) --- */
.works-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gutter);
}
.work-card{
  position:relative;display:block;overflow:hidden;background:var(--bg-warm);
}
.work-card .photo{position:relative;aspect-ratio:4/5;overflow:hidden}
.work-card .photo img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(0.32) contrast(1.06) brightness(.94) sepia(0.08);
  transition:transform 1.4s ease,filter .6s ease;
}
.work-card:hover .photo img{filter:grayscale(0) contrast(1.04) brightness(1) sepia(0);transform:scale(1.04)}
.work-card .meta{padding:18px 4px 0;display:flex;flex-direction:column;gap:4px}
.work-card .meta .cat{font-family:var(--sans-en);font-size:.7rem;letter-spacing:.28em;color:var(--accent);text-transform:uppercase}
.work-card .meta h3{font-family:var(--serif-jp);font-size:1.06rem;font-weight:500;letter-spacing:.04em}
.work-card .meta .place{font-size:.82rem;color:var(--text-mute)}

.work-card--lg{grid-column:span 7;grid-row:span 2}
.work-card--lg .photo{aspect-ratio:4/5}
.work-card--md{grid-column:span 5}
.work-card--sm{grid-column:span 4}
.work-card--md .photo{aspect-ratio:4/5}
.work-card--sm .photo{aspect-ratio:1/1}

@media(max-width:880px){
  .works-grid{grid-template-columns:repeat(2,1fr)}
  .work-card--lg,.work-card--md,.work-card--sm{grid-column:span 1;grid-row:auto}
}
@media(max-width:560px){
  .works-grid{grid-template-columns:1fr}
  .work-card--lg,.work-card--md,.work-card--sm{grid-column:1}
}

/* --- plans excerpt --- */
.plans{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--line-soft);
}
.plan{
  padding:clamp(28px,4vw,48px) clamp(20px,3vw,36px);
  border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:14px;
  background:var(--bg);
  transition:background .4s ease;
}
.plan:last-child{border-right:0}
.plan:hover{background:var(--bg-warm)}
.plan .name{font-family:var(--serif-jp);font-size:1.3rem;font-weight:500;letter-spacing:.04em}
.plan .name .en{font-family:var(--serif-en);font-style:italic;font-size:.96rem;color:var(--accent);margin-left:8px;letter-spacing:.04em}
.plan .price{display:flex;align-items:baseline;gap:6px}
.plan .price .num{font-family:var(--serif-jp);font-size:2.2rem;font-weight:400;color:var(--primary);line-height:1}
.plan .price .unit{font-size:.8rem;color:var(--text-mute)}
.plan .desc{font-size:.92rem;line-height:1.95;color:var(--text-sub)}
.plan ul{display:flex;flex-direction:column;gap:8px;margin:6px 0;padding:0}
.plan ul li{font-size:.86rem;color:var(--text-sub);padding-left:16px;position:relative}
.plan ul li::before{content:"";position:absolute;left:0;top:.7em;width:8px;height:1px;background:var(--accent)}
.plan .arrow-link{margin-top:auto}

@media(max-width:880px){.plans{grid-template-columns:1fr}.plan{border-right:0}}

/* --- voice / testimonials (text only quotes / 写真カード過剰回避) --- */
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gutter)}
.voice{
  padding:32px;border-top:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:18px;
}
.voice blockquote{font-family:var(--serif-jp);font-size:1.04rem;line-height:1.95;color:var(--text)}
.voice .voice-meta{font-family:var(--sans-en);font-size:.74rem;letter-spacing:.18em;color:var(--text-mute);text-transform:uppercase}
.voice .voice-name{font-family:var(--serif-jp);font-size:.96rem;letter-spacing:.04em}
@media(max-width:760px){.voice-grid{grid-template-columns:1fr}}

/* --- news --- */
.news-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line-soft)}
.news-item{
  display:grid;grid-template-columns:140px 100px 1fr auto;gap:24px;
  padding:24px 8px;border-bottom:1px solid var(--line-soft);align-items:center;
  transition:background .35s ease,padding .35s ease;
}
.news-item:hover{background:var(--bg-warm);padding-left:20px}
.news-item .date{font-family:var(--sans-en);font-size:.84rem;color:var(--text-mute);letter-spacing:.06em}
.news-item .cat{
  font-family:var(--sans-jp);font-size:.74rem;letter-spacing:.12em;
  border:1px solid var(--line);padding:4px 10px;display:inline-flex;justify-self:start;color:var(--text-sub);
}
.news-item h3{font-family:var(--serif-jp);font-size:1rem;font-weight:500;letter-spacing:.04em}
.news-item .arrow{width:18px;height:1px;background:var(--text-mute);position:relative;transition:width .3s ease,background .3s ease}
.news-item .arrow::after{content:"";position:absolute;right:-1px;top:-3px;width:7px;height:7px;border-top:1px solid var(--text-mute);border-right:1px solid var(--text-mute);transform:rotate(45deg);transition:border-color .3s ease}
.news-item:hover .arrow{width:30px;background:var(--accent)}
.news-item:hover .arrow::after{border-color:var(--accent)}

@media(max-width:760px){
  .news-item{grid-template-columns:1fr;gap:6px;padding:18px 8px}
  .news-item .arrow{display:none}
}

/* --- access excerpt --- */
.access-block{
  display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:var(--gutter);align-items:start;
}
.access-block__media{aspect-ratio:4/3;overflow:hidden}
.access-block__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.32) contrast(1.06) brightness(.94) sepia(0.08)}
.access-block__info{padding:8px 0;display:flex;flex-direction:column;gap:18px}
.access-block__info dl{display:grid;grid-template-columns:120px 1fr;row-gap:14px;column-gap:18px}
.access-block__info dt{font-family:var(--sans-en);font-size:.74rem;letter-spacing:.22em;color:var(--text-mute);padding-top:4px;text-transform:uppercase}
.access-block__info dd{font-size:.96rem;color:var(--text);line-height:1.85}
.access-block__info .access-cta{margin-top:14px}
@media(max-width:880px){
  .access-block{grid-template-columns:1fr}
}

/* --- bottom CTA band --- */
.cta-band{
  background:var(--bg-deep);color:var(--bg);padding:clamp(70px,10vw,140px) var(--pad);
  position:relative;overflow:hidden;text-align:center;
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 80% 20%,rgba(184,138,74,.16),transparent 60%),
             radial-gradient(ellipse at 20% 80%,rgba(107,125,90,.18),transparent 55%);
}
.cta-band__inner{position:relative;display:flex;flex-direction:column;gap:24px;align-items:center;max-width:760px;margin:0 auto}
.cta-band h2{font-family:var(--serif-jp);font-weight:400;font-size:clamp(2rem,4.5vw,3.4rem);line-height:1.4;letter-spacing:.04em}
.cta-band .lead{color:rgba(250,247,240,.72);max-width:min(100%,48ch);text-align:center;margin:0 auto}
.cta-band .btn{color:var(--bg);border-color:rgba(250,247,240,.6)}
.cta-band .btn--filled{background:var(--accent);border-color:var(--accent);color:var(--bg-deep)}
.cta-band .btn--filled:hover{background:var(--accent-soft);border-color:var(--accent-soft)}
.cta-band .script{color:var(--accent-soft)}

/* --- footer --- */
.site-footer{background:var(--bg-deep);color:rgba(250,247,240,.85);padding:clamp(70px,8vw,120px) var(--pad) 32px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:60px;border-bottom:1px solid rgba(250,247,240,.12)}
.footer-grid h4{font-family:var(--serif-jp);font-size:.86rem;letter-spacing:.18em;color:var(--accent-soft);margin-bottom:18px;font-weight:500}
.footer-grid ul{display:flex;flex-direction:column;gap:10px}
.footer-grid a{font-size:.84rem;color:rgba(250,247,240,.72);transition:color .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;max-width:100%}
.footer-grid a:hover{color:var(--accent-soft)}
.footer-brand{font-family:var(--serif-jp);font-size:1.32rem;color:var(--bg);margin-bottom:14px;display:inline-flex;align-items:center;gap:10px;white-space:nowrap}
.footer-brand .leaf{width:24px;height:24px}
.footer-tagline{font-size:.84rem;line-height:1.95;color:rgba(250,247,240,.6);margin-bottom:18px;max-width:min(100%,34ch)}
.footer-bottom{padding-top:32px;display:flex;justify-content:space-between;flex-wrap:nowrap;gap:24px;font-size:.74rem;color:rgba(250,247,240,.5);letter-spacing:.06em;white-space:nowrap}
.footer-bottom .legal{display:inline-flex;gap:18px;flex-shrink:0}
.footer-bottom .legal a{color:rgba(250,247,240,.5);transition:color .3s ease}
.footer-bottom .legal a:hover{color:var(--accent-soft)}
@media(max-width:980px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}.footer-bottom{flex-wrap:wrap;white-space:normal}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* --- custom cursor --- */
.cursor{position:fixed;top:0;left:0;width:24px;height:24px;border:1px solid var(--text);border-radius:50%;pointer-events:none;z-index:200;transform:translate(-50%,-50%);transition:width .25s ease,height .25s ease,border-color .25s ease,background .25s ease,opacity .25s ease;mix-blend-mode:difference;backdrop-filter:invert(1)}
.cursor.is-hover{width:54px;height:54px;border-color:var(--accent-soft);background:rgba(184,138,74,.12)}
.cursor.is-text{width:2px;height:36px;border-radius:0;border-color:var(--bg);background:var(--bg)}
.cursor.is-hidden{opacity:0}
@media(hover:none),(max-width:760px){.cursor{display:none}}

/* --- reveal variants (8 種類: up / left / right / scale / image-mask / stagger-up / stagger-fan / stagger-rows) --- */
[data-reveal]{opacity:1}
[data-reveal="up"]{opacity:0;transform:translateY(36px);transition:opacity 1s ease,transform 1.1s cubic-bezier(.2,.6,.2,1)}
[data-reveal="up"].is-in{opacity:1;transform:translateY(0)}
[data-reveal="left"]{opacity:0;transform:translateX(-32px);transition:opacity 1s ease,transform 1.1s cubic-bezier(.2,.6,.2,1)}
[data-reveal="left"].is-in{opacity:1;transform:translateX(0)}
[data-reveal="right"]{opacity:0;transform:translateX(32px);transition:opacity 1s ease,transform 1.1s cubic-bezier(.2,.6,.2,1)}
[data-reveal="right"].is-in{opacity:1;transform:translateX(0)}
[data-reveal="scale"]{opacity:0;transform:scale(.96);transition:opacity 1s ease,transform 1.2s cubic-bezier(.2,.6,.2,1)}
[data-reveal="scale"].is-in{opacity:1;transform:scale(1)}
[data-reveal="image"]{position:relative;overflow:hidden;clip-path:inset(0 100% 0 0);transition:clip-path 1.4s cubic-bezier(.6,.0,.2,1)}
[data-reveal="image"].is-in{clip-path:inset(0 0 0 0)}

[data-stagger] > *{opacity:0;transform:translateY(28px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.6,.2,1)}
[data-stagger].is-in > *:nth-child(1){opacity:1;transform:translateY(0);transition-delay:0s}
[data-stagger].is-in > *:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.08s}
[data-stagger].is-in > *:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.16s}
[data-stagger].is-in > *:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.24s}
[data-stagger].is-in > *:nth-child(5){opacity:1;transform:translateY(0);transition-delay:.32s}
[data-stagger].is-in > *:nth-child(6){opacity:1;transform:translateY(0);transition-delay:.4s}
[data-stagger].is-in > *:nth-child(7){opacity:1;transform:translateY(0);transition-delay:.48s}
[data-stagger].is-in > *:nth-child(8){opacity:1;transform:translateY(0);transition-delay:.56s}
[data-stagger].is-in > *:nth-child(9){opacity:1;transform:translateY(0);transition-delay:.64s}

/* fan (扇状にずれて出現) */
[data-stagger="fan"].is-in > *:nth-child(odd){transform:translateY(0) rotate(0)}
[data-stagger="fan"] > *:nth-child(odd){transform:translateY(28px) rotate(-1deg)}
[data-stagger="fan"] > *:nth-child(even){transform:translateY(40px) rotate(1deg)}
[data-stagger="fan"].is-in > *{transform:translateY(0) rotate(0)}

/* reduced motion fallback (除外基準: opacity 固定固まり対策) */
@media (prefers-reduced-motion:reduce){
  [data-reveal],[data-stagger] > *{opacity:1 !important;transform:none !important;clip-path:none !important;transition:none !important}
  .hero__badge{animation:none}
  .hero__cue::after{animation:none}
}

/* --- inner page hero (top 以外のページ用) --- */
.page-hero{
  padding:160px var(--pad) clamp(60px,8vw,120px);
  display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:var(--gutter);
  align-items:end;border-bottom:1px solid var(--line-soft);
}
.page-hero h1{
  font-family:var(--serif-jp);font-weight:400;
  font-size:clamp(2.2rem,5vw,4.2rem);line-height:1.2;letter-spacing:.02em;
}
.page-hero .eyebrow{margin-bottom:14px}
.page-hero .lead{margin-top:14px}
.breadcrumb{font-family:var(--sans-en);font-size:.74rem;letter-spacing:.18em;color:var(--text-mute);text-transform:uppercase;margin-bottom:18px}
.breadcrumb a:hover{color:var(--accent)}
.breadcrumb span{margin:0 8px;color:var(--line)}
@media(max-width:760px){.page-hero{grid-template-columns:1fr}}

/* --- definition list (会社概要 / FAQ) --- */
.deflist{display:grid;grid-template-columns:200px 1fr;gap:18px 32px;border-top:1px solid var(--line-soft)}
.deflist dt,.deflist dd{padding:18px 0;border-bottom:1px solid var(--line-soft)}
.deflist dt{font-family:var(--sans-jp);font-size:.86rem;color:var(--text-sub);letter-spacing:.06em}
.deflist dd{font-size:.96rem;color:var(--text);line-height:1.85}
@media(max-width:760px){.deflist{grid-template-columns:1fr;gap:0}.deflist dt{padding-bottom:6px;border-bottom:0}.deflist dd{padding-top:0}}

/* --- form --- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:24px 32px}
.form .field{display:flex;flex-direction:column;gap:8px}
.form .field--full{grid-column:1/-1}
.form label{font-family:var(--sans-jp);font-size:.84rem;letter-spacing:.08em;color:var(--text-sub)}
.form label .req{color:var(--accent);margin-left:6px;font-size:.7rem}
.form input,.form select,.form textarea{
  border:0;border-bottom:1px solid var(--line);background:transparent;padding:14px 0;
  font-family:var(--sans-jp);font-size:1rem;color:var(--text);
  transition:border-color .3s ease;
}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-bottom-color:var(--accent)}
.form textarea{resize:vertical;min-height:160px}
.form .submit{grid-column:1/-1;margin-top:18px}
.form .check-row{font-size:.86rem;color:var(--text-sub);display:flex;gap:10px;align-items:flex-start}
@media(max-width:760px){.form{grid-template-columns:1fr}}

/* --- FAQ accordion --- */
.faq{border-top:1px solid var(--line-soft)}
.faq details{border-bottom:1px solid var(--line-soft);padding:24px 0}
.faq summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--serif-jp);font-size:1.06rem;font-weight:500;letter-spacing:.04em;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q{font-family:var(--serif-en);font-size:.96rem;color:var(--accent);margin-right:14px}
.faq summary .icon{width:18px;height:1px;background:var(--text);position:relative;transition:transform .3s ease}
.faq summary .icon::after{content:"";position:absolute;left:0;top:0;width:100%;height:100%;background:var(--text);transform:rotate(90deg);transition:transform .3s ease}
.faq details[open] summary .icon::after{transform:rotate(0)}
.faq .answer{padding:18px 0 0;font-size:.96rem;line-height:2;color:var(--text-sub);max-width:64ch}
.faq .answer .a{font-family:var(--serif-en);font-size:.96rem;color:var(--secondary);margin-right:10px}

/* --- privacy / legal page --- */
.legal-doc{max-width:780px;margin:0 auto;padding:0 var(--pad)}
.legal-doc h2{font-family:var(--serif-jp);font-size:1.4rem;margin:36px 0 14px;letter-spacing:.04em}
.legal-doc h3{font-family:var(--serif-jp);font-size:1.06rem;margin:28px 0 8px;color:var(--primary)}
.legal-doc p,.legal-doc li{font-size:.94rem;line-height:2;color:var(--text-sub);margin-bottom:1em}
.legal-doc ul{padding-left:1.4em;list-style:disc}
.legal-doc ol{padding-left:1.4em;list-style:decimal;color:var(--text-sub)}

/* --- works detail --- */
.work-detail-hero{
  position:relative;height:80vh;min-height:520px;overflow:hidden;
}
.work-detail-hero img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.18) contrast(1.04) brightness(.86) sepia(0.06)}
.work-detail-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(31,38,28,.7) 100%)}
.work-detail-hero .copy{position:absolute;left:var(--pad);bottom:60px;color:var(--bg);max-width:680px;z-index:2}
.work-detail-hero .copy h1{font-family:var(--serif-jp);font-weight:400;font-size:clamp(2rem,5vw,4rem);letter-spacing:.04em;line-height:1.2;margin-bottom:14px}
.work-detail-hero .copy .meta{display:flex;gap:24px;flex-wrap:wrap;font-family:var(--sans-en);font-size:.74rem;letter-spacing:.22em;color:var(--accent-soft);text-transform:uppercase}
.work-detail-body{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:var(--gutter)}
.work-detail-body .body-text{padding-right:24px}
.work-detail-body .body-text h2{font-family:var(--serif-jp);font-size:1.4rem;margin:24px 0 14px;letter-spacing:.04em}
.work-detail-body .body-text p{font-size:1rem;line-height:2;color:var(--text-sub);margin-bottom:1.2em}
.work-detail-body .meta-card{padding:32px;background:var(--bg-warm);position:sticky;top:100px;align-self:start}
.work-detail-body .meta-card dl{display:grid;grid-template-columns:1fr;gap:16px}
.work-detail-body .meta-card dt{font-family:var(--sans-en);font-size:.7rem;letter-spacing:.22em;color:var(--text-mute);text-transform:uppercase;margin-bottom:4px}
.work-detail-body .meta-card dd{font-family:var(--serif-jp);font-size:1rem;letter-spacing:.04em;border-bottom:1px solid var(--line-soft);padding-bottom:12px}
.work-detail-body .meta-card dd:last-of-type{border-bottom:0}
@media(max-width:880px){.work-detail-body{grid-template-columns:1fr}.work-detail-body .meta-card{position:static}}

/* --- plant catalog grid --- */
.plant-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gutter)}
.plant-card{display:flex;flex-direction:column;gap:12px}
.plant-card .photo{aspect-ratio:4/5;overflow:hidden}
.plant-card .photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.18) contrast(1.04) brightness(.96) sepia(0.06);transition:transform 1.2s ease}
.plant-card:hover .photo img{transform:scale(1.04)}
.plant-card .name{font-family:var(--serif-jp);font-size:1.06rem;font-weight:500;letter-spacing:.04em}
.plant-card .name .latin{font-family:var(--serif-en);font-style:italic;font-size:.84rem;color:var(--text-mute);margin-left:6px;letter-spacing:.02em}
.plant-card .desc{font-size:.84rem;color:var(--text-sub);line-height:1.85}
@media(max-width:880px){.plant-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.plant-grid{grid-template-columns:1fr}}

/* --- utility --- */
.txt-center{text-align:center}
.mt-sm{margin-top:24px}
.mt-md{margin-top:48px}
.mt-lg{margin-top:80px}
.divider{height:1px;background:var(--line-soft);margin:0 auto;max-width:120px}
.tag{display:inline-flex;padding:6px 12px;border:1px solid var(--line);font-family:var(--sans-jp);font-size:.74rem;color:var(--text-sub);letter-spacing:.08em}

/* --- sub strip / parallax helper --- */
[data-parallax]{will-change:transform}

/* ==========================================================================
   改行・視覚的違和感 polish — 2026-06-02
   1) 見出しの 1 文字 orphan 行 → 自然な日本語改行 + text-wrap:balance で均等化
   2) 本文の短い orphan 末行 → text-wrap:pretty
   3) モバイルで display 見出しを微縮小し、定型フレーズが 1 行に収まるよう調整
   ========================================================================== */

/* 見出し: 固定の句ブロックを解除して自然な日本語改行を許可し、balance で行長を均す。
   line-break:strict で句読点・小書き仮名の行頭禁則は維持する。
   .phrase は意味の区切りとして残すが、幅は固定しない。 */
.display-1,.display-2,.display-3,
.hero__copy h1,.page-hero h1,
.cta-band h2,.intro__copy h2,
.section-head h2,.work-detail-hero .copy h1,
.news-item h3,.work-card .meta h3,.service-card .meta h3,
.plan .name,.metric .label{
  word-break:normal;
  line-break:strict;
  text-wrap:balance;
}
h1 .phrase,h2 .phrase,h3 .phrase{text-wrap:balance}
h1 .phrase,h2 .phrase,h3 .phrase{display:inline-block;max-width:100%}

/* 本文: 末行が極端に短くなる orphan を回避（Chrome 117+/Safari 17.5+） */
.lead,.hero__lead,.intro__copy p,.service-card .meta p,
.plan .desc,.metric .desc,.access-block__info dd,.deflist dd,
.faq .answer,.legal-doc p,.legal-doc li,.work-detail-body .body-text p,
.work-detail-body .meta-card dd,.footer-tagline,.plant-card .desc,
.voice blockquote{
  text-wrap:pretty;
  overflow-wrap:break-word;
}

/* モバイル: display 見出しを微縮小（12〜13 文字の定型フレーズが 1 行に収まる） */
@media(max-width:600px){
  .display-1{font-size:clamp(1.9rem,8vw,2.6rem)}
  .display-2{font-size:clamp(1.4rem,6vw,1.78rem)}
  .display-3{font-size:clamp(1.2rem,5vw,1.55rem)}
  .page-hero h1{font-size:clamp(1.9rem,8.4vw,2.6rem)}
  .cta-band h2{font-size:clamp(1.6rem,6.4vw,2.1rem)}
}

/* news / work タイトル: 境界で 1 文字落ちしていたため字間を詰めて 1 行に収める */
@media(max-width:760px){
  .news-item h3{letter-spacing:.01em}
}

/* footer タグライン: 読点で折り返し、語（一鉢 等）を分断させない */
.footer-tagline{word-break:keep-all;line-break:strict}

/* --- print --- */
@media print{
  .site-header,.cursor,.cta-band,.site-footer{display:none}
  .hero{min-height:auto;padding:60px 20px}
}
