/*
Theme Name: 株式会社 結 (Yui Architects)
Theme URI: https://yui-style.jp/
Author: 結
Description: 株式会社 結 公式サイト。自然素材と職人技をテーマにした建築・リフォーム会社のWordPressテーマ。
Version: 1.0.0
Text Domain: yui-style
*/

:root{
  --c-fg:#1f2520;
  --c-bg:#faf6ef;
  --c-bg-2:#f3ecdd;
  --c-accent:#8a7558;       /* ベージュ・タープ（明るめ） */
  --c-accent-dark:#5e4e3a;
  --c-accent-2:#7a6a4a;     /* 木のブラウン */
  --c-accent-3:#b89b6a;     /* ゴールド */
  --c-line:#d8cdb6;
  --c-muted:#80796b;
  --font-mincho:"Shippori Mincho","Noto Serif JP",serif;
  --font-gothic:"M PLUS Rounded 1c",sans-serif;
  --font-en:"Cormorant Garamond",serif;
  --font-en-deco:"Italiana",serif;
  --container:1200px;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease-soft:cubic-bezier(.34,.08,.32,1);  /* ふわっとホバー用 */
  --radius-sm:8px;
  --radius-md:14px;
  --radius-lg:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-gothic);
  color:var(--c-fg);
  background:#fff;
  line-height:1.95;
  font-weight:400;
  font-feature-settings:"palt";
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
  padding:0 !important;
  margin:0 !important;
}
html{overflow-x:clip;padding:0;margin:0}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:opacity .3s var(--ease)}
.container{max-width:var(--container);margin:0 auto;padding:0 28px}
.en{font-family:var(--font-en);letter-spacing:.1em;font-weight:400}

/* === 全体に流れるドットノイズ背景 === */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:radial-gradient(circle,rgba(120,100,70,.025) 1px,transparent 1px);
  background-size:24px 24px;
}

/* ===== ローディング演出（初回のみ・白ベース） ===== */
.loader{
  position:fixed;inset:0;z-index:10000;background:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:36px;
  transition:opacity 1.4s var(--ease),visibility 1.4s var(--ease);
  pointer-events:none;
}
.loader-mark{
  width:120px;height:120px;
  display:flex;align-items:center;justify-content:center;
  opacity:0;animation:loaderFade 1.8s var(--ease) forwards;
  position:relative;
}
.loader-mark img{width:100%;height:100%;object-fit:contain;display:block}
.loader-mark::after{
  content:"YUI STYLE";
  position:absolute;bottom:-34px;left:50%;transform:translateX(-50%);
  font-family:var(--font-en);font-size:10px;font-weight:400;
  letter-spacing:.45em;color:var(--c-accent-3);
  white-space:nowrap;
  opacity:0;animation:loaderSubFade 1.8s var(--ease) .35s forwards;
}
@keyframes loaderFade{
  0%{opacity:0;transform:scale(.85) translateY(8px)}
  60%{opacity:1;transform:scale(1) translateY(0)}
  100%{opacity:1;transform:scale(1)}
}
@keyframes loaderSubFade{
  0%{opacity:0}
  100%{opacity:1}
}
.loader-bar{
  width:180px;height:1px;background:rgba(122,106,74,.15);
  position:relative;overflow:hidden;margin-top:24px;
}
.loader-bar::before{
  content:"";position:absolute;top:0;left:0;height:100%;
  width:30%;background:var(--c-accent-2);
  animation:loaderBar 1.6s ease-in-out infinite;
}
@keyframes loaderBar{
  0%{left:-30%}
  100%{left:100%}
}
.loaded .loader{opacity:0;visibility:hidden;pointer-events:none}
/* 2回目以降は最初から非表示 */
.no-loader .loader{display:none}

/* ===== ヘッダー ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(250,246,239,.94);
  backdrop-filter:blur(16px) saturate(1.1);
  border-bottom:1px solid rgba(216,205,182,.5);
  transition:all .6s var(--ease);
  transform:translateY(-100%);
}
.loaded .header{transform:translateY(0)}
/* 2回目以降は最初から表示 */
.no-loader .header{transform:translateY(0)}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 40px;max-width:1440px;margin:0 auto;
}
.logo{display:flex;align-items:center;gap:14px;position:relative;z-index:2}
.logo-mark{
  width:54px;height:54px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
  transition:transform .6s var(--ease-soft);
}
.logo-mark img{width:100%;height:100%;object-fit:contain;display:block}
.logo:hover .logo-mark{transform:rotate(-6deg) scale(1.05)}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-name{font-family:var(--font-gothic);font-size:18px;font-weight:500;letter-spacing:.12em}
.logo-sub{font-family:var(--font-en);font-size:11px;color:var(--c-accent-3);letter-spacing:.25em;margin-top:3px}
.nav{display:flex;align-items:center;gap:36px}
.nav-list{display:flex;gap:30px;list-style:none}
.nav-logo{display:none}
.nav-list > li > a{
  font-size:13px;font-weight:500;position:relative;padding:10px 0;
  letter-spacing:.08em;
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.nav-list > li > a iconify-icon{
  font-size:20px;color:var(--c-accent-2);
  transition:color .4s var(--ease-soft),transform .4s var(--ease-soft);
}
.nav-list > li > a:hover iconify-icon{color:var(--c-accent);transform:translateY(-2px)}
.nav-list > li > a::after{
  content:"";position:absolute;left:50%;bottom:0;width:0;height:1px;
  background:var(--c-accent);transition:all .4s var(--ease);transform:translateX(-50%);
}
.nav-list > li > a:hover::after{width:100%}
.nav-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 24px;background:var(--c-accent);color:#fff;
  font-size:12px;font-weight:500;letter-spacing:.15em;
  border-radius:2px;transition:all .4s var(--ease);
  position:relative;overflow:hidden;
}
.nav-cta::before{
  content:"";position:absolute;inset:0;background:var(--c-accent-3);
  transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease);
}
.nav-cta > span{position:relative;z-index:1}
.nav-cta:hover::before{transform:scaleX(1);transform-origin:left}
.nav-cta:hover{opacity:1}
/* === ヘッダー電話 === */
.header-tel{
  display:flex;flex-direction:column;align-items:flex-end;line-height:1.4;
  padding-right:18px;border-right:1px solid var(--c-line);margin-right:6px;
}
.header-tel-label{font-size:9px;color:var(--c-muted);letter-spacing:.25em}
.header-tel-num{
  font-family:var(--font-en);font-size:24px;color:var(--c-accent);
  font-weight:500;letter-spacing:.05em;line-height:1;margin:3px 0 2px;
}
.header-tel-time{font-size:10px;color:var(--c-muted);letter-spacing:.1em}
.hamburger{display:none;width:28px;height:20px;position:relative;cursor:pointer;z-index:1001}
.hamburger span{position:absolute;left:0;width:100%;height:1px;background:var(--c-fg);transition:.4s var(--ease)}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:9px}
.hamburger span:nth-child(3){bottom:0}

/* ===== ヒーロー ===== */
.hero{
  position:relative;height:100vh;min-height:680px;
  overflow:hidden;
}
.hero-swiper{width:100%;height:100%;position:absolute;inset:0}
.swiper-slide{position:relative}
.swiper-slide .bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.12);transition:transform 8s linear;
}
.swiper-slide-active .bg{transform:scale(1)}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(135deg,rgba(20,30,22,.45) 0%,rgba(20,30,22,.15) 40%,rgba(20,30,22,.5) 100%),
    radial-gradient(ellipse at bottom left,rgba(20,30,22,.6) 0%,transparent 50%);
}
.hero-content{
  position:relative;z-index:5;height:100%;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 8%;color:#fff;max-width:900px;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:18px;
  font-family:var(--font-en);font-size:12px;letter-spacing:.4em;
  margin-bottom:30px;font-weight:400;
  opacity:0;animation:heroIn 1.6s var(--ease) .6s forwards;
}
.hero-tag::before{
  content:"";width:50px;height:1px;background:var(--c-accent-3);
  display:block;
}
.hero-tag::after{
  content:"YUI STYLE";color:#fff;opacity:.9;
}
.hero-title{
  font-family:var(--font-mincho);
  font-size:clamp(36px,5.8vw,72px);
  font-weight:500;letter-spacing:.14em;line-height:1.5;
  margin-bottom:34px;
  text-shadow:0 2px 8px rgba(0,0,0,.55), 0 0 30px rgba(0,0,0,.4);
  opacity:0;animation:heroIn 2.2s var(--ease) 1s forwards;
}
.hero-title .accent{
  display:inline-block;color:#d9c89e;
  position:relative;font-style:italic;font-weight:500;
}
.hero-title .accent::before{
  content:"";position:absolute;left:-4px;top:50%;width:calc(100% + 8px);
  height:1px;background:#d9c89e;opacity:.3;
}
.hero-sub{
  font-family:var(--font-gothic);
  font-size:15px;line-height:2.2;letter-spacing:.1em;
  font-weight:400;max-width:560px;opacity:0;
  text-shadow:0 1px 6px rgba(0,0,0,.6), 0 0 16px rgba(0,0,0,.35);
  animation:heroIn 2s var(--ease) 1.5s forwards;
}
@keyframes heroIn{
  0%{opacity:0;transform:translateY(30px)}
  100%{opacity:1;transform:translateY(0)}
}
.hero-vertical{
  position:absolute;right:36px;top:50%;transform:translateY(-50%);
  z-index:6;writing-mode:vertical-rl;
  font-family:var(--font-gothic);color:#fff;font-size:13px;
  letter-spacing:.4em;opacity:.7;
}
.hero-vertical span{display:block;margin-bottom:1em;font-family:var(--font-en);font-style:italic;font-size:10px}
.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  z-index:6;color:#fff;font-family:var(--font-en);font-size:10px;
  letter-spacing:.4em;text-align:center;font-weight:300;
}
.hero-scroll::after{
  content:"";display:block;width:1px;height:70px;background:#fff;
  margin:14px auto 0;animation:scrollLine 2.4s var(--ease) infinite;
  transform-origin:top;
}
@keyframes scrollLine{
  0%{transform:scaleY(0);transform-origin:top}
  45%{transform:scaleY(1);transform-origin:top}
  55%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}
.swiper-pagination{bottom:30px!important;display:flex;justify-content:center;gap:6px}
.swiper-pagination-bullet{
  background:#fff!important;opacity:.4!important;
  width:6px!important;height:6px!important;border-radius:50%!important;
  transition:all .4s var(--ease)!important;
}
.swiper-pagination-bullet-active{
  opacity:1!important;width:32px!important;border-radius:3px!important;
  background:var(--c-accent-3)!important;
}

/* ===== 共通セクション ===== */
section{padding:140px 0;position:relative;z-index:2}
.section-head{margin-bottom:90px;text-align:center;position:relative}
/* === 日本語が主役、英語は小さなラベル === */
.section-en{
  display:block;
  font-family:var(--font-en);
  font-size:18px;
  font-weight:500;
  letter-spacing:.42em;
  color:var(--c-accent-3);
  line-height:1.2;
  text-indent:.42em;
  margin-bottom:18px;
}
.section-title{
  display:block;
  font-family:var(--font-mincho);
  font-size:clamp(28px,3.4vw,42px);
  font-weight:500;
  letter-spacing:.18em;
  color:var(--c-fg);
  line-height:1.5;
  margin-top:0;
  text-indent:.18em;
}
/* 装飾シンボルは削除（参考サイトはシンプル） */
.section-title-deco{display:none}

/* === セクションの背景装飾（左右の縦罫線+番号） === */
.section-deco-no{
  position:absolute;top:80px;
  font-family:var(--font-en);font-size:11px;
  letter-spacing:.3em;color:var(--c-accent-3);
  display:flex;align-items:center;gap:14px;
  writing-mode:vertical-rl;
}
.section-deco-no::after{
  content:"";width:1px;height:60px;background:var(--c-accent-3);opacity:.5;
}
.section-deco-no.left{left:28px}
.section-deco-no.right{right:28px}

/* ===== PICK UP（ヒーロー直下）===== */
.pickup{padding:90px 0 60px;background:#fff;position:relative;overflow:hidden}
.pickup-head{
  text-align:center;margin-bottom:50px;
  display:flex;flex-direction:column;align-items:center;gap:14px;
}
.pickup-en{
  font-family:var(--font-en);font-size:32px;font-weight:300;
  letter-spacing:.25em;color:var(--c-accent);font-style:italic;
}
.pickup-title{
  font-family:var(--font-gothic);font-size:13px;font-weight:400;
  letter-spacing:.5em;color:var(--c-muted);
}
.pickup-line{width:50px;height:1px;background:var(--c-accent-3)}

/* ===== PICK UP Slider ===== */
.pickup-slider-wrap{
  position:relative;
  max-width:1320px;
  margin:0 auto;
  padding:0 60px 60px;
  box-sizing:border-box;
}
.pickup-swiper{
  overflow:hidden;
  width:100%;
  box-sizing:border-box;
  padding:30px 0 40px;
}
.pickup-swiper .swiper-slide{
  height:auto;
  transition:opacity .5s var(--ease-soft),transform .45s var(--ease-soft),box-shadow .45s var(--ease-soft);
  opacity:.45;
}
.pickup-swiper .swiper-slide-active,
.pickup-swiper .swiper-slide-prev,
.pickup-swiper .swiper-slide-next{
  opacity:1;
}
.pickup-nav{
  position:absolute;top:46%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:rgba(255,255,255,.95);
  color:var(--c-accent);
  border:1px solid var(--c-line);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-size:24px;line-height:1;
  cursor:pointer;z-index:5;
  box-shadow:0 6px 18px -4px rgba(40,50,40,.18);
  transition:all .3s var(--ease);
}
.pickup-prev{left:8px}
.pickup-next{right:8px}
.pickup-nav:hover{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}
.pickup-pagination{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:5;
}
.pickup-pagination .swiper-pagination-bullet{
  width:8px;height:8px;border-radius:50%;
  background:var(--c-line);opacity:1;transition:all .3s var(--ease);
}
.pickup-pagination .swiper-pagination-bullet-active{
  background:var(--c-accent);width:24px;border-radius:4px;
}
@media (max-width:768px){
  .pickup-slider-wrap{padding:0 16px 60px}
  .pickup-nav{display:none}
}

.pickup-item{
  display:block;background:#fff;
  box-shadow:0 12px 30px -15px rgba(40,50,40,.18);
  transition:transform .8s var(--ease-soft),box-shadow .8s var(--ease-soft);
  position:relative;overflow:hidden;
  border:1px solid var(--c-line);
  border-radius:var(--radius-md);
}
.pickup-item:hover{
  transform:translateY(-10px);
  box-shadow:0 30px 60px -20px rgba(40,50,40,.28);
  opacity:1;
}
.pickup-img-wrap{
  overflow:hidden;
  border-top-left-radius:var(--radius-md);
  border-top-right-radius:var(--radius-md);
}
.pickup-img{
  aspect-ratio:16/10;background-size:cover;background-position:center;
  transition:transform .9s var(--ease-soft);
}
.pickup-item:hover .pickup-img{transform:scale(1.08)}
.pickup-body{
  display:flex;flex-direction:column;
  padding:20px 22px 22px;
  position:relative;
}
.pickup-date{
  display:flex;align-items:baseline;gap:10px;
  padding-bottom:12px;margin-bottom:14px;
  border-bottom:1px solid var(--c-line);
}
.pickup-date b{
  font-family:var(--font-en);font-size:26px;
  font-weight:300;color:var(--c-accent);line-height:1;
  font-style:italic;
}
.pickup-date span{
  font-family:var(--font-en);font-size:11px;
  letter-spacing:.3em;color:var(--c-accent-2);
}
.pickup-info{min-width:0}
.pickup-cat{
  display:inline-block;font-size:10px;letter-spacing:.2em;
  color:#fff;background:var(--c-accent);padding:3px 10px;margin-bottom:10px;
}
.pickup-name{
  font-family:var(--font-gothic);font-size:15px;font-weight:500;
  line-height:1.6;letter-spacing:.05em;margin-bottom:8px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
  overflow:hidden;
}
.pickup-meta{font-size:11px;color:var(--c-muted);letter-spacing:.05em}
.pickup-arrow{
  position:absolute;right:22px;bottom:20px;
  font-size:18px;color:var(--c-accent-2);
  transition:transform .4s var(--ease-soft);
}
.pickup-item:hover .pickup-arrow{transform:translateX(6px)}

/* ===== コンセプト ===== */
.concept{background:#fff;overflow:hidden;position:relative;padding:140px 0}
.concept::before{
  content:"";position:absolute;top:-40px;right:-50px;
  width:300px;height:300px;
  background:radial-gradient(circle,rgba(184,155,106,.08) 0%,transparent 70%);
  pointer-events:none;
}
.concept-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:80px;
  align-items:center;
}
.concept-img-wrap{
  position:relative;
}
.concept-img{
  aspect-ratio:16/10;
  background-size:cover;background-position:center;
  box-shadow:0 40px 80px -30px rgba(40,50,40,.35);
  position:relative;z-index:2;
  border-radius:var(--radius-md);
  transition:transform 1.8s var(--ease);
}
.concept-img-wrap:hover .concept-img{transform:scale(1.03)}
.concept-img-wrap::before{
  content:"";position:absolute;
  top:30px;left:-30px;width:75%;height:80%;
  border:1px solid var(--c-accent);z-index:1;
  border-radius:var(--radius-md);
}
.concept-img-wrap::after{
  content:"";position:absolute;
  top:-20px;right:-20px;width:80px;height:80px;
  border:1px solid var(--c-accent-3);border-radius:50%;
  z-index:3;
}
.concept-stamp{
  position:absolute;bottom:-30px;right:-20px;z-index:4;
  width:130px;height:130px;border-radius:50%;
  background:var(--c-accent);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--font-gothic);font-size:13px;
  letter-spacing:.2em;text-align:center;line-height:1.6;
  box-shadow:0 12px 30px -8px rgba(40,50,40,.4);
  transform:rotate(-8deg);
}
.concept-stamp .small{font-family:var(--font-en);font-size:9px;letter-spacing:.3em;margin-bottom:4px;color:var(--c-accent-3)}
.concept-stamp .big{font-size:22px;font-weight:500;letter-spacing:.1em;margin:2px 0}

.concept-text{padding:20px 0}
.concept-text .section-head{text-align:left;margin-bottom:46px}
.concept-text .section-title{font-size:36px;line-height:1.7}
.concept-lead{
  font-family:var(--font-gothic);font-size:23px;line-height:2.1;
  margin-bottom:30px;font-weight:500;color:var(--c-accent);
  letter-spacing:.05em;
}
.concept-lead .ruby{
  font-size:.55em;color:var(--c-accent-3);
  letter-spacing:.2em;display:block;margin-bottom:4px;
  font-family:var(--font-en);font-style:italic;font-weight:400;
}
.concept-body{
  font-size:15px;line-height:2.3;color:#3a3a3a;
  margin-bottom:38px;letter-spacing:.04em;
}
/* === 参考サイト風ボタン：細枠＋丸み＋矢印左＋たっぷり余白 === */
.btn-line{
  display:inline-flex;align-items:center;gap:22px;
  font-family:var(--font-gothic);font-size:14px;letter-spacing:.3em;
  font-weight:400;color:var(--c-fg);
  padding:18px 42px 18px 32px;
  border:1px solid var(--c-fg);
  border-radius:40px;
  background:transparent;
  position:relative;overflow:hidden;
  transition:all .5s var(--ease-soft);
}
.btn-line::before{
  content:"→";display:inline-block;
  font-family:var(--font-gothic);font-size:16px;
  transition:transform .4s var(--ease-soft);
}
.btn-line:hover{
  background:var(--c-accent-dark);color:#fff;border-color:var(--c-accent-dark);opacity:1;
}
.btn-line:hover::before{transform:translateX(6px)}

/* ===== フィーチャー（6つの約束） ===== */
.feature{
  background:#faf6ef;
  position:relative;
  overflow:hidden;
}
.feature::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(45deg,transparent 49.5%,rgba(45,62,46,.04) 49.5%,rgba(45,62,46,.04) 50.5%,transparent 50.5%),
    linear-gradient(-45deg,transparent 49.5%,rgba(45,62,46,.04) 49.5%,rgba(45,62,46,.04) 50.5%,transparent 50.5%);
  background-size:60px 60px;
  opacity:.4;pointer-events:none;
}
.feature-intro{
  text-align:center;font-family:var(--font-gothic);
  font-size:14px;line-height:2.4;color:var(--c-muted);
  margin:-50px auto 70px;max-width:680px;letter-spacing:.18em;
  font-weight:400;
}
.feature-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:34px;
  position:relative;z-index:2;
}
.feature-card{
  display:block;
  background:#fff;padding:52px 32px 44px;
  text-align:center;
  text-decoration:none;color:inherit;
  transition:transform .9s var(--ease-soft),box-shadow .9s var(--ease-soft);
  position:relative;overflow:hidden;
  border-radius:var(--radius-md);
}
.feature-card::before{
  content:"";position:absolute;top:0;left:50%;width:0;height:2px;
  background:var(--c-accent-3);
  transform:translateX(-50%);
  transition:width .9s var(--ease-soft);
}
.feature-card:hover{
  transform:translateY(-14px) scale(1.02);
  box-shadow:0 36px 70px -25px rgba(40,50,40,.22);
}
.feature-card:hover::before{width:60%}
.feature-num{
  font-family:var(--font-en-deco);font-size:38px;
  color:var(--c-accent-3);margin-bottom:8px;line-height:1;
}
.feature-num::after{
  content:"";display:block;width:24px;height:1px;background:var(--c-accent-3);
  margin:14px auto 0;
}
.feature-icon{
  width:84px;height:84px;margin:24px auto 28px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.feature-icon::before{
  content:"";position:absolute;inset:0;
  border:1px solid var(--c-accent);
  border-radius:50%;transition:transform .5s var(--ease);
}
.feature-icon::after{
  content:"";position:absolute;inset:-6px;
  border:1px dashed var(--c-accent-3);opacity:0;
  border-radius:50%;transition:all .6s var(--ease);
}
.feature-card:hover .feature-icon::before{transform:rotate(180deg)}
.feature-card:hover .feature-icon::after{opacity:.6;transform:rotate(-180deg)}
.feature-icon svg,.feature-icon iconify-icon{width:36px;height:36px;color:var(--c-accent);position:relative;z-index:1}
iconify-icon{display:inline-block;vertical-align:middle}
.about-icon iconify-icon{color:inherit}
.footer-sns iconify-icon{color:currentColor;display:block}
.float-btn iconify-icon{color:currentColor}
.feature-title{
  font-family:var(--font-gothic);font-size:21px;
  margin-bottom:18px;letter-spacing:.08em;line-height:1.6;
  font-weight:500;
}
.feature-title-en{
  display:block;font-family:var(--font-en);
  font-size:11px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;
  margin-bottom:8px;font-weight:400;
}
.feature-text{font-size:13.5px;line-height:2;color:var(--c-muted);letter-spacing:.03em}

/* ===== 数字バナー ===== */
.stats{padding:80px 0;background:var(--c-accent-dark);color:#fff;position:relative;overflow:hidden}
.stats::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at top right,rgba(184,155,106,.1) 0%,transparent 60%);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative;z-index:2}
.stat-item{
  text-align:center;padding:20px;position:relative;
  display:flex;flex-direction:column;align-items:center;gap:6px;
}
.stat-item:not(:last-child)::after{
  content:"";position:absolute;right:0;top:20%;
  width:1px;height:60%;background:rgba(255,255,255,.15);
}
.stat-label{
  font-family:var(--font-en);font-size:10px;
  letter-spacing:.4em;color:var(--c-accent-3);font-style:italic;
}
.stat-num{
  font-family:var(--font-en);font-size:64px;font-weight:300;
  color:#fff;line-height:1;letter-spacing:.05em;
}
.stat-num small{font-size:22px;margin-left:4px;font-family:var(--font-gothic);color:var(--c-accent-3)}
.stat-text{font-size:12px;letter-spacing:.2em;opacity:.8;margin-top:6px}

/* ===== ABOUT US（8導線）===== */
.about-us{position:relative;background:#fff;padding:140px 0;overflow:hidden}
.about-bg{
  position:absolute;inset:0;
  background:url('https://yui-style.jp/wp-content/uploads/header-05.jpg') center/cover no-repeat;
  opacity:.06;pointer-events:none;
}
.about-intro{
  text-align:center;font-family:var(--font-gothic);
  font-size:14px;line-height:2.4;color:var(--c-muted);
  margin:-50px auto 60px;max-width:680px;letter-spacing:.18em;
}
.about-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
  position:relative;z-index:2;
}
.about-badge{
  position:absolute;top:14px;right:14px;
  background:var(--c-accent-3);color:#fff;
  font-family:var(--font-en);font-size:10px;font-weight:600;
  letter-spacing:.18em;padding:3px 9px;
  border-radius:12px;line-height:1;
  z-index:2;
}
.about-item{position:relative}
.about-item{
  background:#fff;padding:40px 20px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:10px;
  border:1px solid var(--c-line);
  transition:all .9s var(--ease-soft);position:relative;overflow:hidden;
  border-radius:var(--radius-md);
}
.about-item::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,var(--c-accent) 0%,var(--c-accent-dark) 100%);
  transform:translateY(100%);transition:transform .8s var(--ease-soft);
  z-index:0;
}
.about-item > *{position:relative;z-index:1;transition:color .15s var(--ease-soft) .4s}
.about-item:hover{transform:translateY(-10px) scale(1.02);opacity:1;border-color:transparent;box-shadow:0 24px 50px -20px rgba(40,50,40,.22)}
.about-item:hover::before{transform:translateY(0)}
.about-item:hover > *{color:#fff;transition:color .35s var(--ease-soft)}
.about-item:hover .about-num{color:var(--c-accent-3)}
.about-item:hover .about-en{color:#fff}
.about-num{
  position:absolute;top:16px;left:20px;z-index:3;
  font-family:var(--font-en);font-size:24px;letter-spacing:.15em;
  color:#fff;font-style:italic;font-weight:500;
  text-shadow:0 2px 8px rgba(0,0,0,.35);
}
.about-en{
  font-family:var(--font-en);font-size:17px;font-weight:400;
  letter-spacing:.2em;color:var(--c-accent-3);line-height:1.2;
  font-style:italic;
  transition:color .15s var(--ease-soft) .4s;
}
.about-jp{
  font-family:var(--font-gothic);font-size:22px;letter-spacing:.14em;
  color:var(--c-fg);margin-top:4px;font-weight:400;
  transition:color .15s var(--ease-soft) .4s;
}
.about-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;color:var(--c-accent-2);
  margin:4px 0 4px;
  transition:transform .5s var(--ease-soft),color .2s var(--ease-soft) .8s;
}
.about-icon svg{width:100%;height:100%}
.about-item:hover .about-icon{color:var(--c-accent-3);transform:scale(1.08);transition:transform .5s var(--ease-soft),color .35s var(--ease-soft)}
.about-desc{
  font-family:var(--font-gothic);font-size:13px;line-height:1.85;
  color:var(--c-muted);margin-top:12px;letter-spacing:.06em;opacity:.9;
  transition:color .15s var(--ease-soft) .4s;
}
.about-item:hover .about-en,
.about-item:hover .about-jp,
.about-item:hover .about-desc{
  transition:color .35s var(--ease-soft);
}
.about-item:hover .about-desc,.about-item:hover .about-jp{color:rgba(255,255,255,.85)}
.about-item{padding:0;justify-content:flex-start;gap:0}
.about-img{
  width:100%;aspect-ratio:16/10;
  background-size:cover;background-position:center;
  border-radius:var(--radius-md) var(--radius-md) 0 0;
  transition:transform 1.2s var(--ease-soft);
}
.about-item:hover .about-img{transform:scale(1.04)}
.about-body{
  padding:24px 22px 30px;
  display:flex;flex-direction:column;align-items:center;
  gap:4px;flex:1;width:100%;
  position:relative;z-index:1;
}

/* ===== 施工事例 ===== */
.works{background:#fff;position:relative;overflow:hidden}
.works-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px 28px;
  margin-bottom:80px;
}
.work-item{
  position:relative;display:block;
  transition:transform .9s var(--ease-soft);
}
.work-item:hover{transform:translateY(-6px)}
.work-img-wrap{
  position:relative;overflow:hidden;
  aspect-ratio:4/3;margin-bottom:22px;
  border-radius:var(--radius-md);
  box-shadow:0 10px 30px -15px rgba(40,50,40,.2);
  transition:box-shadow .9s var(--ease-soft);
}
.work-item:hover .work-img-wrap{box-shadow:0 24px 50px -20px rgba(40,50,40,.3)}
.work-img{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  transition:transform 2.2s var(--ease);
}
.work-item:hover .work-img{transform:scale(1.12)}
.work-img-wrap::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,30,22,.65) 0%,transparent 50%);
  opacity:0;transition:opacity 1s var(--ease);
}
.work-item:hover .work-img-wrap::after{opacity:1}
.work-num{
  position:absolute;top:14px;left:14px;
  width:42px;height:42px;background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-en);font-size:14px;font-style:italic;
  color:var(--c-accent);z-index:3;border-radius:50%;
  letter-spacing:.05em;
}
.work-cat{
  display:inline-block;font-family:var(--font-en);font-size:10px;
  letter-spacing:.3em;color:var(--c-accent-3);font-style:italic;
  margin-bottom:10px;
}
.work-cat::before{content:"— "}
.work-title{
  font-family:var(--font-gothic);font-size:17px;
  letter-spacing:.06em;line-height:1.7;
  font-weight:500;color:var(--c-fg);
}
.work-meta{
  display:flex;gap:12px;margin-top:12px;
  font-size:11px;color:var(--c-muted);
  letter-spacing:.1em;
}
.work-meta span{position:relative;padding-right:12px}
.work-meta span:not(:last-child)::after{
  content:"";position:absolute;right:0;top:50%;
  width:1px;height:10px;background:var(--c-line);transform:translateY(-50%);
}
.works-cta{text-align:center}

/* ===== 声 ===== */
.voice{
  background:#faf6ef;
  position:relative;overflow:hidden;
}
.voice::before{
  content:"VOICE";
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--font-en-deco);font-size:380px;
  color:rgba(45,62,46,.04);letter-spacing:.1em;
  pointer-events:none;font-weight:400;
}
.voice .container{position:relative;z-index:2}
.voice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:36px}
.voice-card{
  background:#fff;padding:44px 40px;
  display:flex;gap:28px;align-items:flex-start;
  box-shadow:0 20px 50px -20px rgba(40,50,40,.12);
  position:relative;border-radius:var(--radius-md);
  transition:transform .9s var(--ease-soft),box-shadow .9s var(--ease-soft);
}
.voice-card:hover{
  transform:translateY(-8px);
  box-shadow:0 30px 60px -20px rgba(40,50,40,.2);
}
.voice-card::before{
  content:""";position:absolute;top:14px;right:24px;
  font-family:var(--font-en-deco);font-size:80px;
  color:var(--c-accent-3);opacity:.25;line-height:1;
}
.voice-photo-wrap{flex-shrink:0;position:relative}
.voice-photo{
  width:96px;height:96px;
  border-radius:50%;background-size:cover;background-position:center;
  border:3px solid var(--c-bg);
}
.voice-photo-wrap::after{
  content:"";position:absolute;inset:-6px;
  border:1px solid var(--c-accent-3);border-radius:50%;
  opacity:.5;
}
.voice-body{flex:1;position:relative;z-index:1}
.voice-stars{color:var(--c-accent-3);font-size:12px;letter-spacing:.2em;margin-bottom:10px}
.voice-quote{
  font-family:var(--font-gothic);font-size:16px;line-height:2;
  margin-bottom:18px;color:#2c2c2c;letter-spacing:.04em;
  font-weight:500;
}
.voice-meta{
  font-size:12px;color:var(--c-muted);
  border-top:1px solid var(--c-line);padding-top:14px;
  letter-spacing:.05em;
}
.voice-name{
  font-size:14px;font-weight:500;color:var(--c-accent);margin-right:14px;
  font-family:var(--font-gothic);letter-spacing:.08em;
}

/* ===== ニュース ===== */
.news{background:#fff;position:relative;overflow:hidden}
.news::before{
  content:"";position:absolute;top:60px;left:50%;width:1px;height:80px;
  background:var(--c-accent-3);opacity:.5;
}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:44px;margin-bottom:70px}
.news-item{display:flex;flex-direction:column}
.news-img{
  aspect-ratio:16/10;background-size:cover;background-position:center;
  margin-bottom:22px;overflow:hidden;position:relative;
  border-radius:var(--radius-md);
  box-shadow:0 10px 30px -18px rgba(40,50,40,.2);
  transition:box-shadow 1s var(--ease);
}
.news-item{transition:transform .9s var(--ease-soft)}
.news-item:hover{transform:translateY(-6px)}
.news-item:hover .news-img{box-shadow:0 24px 50px -22px rgba(40,50,40,.28)}
.news-img > div{width:100%;height:100%;transition:transform 2s var(--ease)}
.news-item:hover .news-img > div{transform:scale(1.08)}
.news-meta{
  display:flex;gap:14px;align-items:center;
  font-family:var(--font-en);font-size:12px;
  letter-spacing:.15em;margin-bottom:12px;
}
.news-date{color:var(--c-muted);font-style:italic}
.news-cat{
  background:var(--c-accent);color:#fff;padding:4px 14px;font-size:10px;
  letter-spacing:.25em;
}
.news-cat.event{background:var(--c-accent-3);color:#fff}
.news-cat.media{background:var(--c-accent-2)}
.news-title{
  font-family:var(--font-gothic);font-size:17px;line-height:1.8;
  font-weight:500;letter-spacing:.04em;
}

/* ===== モデルハウス・ショールーム ===== */
.modelhouse{background:#faf6ef;padding:140px 0 130px;position:relative;overflow:hidden}
.section-sub{
  text-align:center;font-family:var(--font-gothic);font-size:14px;line-height:2;
  color:var(--c-muted);margin-top:18px;margin-bottom:60px;letter-spacing:.12em;
}
.modelhouse-grid{
  display:grid;grid-template-columns:1.05fr 1fr;gap:80px;align-items:center;
}
.modelhouse-photo{position:relative}
.mh-img{
  aspect-ratio:5/4;background-size:cover;background-position:center;
  border-radius:var(--radius-md);
  box-shadow:0 40px 80px -30px rgba(40,50,40,.3);
  transition:transform 1.4s var(--ease-soft);
}
.modelhouse-photo:hover .mh-img{transform:scale(1.02)}
.mh-photo-caption{
  position:absolute;bottom:24px;left:24px;
  background:rgba(255,255,255,.92);color:var(--c-fg);
  padding:10px 20px;font-size:12px;letter-spacing:.18em;
  font-family:var(--font-gothic);font-weight:500;
}
.modelhouse-info{padding:20px 0}
.mh-tag{
  display:inline-block;font-family:var(--font-en);font-size:11px;
  letter-spacing:.4em;color:var(--c-accent-3);
  border-bottom:1px solid var(--c-accent-3);padding-bottom:6px;margin-bottom:24px;
}
.mh-name{
  font-family:var(--font-mincho);font-size:32px;font-weight:500;
  letter-spacing:.06em;line-height:1.55;margin-bottom:24px;color:var(--c-fg);
}
.mh-desc{
  font-family:var(--font-gothic);font-size:14px;line-height:2.2;
  color:var(--c-muted);margin-bottom:32px;letter-spacing:.08em;
}
.mh-meta{
  display:grid;grid-template-columns:auto 1fr;gap:14px 24px;
  padding:24px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  margin-bottom:32px;
}
.mh-meta dt{
  font-family:var(--font-gothic);font-size:11px;letter-spacing:.25em;
  color:var(--c-accent-2);padding-top:4px;
}
.mh-meta dd{
  font-family:var(--font-gothic);font-size:14px;line-height:1.7;
  color:var(--c-fg);letter-spacing:.05em;
}
.mh-meta dd small{font-size:11px;color:var(--c-muted)}
.mh-cta{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.mh-cta .btn-primary{min-width:auto;padding:18px 38px}

/* ===== 代表挨拶 ===== */
.ceo{background:#fff;padding:140px 0;position:relative;overflow:hidden}
.ceo-grid{
  display:grid;grid-template-columns:0.85fr 1fr;gap:80px;align-items:flex-start;
}
.ceo-photo-wrap{position:relative;padding:30px 0 0 30px}
.ceo-photo{
  aspect-ratio:4/5;background-size:cover;background-position:center;
  border-radius:var(--radius-md);
  box-shadow:0 30px 70px -25px rgba(40,50,40,.3);
  position:relative;z-index:2;
}
.ceo-photo-wrap::before{
  content:"";position:absolute;
  top:0;left:0;width:60%;height:30%;
  border-top:1px solid var(--c-accent-3);
  border-left:1px solid var(--c-accent-3);
  z-index:1;
}
.ceo-photo-stamp{
  position:absolute;bottom:-20px;right:-15px;z-index:3;
  width:110px;height:110px;border-radius:50%;
  background:var(--c-accent);color:#fff;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  font-family:var(--font-gothic);
  box-shadow:0 12px 30px -8px rgba(40,50,40,.4);
}
.ceo-photo-stamp .small{font-family:var(--font-en);font-size:10px;letter-spacing:.3em;color:var(--c-accent-3)}
.ceo-photo-stamp .big{font-family:var(--font-en);font-size:26px;letter-spacing:.05em;margin-top:2px}
.ceo-text{padding-top:30px}
.ceo-quote{
  font-family:var(--font-mincho);font-size:28px;font-weight:500;
  line-height:1.6;letter-spacing:.06em;color:var(--c-accent);
  margin-bottom:32px;font-style:italic;
}
.ceo-body{
  font-family:var(--font-gothic);font-size:15px;line-height:2.4;
  color:var(--c-fg);letter-spacing:.08em;margin-bottom:32px;
}
.ceo-sign{
  display:flex;flex-direction:column;align-items:flex-end;
  padding-right:20px;margin-bottom:48px;
}
.ceo-sign-title{
  font-family:var(--font-gothic);font-size:12px;letter-spacing:.2em;
  color:var(--c-muted);margin-bottom:6px;
}
.ceo-sign-name{
  font-family:var(--font-mincho);font-size:22px;letter-spacing:.15em;
  color:var(--c-fg);
}
.ceo-panels{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  padding-top:32px;border-top:1px solid var(--c-line);
}
.ceo-panel{
  display:flex;flex-direction:column;align-items:flex-start;justify-content:center;
  padding:22px 22px;background:#faf6ef;border-radius:var(--radius-md);
  position:relative;transition:transform .45s var(--ease-soft),background .45s var(--ease-soft);
}
.ceo-panel:hover{transform:translateY(-4px);background:var(--c-accent);opacity:1}
.ceo-panel:hover .ceo-panel-en{color:var(--c-accent-3)}
.ceo-panel:hover .ceo-panel-jp,.ceo-panel:hover .ceo-panel-arrow{color:#fff}
.ceo-panel-en{
  font-family:var(--font-en);font-size:10px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;margin-bottom:6px;
}
.ceo-panel-jp{
  font-family:var(--font-gothic);font-size:14px;letter-spacing:.1em;
  color:var(--c-fg);font-weight:500;
}
.ceo-panel-arrow{
  position:absolute;right:18px;top:50%;transform:translateY(-50%);
  font-size:16px;color:var(--c-accent-2);
  transition:transform .45s var(--ease-soft);
}
.ceo-panel:hover .ceo-panel-arrow{transform:translateY(-50%) translateX(4px)}

/* ===== ブログ・コラム ===== */
.blog{background:#faf6ef;padding:140px 0 120px;position:relative;overflow:hidden}
.blog-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;margin-bottom:60px;
}
.blog-item{
  display:flex;flex-direction:column;background:#fff;
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:0 14px 32px -18px rgba(40,50,40,.18);
  transition:transform .45s var(--ease-soft),box-shadow .45s var(--ease-soft);
}
.blog-item:hover{
  transform:translateY(-8px);opacity:1;
  box-shadow:0 26px 50px -20px rgba(40,50,40,.28);
}
.blog-img{
  aspect-ratio:16/10;background-size:cover;background-position:center;
  transition:transform .9s var(--ease-soft);
}
.blog-item:hover .blog-img{transform:scale(1.05)}
.blog-body{
  padding:22px 22px 26px;
  display:flex;flex-direction:column;gap:10px;
}
.blog-meta{
  display:flex;align-items:center;gap:12px;
}
.blog-cat{
  display:inline-block;font-family:var(--font-gothic);font-size:10px;
  letter-spacing:.2em;color:#fff;background:var(--c-accent);padding:3px 10px;
}
.blog-date{
  font-family:var(--font-en);font-size:11px;letter-spacing:.18em;
  color:var(--c-muted);font-style:italic;
}
.blog-title{
  font-family:var(--font-gothic);font-size:14px;line-height:1.65;
  font-weight:500;letter-spacing:.05em;color:var(--c-fg);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;
  overflow:hidden;
}

@media (max-width:900px){
  .modelhouse-grid,.ceo-grid{grid-template-columns:1fr;gap:50px}
  .ceo-photo-wrap{padding:0;max-width:420px;margin:0 auto}
  .ceo-photo-wrap::before{display:none}
  .ceo-text{padding-top:0}
  .blog-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .ceo-panels{grid-template-columns:1fr}
}
@media (max-width:540px){
  .blog-grid{grid-template-columns:1fr}
}

/* ===== 信頼バッジ ===== */
.trust{background:#fff;padding:120px 0;position:relative;overflow:hidden}
.trust-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:24px;
  align-items:center;
}
.trust-item{
  display:flex;flex-direction:column;align-items:center;gap:14px;
  text-align:center;transition:transform .7s var(--ease-soft);
}
.trust-item:hover{transform:translateY(-6px)}
.trust-badge{
  width:120px;height:120px;border-radius:50%;
  background:#fff;border:2px solid var(--c-accent);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;box-shadow:0 8px 24px -10px rgba(40,50,40,.15);
}
.trust-badge::before{
  content:"";position:absolute;inset:6px;
  border:1px dashed var(--c-accent-3);border-radius:50%;
}
.trust-badge-year{
  font-family:var(--font-en);font-size:11px;
  color:var(--c-accent-3);letter-spacing:.2em;
  font-style:italic;margin-bottom:2px;
}
.trust-badge-name{
  font-family:var(--font-gothic);font-size:13px;font-weight:600;
  color:var(--c-accent);letter-spacing:.05em;line-height:1.3;
  text-align:center;
}
.trust-text{font-size:11px;color:var(--c-muted);letter-spacing:.15em}

/* === セクション末尾CTA === */
.section-cta{text-align:center;margin-top:60px}

/* ===== CTA ===== */
.cta{
  position:relative;padding:160px 0;overflow:hidden;
  background:url("https://yui-style.jp/wp-content/uploads/header-06-pc.jpg") center/cover no-repeat fixed;
}
.cta::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,rgba(250,246,239,.92) 0%,rgba(243,236,221,.88) 100%);
}
.cta::after{
  content:"";position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:600px;height:600px;
  border:1px solid rgba(122,106,74,.35);border-radius:50%;
  animation:ctaPulse 6s ease-in-out infinite;
}
@keyframes ctaPulse{
  0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.7}
  50%{transform:translate(-50%,-50%) scale(1.15);opacity:.35}
}
.cta-inner{position:relative;z-index:2;text-align:center;color:var(--c-fg);max-width:780px;margin:0 auto;padding:0 24px}
.cta-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.4em;
  color:var(--c-accent-2);margin-bottom:24px;font-style:italic;
}
.cta-en::before,.cta-en::after{
  content:"";display:inline-block;width:30px;height:1px;
  background:var(--c-accent-2);vertical-align:middle;margin:0 16px;
}
.cta-title{
  font-family:var(--font-gothic);font-size:46px;font-weight:400;
  letter-spacing:.12em;line-height:1.55;margin-bottom:28px;color:var(--c-fg);
}
.cta-title .accent{color:var(--c-accent-2);font-style:italic;font-weight:500}
.cta-sub{font-size:16px;line-height:2.2;margin-bottom:52px;letter-spacing:.08em;opacity:.85;color:var(--c-fg)}
.cta-buttons{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.btn-primary,.btn-secondary{
  display:inline-flex;align-items:center;gap:14px;
  padding:22px 48px;font-size:13px;letter-spacing:.2em;
  font-weight:500;border-radius:2px;transition:all .4s var(--ease);
  font-family:var(--font-gothic);position:relative;overflow:hidden;
  min-width:240px;justify-content:center;
}
.btn-primary{background:var(--c-accent-3);color:#fff}
.btn-primary::before{
  content:"";position:absolute;inset:0;background:#fff;
  transform:translateY(100%);transition:transform .5s var(--ease);
}
.btn-primary > span{position:relative;z-index:1;transition:color .3s var(--ease)}
.btn-primary:hover::before{transform:translateY(0)}
.btn-primary:hover > span{color:var(--c-fg)}
.btn-primary:hover{opacity:1;transform:translateY(-2px)}
.btn-secondary{background:transparent;color:var(--c-fg);border:1px solid rgba(31,37,32,.35)}
.btn-secondary::before{
  content:"";position:absolute;inset:0;background:var(--c-accent-dark);
  transform:translateX(-100%);transition:transform .5s var(--ease);
}
.btn-secondary > span{position:relative;z-index:1;transition:color .3s var(--ease)}
.btn-secondary:hover::before{transform:translateX(0)}
.btn-secondary:hover > span{color:#fff}
.btn-secondary:hover{opacity:1;border-color:var(--c-accent-dark)}

/* ===== フッター ===== */
.footer{background:#efe7d2;color:var(--c-fg);padding:100px 0 40px;position:relative}
.footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--c-accent-2),transparent);
}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:56px;margin-bottom:60px}
.footer-logo .logo-mark{color:var(--c-accent-2)}
.footer-logo .logo-mark::before{border-color:var(--c-accent-2)}
.footer-logo .logo-name{color:var(--c-fg)}
.footer-logo .logo-sub{color:var(--c-accent-2)}
.footer-desc{
  font-family:var(--font-gothic);
  font-size:14px;line-height:2.2;margin:28px 0 28px;opacity:.8;
  letter-spacing:.08em;
}
.footer-info{font-size:13px;line-height:2;opacity:.75;letter-spacing:.05em;margin-bottom:14px}
.footer-studio{
  display:inline-block;font-family:var(--font-en);font-size:11px;
  letter-spacing:.25em;color:var(--c-accent-2);
  border-bottom:1px solid var(--c-accent-2);padding-bottom:2px;margin-bottom:6px;
}
.footer-info b{font-family:var(--font-en);font-size:18px;color:var(--c-accent-2);display:block;margin-top:6px}
.footer h4{
  font-family:var(--font-gothic);font-size:15px;font-weight:500;
  color:var(--c-fg);margin-bottom:24px;letter-spacing:.15em;
  position:relative;padding-left:18px;
}
.footer h4::before{
  content:"";position:absolute;left:0;top:50%;width:8px;height:1px;
  background:var(--c-accent-2);transform:translateY(-50%);
}
.footer h4 a{color:inherit;text-decoration:none;transition:color .3s var(--ease)}
.footer h4 a:hover{color:var(--c-accent-2)}
.footer ul{list-style:none}
.footer li{margin-bottom:12px;font-size:13px;opacity:.75;letter-spacing:.05em}
.footer li a:hover{opacity:1;color:var(--c-accent-2)}
.footer-bottom{
  border-top:1px solid rgba(31,37,32,.12);
  padding-top:30px;display:flex;justify-content:space-between;
  font-size:11px;opacity:.55;letter-spacing:.1em;font-family:var(--font-en);
}

/* ===== 固定浮遊CTA ===== */
.floating-cta{
  position:fixed;right:20px;bottom:80px;z-index:998;
  display:flex;flex-direction:column;gap:12px;
  opacity:0;visibility:hidden;transform:translateX(20px);
  transition:opacity .5s var(--ease-soft),transform .5s var(--ease-soft),visibility .5s;
  pointer-events:none;
}
body.scrolled .floating-cta{
  opacity:1;visibility:visible;transform:translateX(0);
  pointer-events:auto;
}
.float-btn{
  width:62px;height:62px;border-radius:50%;
  background:#fff;color:var(--c-accent);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 8px 24px -6px rgba(40,50,40,.25);
  transition:all .4s var(--ease);
  border:1px solid var(--c-line);font-size:9px;
  letter-spacing:.1em;gap:2px;
}
.float-btn svg{width:22px;height:22px}
.float-btn:hover{
  transform:translateY(-4px) scale(1.05);
  opacity:1;background:var(--c-accent);color:#fff;
  border-color:var(--c-accent);
}
.float-line{background:#06c755;color:#fff;border-color:#06c755}
.float-line:hover{background:#04a647;border-color:#04a647}
.float-instagram{
  background:linear-gradient(135deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);
  color:#fff;border:none;
}
.float-instagram:hover{background:linear-gradient(135deg,#e08423 0%,#d65a30 25%,#c4193a 50%,#b41a5b 75%,#a8137c 100%);opacity:1}
.float-top{
  background:var(--c-accent-dark);color:#fff;border-color:var(--c-accent-dark);
  width:50px;height:50px;align-self:flex-end;
}
.float-top svg{width:18px;height:18px}
.float-top:hover{background:var(--c-accent);border-color:var(--c-accent)}

/* ===== SNSアイコン ===== */
.footer-sns{
  display:flex;gap:14px;margin-top:24px;
}
.footer-sns a{
  width:38px;height:38px;border-radius:50%;
  border:1px solid rgba(31,37,32,.25);
  display:flex;align-items:center;justify-content:center;
  color:var(--c-fg);transition:all .4s var(--ease);
}
.footer-sns a:hover{
  background:var(--c-accent-2);border-color:var(--c-accent-2);
  color:#fff;opacity:1;transform:translateY(-3px);
}
.footer-sns svg{width:16px;height:16px}

/* ===== preview バナー ===== */
.preview-banner{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  background:#c9a96e;color:#1a1f1a;
  padding:12px 22px;border-radius:30px;font-size:11px;font-weight:500;
  box-shadow:0 8px 24px rgba(0,0,0,.2);
  letter-spacing:.2em;font-family:var(--font-en);font-style:italic;
}

/* ===== レスポンシブ ===== */
@media (max-width:980px){
  .nav-list,.nav-cta,.header-tel{display:none}
  .hamburger{display:block}
  /* スマホメニュー：開いた時 .nav が全画面メニューに */
  body.nav-open{overflow:hidden}
  body.nav-open .nav,
  body.nav-closing .nav{
    position:fixed !important;
    top:0;right:0;bottom:0;left:auto;
    width:66.67vw;height:100vh;height:100dvh;
    background:#fff;z-index:1000;
    display:flex;flex-direction:column;
    align-items:flex-start;justify-content:center;
    gap:24px;padding:120px 36px 60px;
    overflow-y:auto;
    box-shadow:-12px 0 30px -10px rgba(40,50,40,.18);
  }
  body.nav-open .nav{animation:navSlideIn .45s var(--ease-soft)}
  body.nav-closing .nav{animation:navSlideOut .4s var(--ease-soft) forwards}
  @keyframes navSlideIn{
    0%{transform:translateX(100%);opacity:0}
    100%{transform:translateX(0);opacity:1}
  }
  @keyframes navSlideOut{
    0%{transform:translateX(0);opacity:1}
    100%{transform:translateX(100%);opacity:0}
  }
  /* 左 1/3 のオーバーレイ（タップで閉じる） */
  body.nav-open::before,
  body.nav-closing::before{
    content:"";position:fixed;inset:0;
    background:rgba(40,50,40,.35);z-index:999;
    cursor:pointer;
  }
  body.nav-open::before{animation:overlayFadeIn .45s var(--ease-soft)}
  body.nav-closing::before{animation:overlayFadeOut .4s var(--ease-soft) forwards}
  @keyframes overlayFadeIn{0%{opacity:0}100%{opacity:1}}
  @keyframes overlayFadeOut{0%{opacity:1}100%{opacity:0}}
  .nav-logo{display:none}
  body.nav-open .nav-logo,body.nav-closing .nav-logo{
    display:flex;align-items:center;gap:14px;
    margin-bottom:8px;
  }
  body.nav-open .nav-logo .logo-mark{
    width:54px;height:54px;flex-shrink:0;
  }
  body.nav-open .nav-logo .logo-mark img{
    width:100%;height:100%;object-fit:contain;display:block;
  }
  body.nav-open .nav-logo .logo-text{
    display:flex;flex-direction:column;line-height:1.2;
  }
  body.nav-open .nav-logo .logo-name{
    font-family:var(--font-gothic);font-size:18px;font-weight:500;letter-spacing:.12em;
    color:var(--c-fg);
  }
  body.nav-open .nav-logo .logo-sub{
    font-family:var(--font-en);font-size:11px;color:var(--c-accent-3);
    letter-spacing:.25em;margin-top:3px;
  }
  @keyframes navMenuFadeIn{
    0%{opacity:0}
    100%{opacity:1}
  }
  body.nav-open .nav-list,body.nav-closing .nav-list{
    display:flex !important;flex-direction:column;
    gap:2px;align-items:flex-start;margin:0;padding:0;
    width:100%;
  }
  body.nav-open .nav-list > li,body.nav-closing .nav-list > li{width:100%}
  body.nav-open .nav-list > li > a,body.nav-closing .nav-list > li > a{
    display:flex;flex-direction:row;align-items:center;justify-content:flex-start;
    font-size:17px;padding:10px 0;gap:14px;width:100%;
  }
  body.nav-open .nav-list > li > a iconify-icon,body.nav-closing .nav-list > li > a iconify-icon{font-size:22px}
  body.nav-open .header-tel,body.nav-closing .header-tel{
    display:flex;flex-direction:column;align-items:flex-start;
    text-align:left;margin-top:12px;
  }
  body.nav-open .nav-cta,body.nav-closing .nav-cta{
    display:inline-flex;margin-top:8px;
  }
  body.nav-open .hamburger,
  body.nav-closing .hamburger{
    position:fixed !important;top:30px;right:30px;z-index:1002;
  }
  body.nav-open .hamburger span:nth-child(1){top:9px;transform:rotate(45deg)}
  body.nav-open .hamburger span:nth-child(2){opacity:0}
  body.nav-open .hamburger span:nth-child(3){bottom:auto;top:9px;transform:rotate(-45deg)}
  section{padding:90px 0}
  .section-title{font-size:24px;letter-spacing:.1em}
  .concept-grid,.feature-grid,.works-grid,.voice-grid,.news-grid{grid-template-columns:1fr;gap:50px}
  .concept-img-wrap::before{display:none}
  .hero-title{font-size:34px}
  .hero-content{padding:0 28px}
  .cta-title{font-size:30px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
  .hero-vertical,.section-deco-no{display:none}
  .voice::before{font-size:200px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:30px 0}
  .stat-item:nth-child(2)::after{display:none}
  .about-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(3,1fr);gap:30px}
  .floating-cta{right:14px;bottom:14px}
  .float-btn{width:52px;height:52px}
}
@media (max-width:600px){
  .feature-grid{grid-template-columns:1fr}
  .voice-card{flex-direction:column;align-items:center;text-align:center;padding:32px 24px}
  .footer-grid{grid-template-columns:1fr}
  .header-inner{padding:14px 20px}
  .logo-name{font-size:15px}
  .cta-buttons{flex-direction:column;align-items:stretch;padding:0 20px}
  .btn-primary,.btn-secondary{width:100%}
  .about-grid{grid-template-columns:1fr;gap:18px}
  .news::before{display:none}
  .mh-name{font-size:clamp(20px,5.2vw,28px);letter-spacing:.04em}
  .ceo-photo-wrap{max-width:320px}
  .vision-page .vision-hero-title{font-size:clamp(22px,6.5vw,38px);letter-spacing:.12em;margin-bottom:24px}
  .vision-page .vision-hero-sub{font-size:clamp(15px,4.5vw,22px);letter-spacing:.14em;margin-bottom:30px}
  .vision-page .vision-hero-lead{font-size:13px;line-height:2}
  .vision-page .vision-hero-en{font-size:12px;margin-bottom:24px}
}
/* CEO photo: aspect-ratio対策で最低高さ保証 */
.ceo-photo{min-height:280px}

/* ===== スクロールアニメ（ふわっとゆっくり）===== */
.fade-up{opacity:0;transform:translateY(80px);transition:opacity 2s var(--ease),transform 2s var(--ease)}

/* ===== あしらい（手描き風装飾画像） ===== */
.deco-ashirai{
  position:absolute;pointer-events:none;
  user-select:none;z-index:1;
  max-width:none;
}
.deco-ashirai.blob{opacity:.55}              /* 水彩風の抽象丸 */
.deco-ashirai.wash{opacity:.75}              /* 薄い水彩 */
.deco-ashirai.brush{opacity:.45}             /* 手描きブラシ */
.deco-ashirai.flip-x{transform:scaleX(-1)}
.deco-ashirai.flip-y{transform:scaleY(-1)}
.deco-ashirai.flip-xy{transform:scale(-1,-1)}
.deco-ashirai.rotate-15{transform:rotate(15deg)}
.deco-ashirai.rotate-30{transform:rotate(30deg)}
.deco-ashirai.rotate--15{transform:rotate(-15deg)}
@media (max-width:768px){
  .deco-ashirai{display:none}
}
.fade-up.is-show{opacity:1;transform:translateY(0)}
.fade-up-d1{transition-delay:.15s}
.fade-up-d2{transition-delay:.3s}
.fade-up-d3{transition-delay:.45s}
.fade-up-d4{transition-delay:.6s}
.fade-up-d5{transition-delay:.75s}
.fade-up-d6{transition-delay:.9s}

.fade-scale{opacity:0;transform:scale(.94);transition:opacity 2.2s var(--ease),transform 2.2s var(--ease)}
.fade-scale.is-show{opacity:1;transform:scale(1)}

/* === テキスト分割アニメ === */
.split-word{display:inline-block;overflow:hidden}
.split-word span{
  display:inline-block;transform:translateY(110%);
  transition:transform 1.2s var(--ease);
}
.is-show .split-word span{transform:translateY(0)}
.split-word span:nth-child(2){transition-delay:.06s}
.split-word span:nth-child(3){transition-delay:.12s}
.split-word span:nth-child(4){transition-delay:.18s}
.split-word span:nth-child(5){transition-delay:.24s}
.split-word span:nth-child(6){transition-delay:.30s}

/* ===== アーカイブ（お知らせ一覧）===== */
.archive-page{padding:160px 0 120px;background:#fff;min-height:60vh}
.archive-page .container{max-width:1100px}
.archive-page .section-head{margin-bottom:70px}
.archive-list{display:grid;grid-template-columns:1fr;gap:30px;margin-bottom:60px}
.archive-list.small{grid-template-columns:repeat(3,1fr);gap:24px}
.archive-item{
  display:flex;gap:32px;
  background:#fff;border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--c-line);
  transition:transform .5s var(--ease-soft),box-shadow .5s var(--ease-soft);
}
.archive-list.small .archive-item{flex-direction:column;gap:0}
.archive-item:hover{transform:translateY(-4px);box-shadow:0 16px 40px -20px rgba(40,50,40,.22);opacity:1}
.archive-thumb{flex-shrink:0;width:280px;overflow:hidden;align-self:stretch}
.archive-thumb > div{
  width:100%;height:100%;min-height:180px;aspect-ratio:4/3;
  transition:transform 1s var(--ease-soft);
}
.archive-item:hover .archive-thumb > div{transform:scale(1.05)}
.archive-list.small .archive-thumb{width:100%}
.archive-list.small .archive-thumb > div{aspect-ratio:16/10}
.archive-body{flex:1;padding:24px 28px;display:flex;flex-direction:column;justify-content:center}
.archive-list.small .archive-body{padding:18px 20px 22px}
.archive-meta{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.archive-date{
  font-family:var(--font-en);font-size:13px;letter-spacing:.18em;
  color:var(--c-muted);font-style:italic;
}
.archive-title{
  font-family:var(--font-gothic);font-size:20px;font-weight:500;line-height:1.55;
  letter-spacing:.04em;color:var(--c-fg);margin-bottom:14px;
}
.archive-list.small .archive-title{font-size:15px;margin-bottom:8px}
.archive-excerpt{
  font-family:var(--font-gothic);font-size:14px;line-height:1.85;
  color:var(--c-muted);letter-spacing:.04em;margin-bottom:14px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.archive-list.small .archive-excerpt{display:none}
.archive-readmore{
  font-family:var(--font-en);font-size:12px;letter-spacing:.2em;
  color:var(--c-accent-3);font-style:italic;
}
.archive-pagination{
  display:flex;justify-content:center;gap:8px;flex-wrap:wrap;
  font-family:var(--font-en);
}
.archive-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:42px;height:42px;padding:0 14px;
  border:1px solid var(--c-line);border-radius:24px;
  color:var(--c-fg);font-size:14px;letter-spacing:.05em;
  transition:all .35s var(--ease-soft);
}
.archive-pagination .page-numbers:hover{background:var(--c-accent-3);color:#fff;border-color:var(--c-accent-3);opacity:1}
.archive-pagination .page-numbers.current{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}
.archive-empty{text-align:center;padding:60px 0;color:var(--c-muted)}
.archive-cat-desc{
  font-family:var(--font-gothic);font-size:14px;line-height:2;color:var(--c-muted);
  letter-spacing:.06em;margin-top:24px;max-width:680px;margin-left:auto;margin-right:auto;
}
@media (max-width:768px){
  .archive-item{flex-direction:column;gap:0}
  .archive-thumb{width:100%}
  .archive-thumb > div{aspect-ratio:16/10}
  .archive-list.small{grid-template-columns:1fr}
}

/* ===== 個別記事ページ ===== */
.single-post{padding:140px 0 100px;background:#fff;min-height:60vh}
.single-container{max-width:820px}
.single-meta{display:flex;align-items:center;gap:16px;margin-bottom:24px;justify-content:flex-start}
.single-date{
  font-family:var(--font-en);font-size:14px;letter-spacing:.18em;
  color:var(--c-muted);font-style:italic;
}
.single-title{
  font-family:var(--font-mincho);font-size:clamp(24px,3.4vw,36px);font-weight:500;
  line-height:1.5;letter-spacing:.06em;text-align:left;
  color:var(--c-fg);margin-bottom:40px;
}
.single-thumb{margin:0 -10px 50px}
.single-thumb img{width:100%;height:auto;border-radius:var(--radius-md);display:block}
/* ===== イベント情報ブロック（詳細ページ） ===== */
.single-event-info{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-md);
  padding:32px 36px;margin:0 0 50px;position:relative;
}
.single-event-type{
  display:inline-block;background:var(--c-accent);color:#fff;
  font-family:var(--font-gothic);font-size:12px;letter-spacing:.12em;
  padding:6px 18px;border-radius:20px;margin-bottom:22px;
}
.single-event-list{margin:0}
.single-event-row{
  display:flex;gap:24px;padding:14px 2px;border-bottom:1px solid rgba(40,50,40,.08);
}
.single-event-row:last-child{border-bottom:none}
.single-event-row dt{
  font-family:var(--font-gothic);font-size:13px;letter-spacing:.1em;
  color:var(--c-muted);min-width:72px;flex-shrink:0;padding-top:2px;
}
.single-event-row dd{
  font-family:var(--font-gothic);font-size:15.5px;letter-spacing:.05em;
  color:var(--c-fg);margin:0;font-weight:500;line-height:1.7;
}
.single-event-map{
  margin-top:24px;border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--c-line);line-height:0;
}
.single-event-map iframe{display:block;width:100%}
@media (max-width:640px){
  .single-event-info{padding:24px 22px}
  .single-event-row{gap:14px}
  .single-event-map iframe{height:240px}
}
.single-body{
  font-family:var(--font-gothic);font-size:15.5px;line-height:2.15;
  color:var(--c-fg);letter-spacing:.06em;
  margin-bottom:60px;
}
.single-body p{margin-bottom:24px}
.single-body p:empty{display:none}
.single-body a{color:var(--c-accent-2);text-decoration:underline;text-underline-offset:3px}
.single-body h2,.single-body h3,.single-body h4{font-family:var(--font-mincho);font-weight:500;letter-spacing:.12em;line-height:1.5}
.single-body h2{font-size:26px;margin:60px 0 24px;padding-left:18px;border-left:4px solid var(--c-accent-3)}
.single-body h3,.single-body .stripe{
  font-size:22px;margin:54px 0 20px;padding-bottom:14px;
  border-bottom:1px solid rgba(184,155,106,.4);position:relative;
}
.single-body h3::after,.single-body .stripe::after{
  content:"";position:absolute;left:0;bottom:-1px;width:60px;height:2px;
  background:var(--c-accent-3);
}
.single-body h4,.single-body .stripe-sub{
  font-size:18px;margin:40px 0 16px;padding-left:14px;
  border-left:3px solid var(--c-accent-2);color:var(--c-accent-2);
}
.single-body ul,.single-body ol{margin:0 0 24px 0;padding:0;list-style:none}
.single-body ul li{margin-bottom:10px;padding-left:22px;position:relative;line-height:2}
.single-body ul li::before{
  content:"";position:absolute;left:4px;top:.85em;
  width:8px;height:8px;border-radius:50%;background:var(--c-accent-3);
}
.single-body ol{counter-reset:item;margin-left:0}
.single-body ol li{counter-increment:item;padding-left:36px;position:relative;margin-bottom:10px;line-height:2}
.single-body ol li::before{
  content:counter(item, decimal-leading-zero);
  position:absolute;left:0;top:.05em;
  font-family:var(--font-en);font-size:14px;color:var(--c-accent-3);
  font-style:italic;letter-spacing:.05em;
}
.single-body img,
.single-body .rounded-image,
.single-body .wp-block-image img{
  max-width:100%;height:auto;border-radius:var(--radius-md);
  margin:30px 0;display:block;
  box-shadow:0 14px 40px -20px rgba(40,50,40,.18);
}
.single-body strong{font-weight:600;color:var(--c-accent-2)}
.single-body blockquote{
  margin:32px 0;padding:24px 28px;background:#faf6ef;
  border-left:4px solid var(--c-accent-3);border-radius:0 8px 8px 0;
  font-style:italic;
}
.single-body blockquote p:last-child{margin-bottom:0}
.single-body hr{
  border:none;height:1px;background:var(--c-line);
  margin:50px auto;width:80px;
}
/* 古い投稿の独自クラスをリセット */
.single-body .natural-material-section,
.single-body .natural-material-wrapper,
.single-body .construction-container{
  background:none;padding:0;margin:0;display:block;
}

/* ===== Arie シリーズ投稿（リッチレイアウト） ===== */
.arie-post{font-family:var(--font-gothic)}
.arie-post *{box-sizing:border-box}
.arie-hero{
  position:relative;aspect-ratio:16/8;border-radius:var(--radius-md);
  overflow:hidden;margin-bottom:80px;
}
.arie-hero-img{position:absolute;inset:0}
.arie-hero-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  margin:0;border-radius:0;box-shadow:none;
}
.arie-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,18,15,.3),rgba(20,18,15,.6));
}
.arie-hero-text{
  position:absolute;left:0;right:0;bottom:50px;text-align:center;
  color:#fff;z-index:2;padding:0 20px;
}
.arie-hero-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.4em;
  display:block;margin-bottom:18px;opacity:.9;font-style:italic;
}
.single-body .arie-hero h2{
  font-family:var(--font-mincho);font-size:clamp(24px,3.5vw,38px);font-weight:500;
  letter-spacing:.18em;margin:0 0 14px;line-height:1.5;color:#fff;
  border:none;padding:0;
}
.single-body .arie-hero h2::after{display:none}
.arie-hero-text > p{
  font-family:var(--font-mincho);font-size:clamp(14px,1.6vw,17px);
  letter-spacing:.15em;line-height:1.8;color:#fff;opacity:.95;margin:0;
}
.arie-section{margin-bottom:70px}
.arie-section > p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.2;letter-spacing:.06em;
  margin:0 auto 22px;color:var(--c-fg);text-align:center;max-width:680px;
}
.arie-section > p:last-child{margin-bottom:0}
.single-body .arie-section-title{
  text-align:center;margin:0 auto 44px;font-family:var(--font-mincho);
  font-size:clamp(24px,3vw,32px);font-weight:500;letter-spacing:.14em;line-height:1.6;
  color:var(--c-fg);border:none;padding:0;
}
.single-body .arie-section-title::after{display:none}
.arie-section-en{
  display:block;font-family:var(--font-en);font-size:13px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);margin-bottom:14px;
}
.arie-feature{
  display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;
  margin-bottom:50px;
}
.arie-feature:last-child{margin-bottom:0}
.arie-feature-reverse > .arie-feature-img{order:2}
.arie-feature-img{
  aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-md);
  box-shadow:0 20px 50px -25px rgba(40,50,40,.3);
}
.arie-feature-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  margin:0;border-radius:0;box-shadow:none;
}
.single-body .arie-feature-text h3{
  font-family:var(--font-mincho);font-size:clamp(20px,2.4vw,26px);font-weight:500;
  letter-spacing:.12em;margin:0 0 24px;color:var(--c-fg);line-height:1.5;
  padding-left:18px;border-left:3px solid var(--c-accent-3);
  border-bottom:none;padding-bottom:0;
}
.single-body .arie-feature-text h3::after{display:none}
.arie-feature-text p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.15;letter-spacing:.06em;
  color:var(--c-fg);margin-bottom:18px;
}
.arie-feature-text p:last-child{margin-bottom:0}
.arie-gallery{
  display:grid;grid-template-columns:repeat(4,1fr);gap:12px;
  margin:60px 0 70px;
}
/* wpautopが入れる <br> を無効化 */
.arie-gallery br,.arie-lineup-list br,.arie-feature br,.arie-living-grid br{display:none}
.arie-gallery a{
  display:block;aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-sm);
  cursor:zoom-in;
}
.arie-gallery img{
  width:100%;height:100%;object-fit:cover;display:block;
  margin:0;border-radius:0;box-shadow:none;
  transition:transform .8s var(--ease-soft);
}
.arie-gallery a:hover img{transform:scale(1.08)}
.arie-living-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.arie-living-card{
  background:#faf6ef;padding:40px 36px;border-radius:var(--radius-md);
}
.single-body .arie-living-card h3{
  font-family:var(--font-mincho);font-size:20px;font-weight:500;letter-spacing:.12em;
  margin:0 0 22px;color:var(--c-fg);line-height:1.5;
  border:none;padding:0;
}
.single-body .arie-living-card h3::after{display:none}
.arie-living-card p{
  font-family:var(--font-gothic);font-size:14px;line-height:2.05;letter-spacing:.05em;
  color:var(--c-fg);margin-bottom:14px;
}
.arie-living-card p:last-child{margin-bottom:0}
.arie-lineup-list{display:flex;flex-direction:column;gap:50px;margin-top:0}
.arie-lineup-item{
  display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;
}
.arie-lineup-item.reverse > .arie-lineup-img{order:2}
.arie-lineup-img{
  aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-md);
  box-shadow:0 16px 40px -20px rgba(40,50,40,.22);
}
.arie-lineup-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s var(--ease-soft);
  margin:0;border-radius:0;box-shadow:none;
}
.arie-lineup-item:hover .arie-lineup-img img{transform:scale(1.05)}
.arie-lineup-body{padding:8px 0}
.arie-lineup-tag{
  display:inline-block;font-family:var(--font-en);font-size:11px;letter-spacing:.25em;
  color:var(--c-accent-3);font-style:italic;
  border-bottom:1px solid var(--c-accent-3);padding-bottom:3px;margin-bottom:20px;
}
.single-body .arie-lineup-name{
  font-family:var(--font-mincho);font-size:clamp(22px,2.6vw,28px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin:0 0 24px;line-height:1.5;
  border:none;padding:0;
}
.single-body .arie-lineup-name::after{display:none}
.arie-lineup-desc{
  font-family:var(--font-gothic);font-size:14px;line-height:2.05;letter-spacing:.05em;
  color:var(--c-fg);margin:0;
}
@media (max-width:880px){
  .arie-hero{aspect-ratio:16/10;margin-bottom:50px}
  .arie-hero-text{bottom:30px}
  .arie-section{margin-bottom:60px}
  .arie-feature{grid-template-columns:1fr;gap:30px;margin-bottom:50px}
  .arie-feature-reverse > .arie-feature-img{order:0}
  .arie-gallery{grid-template-columns:repeat(2,1fr);gap:10px;margin:50px 0 60px}
  .arie-living-grid{grid-template-columns:1fr;gap:16px}
  .arie-lineup-list{gap:40px}
  .arie-lineup-item{grid-template-columns:1fr;gap:24px}
  .arie-lineup-item.reverse > .arie-lineup-img{order:0}
}

/* ===== HUCK シリーズ投稿（マガジン風レイアウト） ===== */
.huck-post{font-family:var(--font-gothic)}
.huck-post *{box-sizing:border-box}
.huck-hero{
  position:relative;aspect-ratio:16/8;border-radius:var(--radius-md);
  overflow:hidden;margin-bottom:70px;
}
.huck-hero-img{position:absolute;inset:0}
.huck-hero-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  margin:0;border-radius:0;box-shadow:none;
}
.huck-hero::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(20,30,18,.7) 0%,rgba(20,18,15,.45) 60%,rgba(20,18,15,.3) 100%);
}
.huck-hero-text{
  position:absolute;left:48px;top:50%;transform:translateY(-50%);
  color:#fff;z-index:2;max-width:60%;
}
.huck-hero-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.4em;
  display:block;margin-bottom:18px;opacity:.9;font-style:italic;
  border-left:2px solid #fff;padding-left:14px;
}
.single-body .huck-hero h2{
  font-family:var(--font-mincho);font-size:clamp(24px,3.5vw,40px);font-weight:500;
  letter-spacing:.16em;margin:0 0 18px;line-height:1.5;color:#fff;
  border:none;padding:0;
}
.single-body .huck-hero h2::after{display:none}
.huck-hero-text > p{
  font-family:var(--font-mincho);font-size:clamp(14px,1.6vw,17px);
  letter-spacing:.14em;line-height:1.8;color:#fff;opacity:.95;margin:0;
}
.huck-section{margin-bottom:80px}
.huck-section > p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.2;letter-spacing:.06em;
  margin:0 auto 22px;color:var(--c-fg);text-align:center;max-width:680px;
}
.huck-section > p:last-child{margin-bottom:0}
.single-body .huck-section-title{
  text-align:center;margin:0 auto 50px;font-family:var(--font-mincho);
  font-size:clamp(24px,3vw,32px);font-weight:500;letter-spacing:.14em;line-height:1.6;
  color:var(--c-fg);border:none;padding:0;
}
.single-body .huck-section-title::after{display:none}
.huck-section-en{
  display:block;font-family:var(--font-en);font-size:13px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);margin-bottom:14px;
}
.huck-feature{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  margin-bottom:80px;
}
.huck-feature:last-of-type{margin-bottom:0}
.huck-feature-reverse > .huck-feature-mosaic{order:2}
.huck-feature-mosaic{position:relative;aspect-ratio:1/1}
.huck-feature-img-large{
  position:absolute;left:0;top:0;width:78%;height:78%;
  overflow:hidden;border-radius:var(--radius-md);
  box-shadow:0 20px 50px -25px rgba(40,50,40,.28);
}
.huck-feature-img-small{
  position:absolute;right:0;bottom:0;width:55%;height:55%;
  overflow:hidden;border-radius:var(--radius-md);
  box-shadow:0 25px 50px -15px rgba(40,50,40,.35);
  border:6px solid #fff;
}
.huck-feature-img-large img,
.huck-feature-img-small img{
  width:100%;height:100%;object-fit:cover;display:block;
  margin:0;border-radius:0;box-shadow:none;
}
.single-body .huck-feature-text h3{
  font-family:var(--font-mincho);font-size:clamp(20px,2.4vw,26px);font-weight:500;
  letter-spacing:.12em;margin:0 0 24px;color:var(--c-fg);line-height:1.5;
  border:none;padding:0 0 0 0;border-bottom:none;
}
.single-body .huck-feature-text h3::before{
  content:"";display:inline-block;width:30px;height:1px;background:var(--c-accent-3);
  vertical-align:middle;margin-right:14px;
}
.single-body .huck-feature-text h3::after{display:none}
.huck-feature-text p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.15;letter-spacing:.06em;
  color:var(--c-fg);margin-bottom:0;
}
.huck-lineup-intro{
  text-align:center;font-family:var(--font-gothic);font-size:15px;line-height:2.2;
  letter-spacing:.06em;color:var(--c-fg);max-width:680px;margin:0 auto 50px;
}
.huck-lineup-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:0;
}
.huck-lineup-card{
  background:#fff;border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--c-line);
  transition:transform .5s var(--ease-soft),box-shadow .5s var(--ease-soft);
}
.huck-lineup-card:hover{
  transform:translateY(-4px);box-shadow:0 18px 40px -18px rgba(40,50,40,.2);
}
.huck-lineup-card.full{
  grid-column:span 2;display:grid;grid-template-columns:1fr 1fr;
}
.huck-lineup-card.full .huck-lineup-card-img{aspect-ratio:auto;height:100%}
.huck-lineup-card-img{aspect-ratio:16/10;overflow:hidden}
.huck-lineup-card-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  margin:0;border-radius:0;box-shadow:none;
  transition:transform 1.2s var(--ease-soft);
}
.huck-lineup-card:hover .huck-lineup-card-img img{transform:scale(1.06)}
.huck-lineup-card-body{padding:28px 30px 30px}
.huck-lineup-card.full .huck-lineup-card-body{padding:40px 44px;display:flex;flex-direction:column;justify-content:center}
.huck-lineup-card-tag{
  display:inline-block;font-family:var(--font-en);font-size:11px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;
  border:1px solid var(--c-accent-3);padding:3px 12px;border-radius:14px;
  margin-bottom:14px;
}
.single-body .huck-lineup-card h3{
  font-family:var(--font-mincho);font-size:20px;font-weight:500;letter-spacing:.12em;
  margin:0 0 16px;color:var(--c-fg);line-height:1.5;
  border:none;padding:0;
}
.single-body .huck-lineup-card h3::after{display:none}
.huck-lineup-card.full h3{font-size:clamp(22px,2.4vw,28px)}
.huck-lineup-card p{
  font-family:var(--font-gothic);font-size:13px;line-height:2;letter-spacing:.04em;
  color:var(--c-muted);margin:0;
}
.huck-closing{
  margin-top:60px;padding:36px 30px;background:#faf6ef;border-radius:var(--radius-md);
  text-align:center;
}
.huck-closing p{
  font-family:var(--font-mincho);font-size:15px;line-height:2;letter-spacing:.1em;
  color:var(--c-fg);margin:0;
}
.huck-section br,.huck-lineup-grid br,.huck-feature br{display:none}
@media (max-width:880px){
  .huck-hero{aspect-ratio:16/10;margin-bottom:50px}
  .huck-hero-text{left:20px;right:20px;max-width:100%}
  .huck-section{margin-bottom:60px}
  .huck-feature{grid-template-columns:1fr;gap:30px;margin-bottom:50px}
  .huck-feature-reverse > .huck-feature-mosaic{order:0}
  .huck-feature-mosaic{max-width:480px;margin:0 auto}
  .huck-lineup-grid{grid-template-columns:1fr;gap:18px}
  .huck-lineup-card.full{grid-column:span 1;grid-template-columns:1fr}
  .huck-lineup-card.full .huck-lineup-card-img{aspect-ratio:16/10}
  .huck-lineup-card.full .huck-lineup-card-body{padding:28px 30px 30px}
}

/* ===== SDGs 投稿（緑系アクセント・サステナブル風） ===== */
.sdgs-post{font-family:var(--font-gothic)}
.sdgs-post *{box-sizing:border-box}
.sdgs-hero{
  position:relative;padding:170px 110px 150px;
  background:linear-gradient(135deg,#3d5f40 0%,#5a7d4d 60%,#83a268 100%);
  border-radius:var(--radius-md);overflow:hidden;
  margin-bottom:80px;text-align:center;color:#fff;
}
.sdgs-hero::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);
  background-size:30px 30px;opacity:.5;
}
.sdgs-vision-wrap{
  display:grid;grid-template-columns:0.8fr 1.2fr;gap:60px;align-items:center;
  max-width:980px;margin:0 auto;
}
.sdgs-vision-image{
  border-radius:var(--radius-md);overflow:hidden;
  box-shadow:0 18px 40px -20px rgba(40,50,40,.22);
}
.sdgs-vision-image img{
  width:100%;height:auto;display:block;
  margin:0;border-radius:0;box-shadow:none;
}
.sdgs-vision-wrap .sdgs-vision{text-align:left;max-width:none}
.sdgs-vision-wrap .sdgs-vision .quote{text-align:center}
.sdgs-goals-banner{
  background:#faf8f0;border:1px solid var(--c-line);
  border-radius:var(--radius-md);padding:36px 44px;text-align:center;
  margin-bottom:60px;
}
.sdgs-goals-banner-label{
  display:block;font-family:var(--font-en);font-size:12px;letter-spacing:.35em;
  font-style:italic;color:#5a7d4d;margin-bottom:18px;
}
.sdgs-goals-banner-image img{
  max-width:100%;height:auto;display:block;margin:0 auto;
  border-radius:8px;box-shadow:0 10px 30px -16px rgba(40,50,40,.2);
}
.sdgs-goals-banner-caption{
  font-family:var(--font-gothic);font-size:13px;line-height:1.95;color:var(--c-muted);
  letter-spacing:.06em;margin-top:18px;
}
.sdgs-hero-en{
  display:block;font-family:var(--font-en);font-size:13px;letter-spacing:.4em;
  font-style:italic;opacity:.85;margin-bottom:20px;position:relative;
}
.single-body .sdgs-hero h2{
  font-family:var(--font-mincho);font-size:clamp(22px,3.2vw,34px);font-weight:500;
  letter-spacing:.13em;color:#fff;border:none;padding:0;margin:0 auto 26px;
  line-height:1.7;position:relative;max-width:640px;
}
.single-body .sdgs-hero h2::after{display:none}
.sdgs-hero-lead{
  font-family:var(--font-mincho);font-size:clamp(14px,1.6vw,17px);
  letter-spacing:.12em;line-height:2;opacity:.95;max-width:580px;margin:0 auto;
  position:relative;
}
.sdgs-section{margin-bottom:90px}
.sdgs-section:last-of-type{margin-bottom:0}
.single-body .sdgs-section-title{
  text-align:center;margin:0 auto 50px;font-family:var(--font-mincho);
  font-size:clamp(24px,2.8vw,32px);font-weight:500;letter-spacing:.14em;
  color:var(--c-fg);border:none;padding:0;line-height:1.6;
}
.single-body .sdgs-section-title::after{display:none}
.sdgs-section-en{
  display:block;font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  font-style:italic;color:#5a7d4d;margin-bottom:14px;
}
.sdgs-vision{text-align:center;max-width:760px;margin:0 auto}
.sdgs-vision p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.2;letter-spacing:.06em;
  color:var(--c-fg);margin-bottom:22px;
}
.sdgs-vision p:last-child{margin-bottom:0}
.sdgs-vision .quote{
  font-family:var(--font-mincho);font-size:clamp(16px,1.9vw,21px);
  color:#3d5f40;letter-spacing:.16em;line-height:2;margin-bottom:30px;
  padding:28px 0;border-top:1px solid rgba(90,125,77,.35);border-bottom:1px solid rgba(90,125,77,.35);
}
.sdgs-initiatives{display:flex;flex-direction:column;gap:24px;max-width:920px;margin:0 auto}
.sdgs-initiative{
  display:grid;grid-template-columns:160px 1fr;gap:40px;align-items:start;
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-md);
  padding:36px 40px;
  transition:transform .4s,box-shadow .4s,border-color .4s;
}
.sdgs-initiative:hover{
  transform:translateY(-3px);box-shadow:0 18px 40px -18px rgba(40,50,40,.15);
  border-color:#83a268;
}
.sdgs-initiative-left{
  display:flex;flex-direction:column;align-items:center;gap:16px;padding-top:6px;
}
.sdgs-initiative-num{
  font-family:var(--font-en);font-size:54px;font-weight:500;letter-spacing:.02em;
  color:#83a268;line-height:1;font-style:italic;
}
.sdgs-initiative-icon{
  width:64px;height:64px;border-radius:50%;
  background:#eef3e6;color:#5a7d4d;
  display:flex;align-items:center;justify-content:center;
}
.sdgs-initiative-icon iconify-icon{font-size:30px}
.single-body .sdgs-initiative-body h3{
  font-family:var(--font-mincho);font-size:22px;font-weight:500;letter-spacing:.12em;
  color:var(--c-fg);margin:0 0 18px;line-height:1.5;
  border:none;padding:0;
}
.single-body .sdgs-initiative-body h3::after{display:none}
.sdgs-initiative-body p{
  font-family:var(--font-gothic);font-size:14px;line-height:2.1;letter-spacing:.05em;
  color:var(--c-fg);margin-bottom:14px;
}
.sdgs-initiative-body p:last-child{margin-bottom:0}
.sdgs-goal{
  background:linear-gradient(135deg,#eef3e6 0%,#dde6cf 100%);
  border-radius:var(--radius-md);padding:54px 50px;text-align:center;
  position:relative;overflow:hidden;
}
.sdgs-goal::before{
  content:"→";position:absolute;right:-30px;top:50%;transform:translateY(-50%);
  font-size:240px;color:#fff;opacity:.45;line-height:1;font-family:var(--font-en);
  font-weight:300;pointer-events:none;
}
.sdgs-goal-label{
  display:inline-block;font-family:var(--font-en);font-size:11px;letter-spacing:.35em;
  color:#3d5f40;font-style:italic;margin-bottom:18px;
  padding:5px 16px;background:#fff;border-radius:14px;position:relative;
}
.single-body .sdgs-goal h2{
  font-family:var(--font-mincho);font-size:clamp(22px,2.6vw,28px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin:0 0 22px;line-height:1.6;
  border:none;padding:0;position:relative;
}
.single-body .sdgs-goal h2::after{display:none}
.sdgs-goal p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.15;letter-spacing:.05em;
  color:var(--c-fg);margin:0 auto;max-width:680px;position:relative;
}
.sdgs-commitment{text-align:center;padding:60px 30px 30px;border-top:1px solid var(--c-line);margin-top:60px}
.sdgs-commitment-en{
  display:block;font-family:var(--font-en);font-size:12px;letter-spacing:.4em;
  font-style:italic;color:#5a7d4d;margin-bottom:16px;
}
.single-body .sdgs-commitment h2{
  font-family:var(--font-mincho);font-size:clamp(22px,2.6vw,28px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin:0 0 30px;line-height:1.6;
  border:none;padding:0;
}
.single-body .sdgs-commitment h2::after{display:none}
.sdgs-commitment p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.2;letter-spacing:.06em;
  color:var(--c-fg);max-width:720px;margin:0 auto 22px;
}
.sdgs-commitment p:last-child{margin-bottom:0}
.sdgs-section br,.sdgs-initiatives br,.sdgs-initiative br,.sdgs-vision br{display:none}
.sdgs-initiative-body .sdgs-related-goals{
  margin-top:18px;padding:14px 18px;
  background:#f4f7ee;border-left:3px solid #7a9b5a;
  font-size:12.5px;line-height:1.85;color:var(--c-muted);
  letter-spacing:.04em;border-radius:0 6px 6px 0;
}
.sdgs-initiative-body .sdgs-related-goals strong{
  color:#3d5f40;font-weight:500;display:inline-block;margin-right:4px;
}
.sdgs-commitment .sdgs-commitment-links{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
  margin:32px auto 0;max-width:none;
}
.sdgs-commitment .sdgs-commitment-links a{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-en);font-size:12px;letter-spacing:.18em;
  color:#3d5f40;text-decoration:none;padding:11px 24px;
  background:#fff;border:1px solid #b5c89a;border-radius:30px;
  transition:all .4s var(--ease-soft);
}
.sdgs-commitment .sdgs-commitment-links a:hover{
  background:#3d5f40;color:#fff;border-color:#3d5f40;
}
@media (max-width:768px){
  .sdgs-hero{padding:70px 32px 80px;margin-bottom:50px}
  .sdgs-section{margin-bottom:60px}
  .sdgs-vision-wrap{grid-template-columns:1fr;gap:30px}
  .sdgs-vision-image{max-width:340px;margin:0 auto}
  .sdgs-goals-banner{padding:24px 22px}
  .sdgs-initiative{grid-template-columns:1fr;gap:20px;padding:28px 24px}
  .sdgs-initiative-left{flex-direction:row;gap:20px;justify-content:flex-start;align-items:center;padding-top:0}
  .sdgs-initiative-num{font-size:40px}
  .sdgs-initiative-icon{width:54px;height:54px}
  .sdgs-goal{padding:40px 28px}
  .sdgs-goal::before{font-size:120px;right:-20px}
  .sdgs-commitment{padding:40px 20px 20px}
}

.single-share{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 0 70px;padding:24px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line)}
.single-share-label{
  font-family:var(--font-gothic);font-size:12px;letter-spacing:.2em;
  color:var(--c-muted);
}
.single-share-buttons{display:flex;gap:12px}
.share-btn{
  display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:50%;
  background:#fff;color:var(--c-accent-2);
  border:1px solid var(--c-line);
  transition:all .35s var(--ease-soft);
}
.share-btn:hover{transform:translateY(-3px);opacity:1}
.share-x:hover{background:#000;border-color:#000;color:#fff}
.share-fb:hover{background:#1877f2;border-color:#1877f2;color:#fff}
.share-line:hover{background:#06c755;border-color:#06c755;color:#fff}

.single-nav{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;margin-bottom:80px}
.single-nav-link{
  display:flex;flex-direction:column;gap:6px;padding:18px 22px;
  border:1px solid var(--c-line);border-radius:var(--radius-md);
  transition:all .35s var(--ease-soft);
}
.single-nav-link:hover{border-color:var(--c-accent-3);background:#faf6ef;opacity:1}
.single-nav-link.next{text-align:right;align-items:flex-end}
.single-nav-link.back{padding:14px 22px;text-align:center;align-items:center}
.single-nav-label{font-family:var(--font-en);font-size:11px;letter-spacing:.2em;color:var(--c-accent-3);font-style:italic}
.single-nav-title{font-family:var(--font-gothic);font-size:13px;line-height:1.5;color:var(--c-fg);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}

.single-related{margin-top:30px}
.single-related-title{
  text-align:center;font-family:var(--font-mincho);font-size:22px;
  letter-spacing:.15em;color:var(--c-fg);margin-bottom:40px;font-weight:500;
}
@media (max-width:768px){
  .single-nav{grid-template-columns:1fr;gap:10px}
  .single-nav-link.next{text-align:left;align-items:flex-start}
}

/* ===== ライトボックス ===== */
.lightbox{
  position:fixed;inset:0;z-index:99999;
  background:rgba(15,15,15,.94);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .4s var(--ease),visibility .4s var(--ease);
}
.lightbox.is-open{opacity:1;visibility:visible;pointer-events:auto}
.lightbox-content{
  position:relative;max-width:92vw;max-height:88vh;
  display:flex;align-items:center;justify-content:center;
}
.lightbox-img{
  max-width:92vw;max-height:88vh;display:block;
  border-radius:8px;box-shadow:0 30px 60px -20px rgba(0,0,0,.5);
  transform:scale(.94);transition:transform .5s var(--ease-soft);object-fit:contain;
}
.lightbox.is-open .lightbox-img{transform:scale(1)}
.lightbox-close,.lightbox-prev,.lightbox-next{
  position:absolute;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.14);color:#fff;cursor:pointer;border:none;
  border-radius:50%;backdrop-filter:blur(10px);
  transition:background .3s,transform .3s;z-index:2;
}
.lightbox-close{
  top:24px;right:24px;width:46px;height:46px;
}
.lightbox-prev,.lightbox-next{
  top:50%;transform:translateY(-50%);width:54px;height:54px;
}
.lightbox-prev{left:24px}
.lightbox-next{right:24px}
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover{
  background:rgba(255,255,255,.3);
}
.lightbox-prev:hover{transform:translateY(-50%) translateX(-4px)}
.lightbox-next:hover{transform:translateY(-50%) translateX(4px)}
.lightbox-counter{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);
  color:#fff;font-family:var(--font-en);font-size:11px;letter-spacing:.28em;
  background:rgba(0,0,0,.4);padding:8px 18px;border-radius:20px;
  backdrop-filter:blur(8px);font-style:italic;
}
body.lightbox-open{overflow:hidden}
.gallery-item{cursor:zoom-in}
@media (max-width:640px){
  .lightbox-prev{left:8px;width:42px;height:42px}
  .lightbox-next{right:8px;width:42px;height:42px}
  .lightbox-close{top:12px;right:12px;width:38px;height:38px}
  .lightbox-counter{bottom:14px;font-size:10px}
}

/* ===== 各ページ共通: 既定のsection padding(140px)をリセット ===== */
.company-page section,
.contact-page section,
.access-page section,
.legal-page section,
.works-page section,
.thanks-page section,
.booking-page section,
.notfound-page section,
.promises-page section,
.service-hub-page section,
.single-post section,
.arie-post section,
.huck-post section,
.sdgs-post section{padding:0}
/* vision-page と service-detail-page は各セクションが独自paddingを持つので、特定要素だけリセット */
.vision-page .vision-principles{padding:0}
.service-detail-page .service-detail-hero{padding:0}
.sdgs-post .sdgs-hero{padding:90px 110px 90px}
@media (max-width:768px){
  .sdgs-post .sdgs-hero{padding:80px 32px 70px}
}

/* ===== 会社概要ページ ===== */
.company-page{padding:140px 0 100px;background:#fff;min-height:60vh;position:relative;overflow:hidden}
.company-page .container{max-width:1100px;position:relative}
.company-intro{text-align:center;margin-bottom:80px;position:relative}
.company-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:24px;
}
.company-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(30px,4.5vw,46px);font-weight:500;
  letter-spacing:.12em;margin-bottom:36px;color:var(--c-fg);
}
.company-tagline{
  font-family:var(--font-mincho);font-size:clamp(17px,2vw,22px);
  color:var(--c-accent-2);letter-spacing:.15em;line-height:1.7;
}
.company-section{margin-bottom:90px;position:relative}
.company-section:last-of-type{margin-bottom:0}
.company-section-head{margin-bottom:48px;text-align:center}
.company-section-head .section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:16px;
}
.company-section-head h2{
  font-family:var(--font-mincho);font-size:clamp(26px,3.2vw,36px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);
}
.philosophy-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.philosophy-image{
  border-radius:var(--radius-md);overflow:hidden;position:relative;
  aspect-ratio:4/3;box-shadow:0 20px 50px -20px rgba(40,50,40,.25);
}
.philosophy-image img{width:100%;height:100%;object-fit:cover;display:block}
.philosophy-text p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;letter-spacing:.04em;
  color:var(--c-fg);margin-bottom:22px;
}
.philosophy-text p:last-child{margin-bottom:0}
.company-table{
  width:100%;border-collapse:collapse;
  background:#fff;border-radius:var(--radius-md);overflow:hidden;
  box-shadow:0 4px 30px -10px rgba(40,50,40,.08);border:1px solid var(--c-line);
}
.company-table th,.company-table td{
  padding:24px 32px;text-align:left;vertical-align:top;
  border-bottom:1px solid var(--c-line);
  font-family:var(--font-gothic);font-size:15px;line-height:1.95;letter-spacing:.04em;
}
.company-table tr:last-child th,.company-table tr:last-child td{border-bottom:none}
.company-table th{
  width:30%;background:#faf6ef;color:var(--c-accent-2);
  font-weight:500;letter-spacing:.12em;font-size:14px;
}
.studio-block{margin-bottom:18px}
.studio-block:last-child{margin-bottom:0}
.studio-name{
  display:inline-block;font-family:var(--font-en);font-size:11px;letter-spacing:.25em;
  color:var(--c-accent-3);border-bottom:1px solid var(--c-accent-3);
  padding-bottom:3px;margin-bottom:8px;font-style:italic;
}
.placeholder-badge{
  display:inline-block;background:#f3e9d6;color:#a8956a;
  font-size:10px;padding:3px 10px;border-radius:10px;
  letter-spacing:.18em;margin-left:10px;vertical-align:middle;font-style:italic;
}
.business-intro{
  text-align:center;max-width:760px;margin:0 auto 50px;
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;color:var(--c-fg);
  letter-spacing:.04em;
}
.business-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.business-card{
  background:#fff;border-radius:var(--radius-md);overflow:hidden;
  box-shadow:0 4px 30px -10px rgba(40,50,40,.08);
  border:1px solid var(--c-line);
  transition:transform .6s var(--ease-soft),box-shadow .6s var(--ease-soft);
}
.business-card:hover{transform:translateY(-4px);box-shadow:0 20px 50px -20px rgba(40,50,40,.2);opacity:1}
.business-card-image{aspect-ratio:16/10;overflow:hidden;position:relative}
.business-card-image img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s var(--ease-soft);
}
.business-card:hover .business-card-image img{transform:scale(1.06)}
.business-card-body{padding:32px 32px 36px}
.business-card-number{
  font-family:var(--font-en);font-size:12px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:10px;
}
.business-card h3{
  font-family:var(--font-mincho);font-size:22px;font-weight:500;letter-spacing:.1em;
  color:var(--c-fg);margin-bottom:18px;
}
.business-card p{
  font-family:var(--font-gothic);font-size:14px;line-height:2;letter-spacing:.03em;
  color:var(--c-muted);
}
@media (max-width:880px){
  .philosophy-grid{grid-template-columns:1fr;gap:36px}
  .business-grid{grid-template-columns:1fr;gap:30px}
}
@media (max-width:640px){
  .company-table th,.company-table td{display:block;width:100%;padding:14px 22px}
  .company-table th{border-bottom:none;padding-bottom:6px}
  .company-table td{padding-top:0}
  .company-section{margin-bottom:90px}
}

/* ===== お問い合わせページ ===== */
.contact-page{padding:140px 0 100px;background:#fff;min-height:60vh;position:relative;overflow:hidden}
.contact-page .container{max-width:1100px;position:relative}
.contact-intro{text-align:center;margin-bottom:70px;position:relative}
.contact-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:24px;
}
.contact-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(30px,4.5vw,46px);font-weight:500;
  letter-spacing:.12em;margin-bottom:30px;color:var(--c-fg);
}
.contact-tagline{
  font-family:var(--font-mincho);font-size:clamp(17px,2vw,22px);
  color:var(--c-accent-2);letter-spacing:.15em;line-height:1.7;margin-bottom:26px;
}
.contact-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;color:var(--c-fg);
  letter-spacing:.04em;max-width:720px;margin:0 auto;
}
.contact-methods{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:90px;
}
.contact-method-card{
  display:block;background:#fff;border-radius:var(--radius-md);
  border:1px solid var(--c-line);padding:38px 24px 32px;text-align:center;
  transition:transform .5s var(--ease-soft),box-shadow .5s var(--ease-soft),border-color .5s;
  text-decoration:none;color:var(--c-fg);
}
.contact-method-card:hover{
  transform:translateY(-4px);box-shadow:0 18px 40px -18px rgba(40,50,40,.18);
  border-color:var(--c-accent-3);opacity:1;
}
.contact-method-icon{
  display:inline-flex;width:64px;height:64px;border-radius:50%;
  background:#faf6ef;color:var(--c-accent-2);
  align-items:center;justify-content:center;font-size:28px;margin-bottom:20px;
  transition:background .5s,color .5s;
}
.contact-method-card:hover .contact-method-icon{
  background:var(--c-accent-2);color:#fff;
}
.contact-method-label{
  display:block;font-family:var(--font-en);font-size:11px;letter-spacing:.25em;
  color:var(--c-accent-3);font-style:italic;margin-bottom:8px;
}
.contact-method-title{
  display:block;font-family:var(--font-mincho);font-size:18px;font-weight:500;
  letter-spacing:.08em;margin-bottom:12px;color:var(--c-fg);
}
.contact-method-value{
  display:block;font-family:var(--font-gothic);font-size:13px;line-height:1.85;
  color:var(--c-muted);letter-spacing:.03em;
}
.contact-method-value strong{
  display:block;font-family:var(--font-en);font-size:20px;font-weight:500;
  color:var(--c-accent-2);letter-spacing:.05em;margin-bottom:6px;
}
.contact-form-section{margin-bottom:50px;position:relative}
.contact-form-head{margin-bottom:48px;text-align:center}
.contact-studios-head{margin-bottom:40px;text-align:center}
.contact-studios-head .section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:14px;
}
.contact-studios-head h2{
  font-family:var(--font-mincho);font-size:clamp(24px,2.8vw,32px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);
}
.contact-form-head .section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:16px;
}
.contact-form-head h2{
  font-family:var(--font-mincho);font-size:clamp(26px,3.2vw,36px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);
}
.contact-form-wrap{
  max-width:820px;margin:0 auto;background:#faf6ef;
  padding:60px 56px;border-radius:var(--radius-md);
}
.contact-form-wrap .wpcf7 p{margin:0}
.cf-form{display:flex;flex-direction:column;gap:26px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cf-field{display:flex;flex-direction:column;gap:10px}
.cf-label{
  font-family:var(--font-gothic);font-size:14px;font-weight:500;
  color:var(--c-fg);letter-spacing:.08em;
  display:flex;align-items:center;gap:10px;
}
.cf-req{
  display:inline-block;padding:3px 10px;background:var(--c-accent-3);
  color:#fff;font-size:10px;letter-spacing:.15em;border-radius:10px;
  font-weight:500;
}
.contact-form-wrap .cf-form input[type="text"],
.contact-form-wrap .cf-form input[type="email"],
.contact-form-wrap .cf-form input[type="tel"],
.contact-form-wrap .cf-form input[type="url"],
.contact-form-wrap .cf-form input[type="number"],
.contact-form-wrap .cf-form textarea,
.contact-form-wrap .cf-form select{
  width:100%;padding:16px 20px;
  border:1px solid var(--c-line);background:#fff;
  border-radius:var(--radius-sm);font-family:inherit;font-size:15px;
  letter-spacing:.04em;color:var(--c-fg);
  transition:border-color .3s,box-shadow .3s;
  margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;
}
.contact-form-wrap .cf-form select{
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%238a7558' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 18px center;background-size:16px;
  padding-right:46px;cursor:pointer;
}
.contact-form-wrap .cf-form input:focus,
.contact-form-wrap .cf-form textarea:focus,
.contact-form-wrap .cf-form select:focus{
  outline:none;border-color:var(--c-accent-3);
  box-shadow:0 0 0 3px rgba(184,155,106,.18);
}
.contact-form-wrap .cf-form textarea{min-height:200px;resize:vertical;line-height:1.85}
.contact-form-wrap .cf-form input::placeholder,
.contact-form-wrap .cf-form textarea::placeholder{
  color:#bfb39a;letter-spacing:.04em;
}
.cf-submit{display:flex;justify-content:center;margin-top:14px}
.contact-form-wrap .cf-form input[type="submit"],
.contact-form-wrap .cf-submit input[type="submit"]{
  display:inline-block;padding:20px 64px;background:var(--c-accent);
  color:#fff;border:none;border-radius:30px;
  font-family:var(--font-gothic);font-size:15px;font-weight:500;
  letter-spacing:.2em;cursor:pointer;width:auto;
  transition:background .4s,transform .4s,box-shadow .4s;
  box-shadow:0 8px 24px -10px rgba(40,50,40,.3);
}
.contact-form-wrap .cf-form input[type="submit"]:hover,
.contact-form-wrap .cf-submit input[type="submit"]:hover{
  background:var(--c-accent-2);transform:translateY(-2px);
  box-shadow:0 14px 30px -10px rgba(40,50,40,.4);
}
.contact-form-wrap .wpcf7-list-item{margin:0 16px 8px 0;display:inline-block}
.contact-form-wrap .wpcf7-not-valid-tip{
  font-family:var(--font-gothic);font-size:12px;color:#c54545;
  margin-top:6px;letter-spacing:.04em;
}
.contact-form-wrap .wpcf7-response-output{
  border-radius:var(--radius-sm);padding:16px 20px;font-size:13.5px;margin:24px 0 0;
  border-width:1px;font-family:var(--font-gothic);letter-spacing:.04em;
}
.contact-form-wrap .wpcf7 form.invalid .wpcf7-response-output,
.contact-form-wrap .wpcf7 form.unaccepted .wpcf7-response-output{
  background:#fff5f5;border-color:#e8c0c0;color:#a04545;
}
.contact-form-wrap .wpcf7 form.sent .wpcf7-response-output{
  background:#f3f8ee;border-color:#c0d8b0;color:#557040;
}
@media (max-width:640px){
  .contact-form-wrap{padding:36px 22px}
  .cf-row{grid-template-columns:1fr;gap:24px}
  .contact-form-wrap .cf-form input[type="submit"],
  .contact-form-wrap .cf-submit input[type="submit"]{padding:18px 48px;font-size:14px}
}
.contact-studios{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.contact-studio{
  background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-md);padding:34px 32px;
}
.contact-studio-name{
  display:inline-block;font-family:var(--font-en);font-size:12px;letter-spacing:.25em;
  color:var(--c-accent-3);font-style:italic;
  border-bottom:1px solid var(--c-accent-3);padding-bottom:4px;margin-bottom:18px;
}
.contact-studio h3{
  font-family:var(--font-mincho);font-size:20px;font-weight:500;letter-spacing:.1em;
  color:var(--c-fg);margin-bottom:14px;
}
.contact-studio p{
  font-family:var(--font-gothic);font-size:14px;line-height:1.95;
  color:var(--c-muted);letter-spacing:.04em;
}
@media (max-width:880px){
  .contact-methods{grid-template-columns:1fr;gap:16px;margin-bottom:60px}
  .contact-form-wrap{padding:40px 22px}
  .contact-studios{grid-template-columns:1fr;gap:20px}
}

/* ===== プライバシーポリシーページ ===== */
.legal-page{padding:140px 0 100px;background:#fff;min-height:60vh;position:relative;overflow:hidden}
.legal-page .container{max-width:880px;position:relative}
.legal-intro{text-align:center;margin-bottom:70px;position:relative}
.legal-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:24px;
}
.legal-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(28px,4vw,42px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);
}
.legal-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.1;color:var(--c-fg);
  letter-spacing:.04em;margin-bottom:60px;
}
.legal-article{margin-bottom:42px}
.legal-article:last-child{margin-bottom:0}
.legal-article h2{
  font-family:var(--font-mincho);font-size:20px;font-weight:500;letter-spacing:.1em;
  color:var(--c-fg);margin-bottom:18px;
  padding-left:18px;border-left:3px solid var(--c-accent-3);line-height:1.5;
}
.legal-article p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.1;letter-spacing:.04em;
  color:var(--c-fg);margin-bottom:14px;
}
.legal-article ul{
  list-style:none;margin:0 0 14px;padding:0;
}
.legal-article li{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2;letter-spacing:.04em;
  color:var(--c-fg);padding-left:22px;position:relative;margin-bottom:6px;
}
.legal-article li::before{
  content:"";position:absolute;left:4px;top:.95em;
  width:6px;height:6px;border-radius:50%;background:var(--c-accent-3);
}
.legal-article a{
  color:var(--c-accent-2);text-decoration:underline;text-underline-offset:3px;
  word-break:break-all;
}
.legal-meta{
  margin-top:60px;padding-top:30px;border-top:1px solid var(--c-line);
  font-family:var(--font-gothic);font-size:13px;color:var(--c-muted);
  letter-spacing:.05em;text-align:right;line-height:2;
}

/* ===== アクセスページ ===== */
.access-page{padding:140px 0 100px;background:#fff;min-height:60vh;position:relative;overflow:hidden}
.access-page .container{max-width:1100px;position:relative}
.access-intro{text-align:center;margin-bottom:70px;position:relative}
.access-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:24px;
}
.access-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(30px,4.5vw,46px);font-weight:500;
  letter-spacing:.12em;margin-bottom:30px;color:var(--c-fg);
}
.access-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;color:var(--c-fg);
  letter-spacing:.04em;max-width:720px;margin:0 auto;
}
.access-studio{
  margin-bottom:80px;background:#fff;border-radius:var(--radius-md);
  overflow:hidden;border:1px solid var(--c-line);
  box-shadow:0 4px 30px -12px rgba(40,50,40,.08);
}
.access-studio:last-child{margin-bottom:0}
.access-studio-head{
  padding:38px 40px;background:#faf6ef;border-bottom:1px solid var(--c-line);
  line-height:1.5;
}
.access-studio-en{
  font-family:var(--font-en);font-size:11px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;
  border-bottom:1px solid var(--c-accent-3);padding-bottom:3px;
  display:inline-block;margin-bottom:6px;
}
.access-studio-title{
  font-family:var(--font-mincho);font-size:22px;font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);line-height:1.4;display:block;
}
.access-studio-body{display:grid;grid-template-columns:1fr 1.2fr;gap:0}
.access-info{padding:36px 40px}
.access-info-row{
  display:grid;grid-template-columns:90px 1fr;gap:14px;
  padding:14px 0;border-bottom:1px solid var(--c-line);
}
.access-info-row:last-child{border-bottom:none}
.access-info-label{
  font-family:var(--font-en);font-size:11px;letter-spacing:.2em;
  color:var(--c-accent-3);font-style:italic;padding-top:3px;
}
.access-info-value{
  font-family:var(--font-gothic);font-size:14px;line-height:1.85;letter-spacing:.04em;
  color:var(--c-fg);
}
.access-info-value strong{
  font-family:var(--font-en);font-size:18px;color:var(--c-accent-2);
  font-weight:500;letter-spacing:.05em;display:block;
}
.access-map{position:relative;min-height:380px;background:#f5efe1}
.access-map iframe{width:100%;height:100%;border:0;display:block;position:absolute;inset:0}
@media (max-width:880px){
  .access-studio-body{grid-template-columns:1fr}
  .access-map{min-height:300px;position:relative}
  .access-map iframe{position:relative}
  .access-info{padding:28px 24px}
  .access-studio-head{padding:24px 28px}
}

/* ===== 施工事例ページ ===== */
.works-page{padding:140px 0 100px;background:#fff;min-height:60vh;position:relative;overflow:hidden}
.works-page .container{max-width:1100px;position:relative}
.works-page section{padding:0}
.works-intro{text-align:center;margin-bottom:70px;position:relative}
.works-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:24px;
}
.works-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(30px,4.5vw,46px);font-weight:500;
  letter-spacing:.12em;margin-bottom:30px;color:var(--c-fg);
}
.works-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;color:var(--c-fg);
  letter-spacing:.04em;max-width:720px;margin:0 auto;
}
.work-case{margin-bottom:120px;position:relative}
.work-case:last-of-type{margin-bottom:80px}
.work-case-hero{
  position:relative;border-radius:var(--radius-md);overflow:hidden;
  margin-bottom:50px;aspect-ratio:16/8;box-shadow:0 20px 50px -25px rgba(40,50,40,.3);
}
.work-case-main{width:100%;height:100%;object-fit:cover;display:block}
.work-case-tags{
  position:absolute;left:24px;top:24px;display:flex;gap:8px;flex-wrap:wrap;
}
.work-case-tags span{
  padding:6px 16px;background:rgba(255,255,255,.92);border-radius:20px;
  font-family:var(--font-gothic);font-size:12px;letter-spacing:.12em;color:var(--c-fg);
  backdrop-filter:blur(8px);font-weight:500;
}
.work-case-head{text-align:center;margin-bottom:60px}
.case-number{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:16px;
}
.work-case-head h2{
  font-family:var(--font-mincho);font-size:clamp(24px,3vw,32px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);margin-bottom:10px;line-height:1.5;
}
.case-sub{
  font-family:var(--font-gothic);font-size:14px;letter-spacing:.1em;color:var(--c-muted);
}
.work-case-section{margin-bottom:50px}
.work-case-section:last-child{margin-bottom:0}
.work-case-section h3{
  font-family:var(--font-mincho);font-size:18px;font-weight:500;letter-spacing:.12em;
  color:var(--c-fg);margin-bottom:24px;padding-left:18px;
  border-left:3px solid var(--c-accent-3);line-height:1.5;
}
.data-table{
  display:grid;grid-template-columns:170px 1fr;gap:0;
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-md);
  overflow:hidden;
}
.data-table dt{
  padding:16px 26px;background:#faf6ef;color:var(--c-accent-2);
  font-family:var(--font-gothic);font-size:13px;font-weight:500;letter-spacing:.12em;
  border-bottom:1px solid var(--c-line);
}
.data-table dd{
  padding:16px 28px;color:var(--c-fg);
  font-family:var(--font-gothic);font-size:14px;line-height:1.85;letter-spacing:.04em;
  border-bottom:1px solid var(--c-line);margin:0;
}
.data-table dt:last-of-type,.data-table dd:last-of-type{border-bottom:none}
.points-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:14px}
.points-list li{
  font-family:var(--font-gothic);font-size:14.5px;line-height:1.85;letter-spacing:.04em;
  color:var(--c-fg);padding:18px 22px 18px 52px;background:#faf6ef;
  border-radius:var(--radius-sm);position:relative;
}
.points-list li::before{
  content:"";position:absolute;left:20px;top:22px;
  width:20px;height:20px;border-radius:50%;background:var(--c-accent-3);
  background-image:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
  background-size:12px;background-position:center;background-repeat:no-repeat;
}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gallery-item{
  display:block;aspect-ratio:1/1;overflow:hidden;border-radius:var(--radius-sm);
  position:relative;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease-soft);
}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item:hover{opacity:1}
.partners-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.partner-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-sm);
  padding:18px 22px;display:flex;flex-direction:column;gap:6px;
  transition:border-color .4s,transform .4s;
}
.partner-card:hover{border-color:var(--c-accent-3);transform:translateY(-2px)}
.partner-label{
  font-family:var(--font-en);font-size:11px;letter-spacing:.2em;font-style:italic;
  color:var(--c-accent-3);
}
.partner-name{
  font-family:var(--font-gothic);font-size:15px;letter-spacing:.04em;font-weight:500;
  color:var(--c-fg);
}
.works-cta{
  margin-top:80px;padding:60px 50px;background:#faf6ef;
  border-radius:var(--radius-md);text-align:center;position:relative;
}
.works-cta h2{
  font-family:var(--font-mincho);font-size:clamp(20px,2.5vw,26px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);margin-bottom:14px;line-height:1.6;
}
.works-cta p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:1.95;color:var(--c-fg);
  margin-bottom:28px;letter-spacing:.04em;
}
.works-cta-buttons{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.works-cta-buttons a{
  display:inline-block;padding:14px 36px;font-family:var(--font-gothic);
  font-size:14px;letter-spacing:.15em;text-decoration:none;border-radius:30px;
  transition:all .4s;
}
.works-cta-buttons .btn-pri{background:var(--c-accent);color:#fff}
.works-cta-buttons .btn-pri:hover{background:var(--c-accent-2);opacity:1}
.works-cta-buttons .btn-sec{background:#fff;color:var(--c-fg);border:1px solid var(--c-accent-3)}
.works-cta-buttons .btn-sec:hover{background:var(--c-accent-3);color:#fff;opacity:1}
@media (max-width:880px){
  .work-case-hero{aspect-ratio:16/10}
  .work-case-tags{left:14px;top:14px}
  .data-table{grid-template-columns:1fr}
  .data-table dt,.data-table dd{padding:12px 18px}
  .data-table dt{border-bottom:none;padding-bottom:0}
  .points-list{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .partners-grid{grid-template-columns:1fr 1fr;gap:10px}
  .works-cta{padding:40px 22px}
}

/* ===== 送信完了ページ ===== */
.thanks-page{padding:160px 0 120px;background:#fff;min-height:80vh;position:relative;overflow:hidden}
.thanks-page .container{max-width:680px;text-align:center;position:relative}
.thanks-icon{
  width:84px;height:84px;border-radius:50%;background:var(--c-accent);
  display:inline-flex;align-items:center;justify-content:center;color:#fff;
  margin:0 auto 30px;
}
.thanks-icon iconify-icon{font-size:42px;color:#fff}
.thanks-title{
  font-family:var(--font-mincho);font-size:clamp(26px,3.5vw,38px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);margin-bottom:24px;line-height:1.5;
}
.thanks-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;color:var(--c-fg);
  letter-spacing:.04em;margin-bottom:50px;
}
.thanks-notice{
  background:#fcf6e7;border-radius:var(--radius-md);padding:32px 36px;
  text-align:left;margin-bottom:40px;border-left:4px solid #c9a96e;
}
.thanks-notice h2{
  font-family:var(--font-mincho);font-size:16px;font-weight:500;letter-spacing:.12em;
  color:var(--c-accent-2);margin-bottom:16px;line-height:1.5;
}
.thanks-notice ul{list-style:none;margin:0;padding:0}
.thanks-notice li{
  font-family:var(--font-gothic);font-size:13.5px;line-height:1.95;letter-spacing:.04em;
  color:var(--c-fg);padding-left:22px;position:relative;margin-bottom:10px;
}
.thanks-notice li::before{
  content:"";position:absolute;left:6px;top:.75em;
  width:6px;height:6px;border-radius:50%;background:#c9a96e;
}
.thanks-contact{
  margin-bottom:50px;padding:36px 30px;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-md);
}
.thanks-contact-label{
  display:block;font-family:var(--font-en);font-size:11px;letter-spacing:.25em;
  color:var(--c-accent-3);font-style:italic;margin-bottom:10px;
}
.thanks-contact-tel{
  display:inline-block;font-family:var(--font-en);font-size:30px;font-weight:500;
  color:var(--c-accent-2);letter-spacing:.05em;text-decoration:none;margin-bottom:8px;
}
.thanks-contact-tel:hover{opacity:.85}
.thanks-contact-hours{
  display:block;font-family:var(--font-gothic);font-size:13px;color:var(--c-muted);
  letter-spacing:.05em;margin-top:6px;
}
.thanks-home-btn{
  display:inline-block;padding:16px 50px;background:var(--c-accent);color:#fff;
  border-radius:30px;text-decoration:none;font-family:var(--font-gothic);font-size:14px;
  letter-spacing:.18em;transition:all .4s;
}
.thanks-home-btn:hover{background:var(--c-accent-2);opacity:1;transform:translateY(-2px)}
@media (max-width:640px){
  .thanks-notice{padding:24px 22px}
  .thanks-contact{padding:28px 22px}
  .thanks-contact-tel{font-size:26px}
}

/* ===== 404 Not Found ページ ===== */
.notfound-page{padding:160px 0 120px;background:#fff;min-height:80vh;position:relative;overflow:hidden}
.notfound-page .container{max-width:880px;text-align:center;position:relative}
.notfound-num{
  font-family:var(--font-en);font-size:clamp(120px,18vw,200px);font-weight:300;
  color:var(--c-accent-3);line-height:1;letter-spacing:.04em;
  margin-bottom:24px;opacity:.85;position:relative;
}
.notfound-num::after{
  content:"";display:block;width:60px;height:1px;background:var(--c-accent-3);
  margin:18px auto 0;
}
.notfound-title{
  font-family:var(--font-mincho);font-size:clamp(24px,3.2vw,34px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin-bottom:24px;line-height:1.5;
}
.notfound-lead{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.1;color:var(--c-fg);
  letter-spacing:.05em;margin-bottom:60px;
}
.notfound-links{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-bottom:60px;
}
.notfound-link-card{
  display:flex;flex-direction:column;align-items:flex-start;
  padding:24px 26px;background:#fff;border:1px solid var(--c-line);
  border-radius:var(--radius-md);text-decoration:none;
  transition:all .4s var(--ease-soft);position:relative;
}
.notfound-link-card:hover{
  border-color:var(--c-accent);transform:translateY(-3px);
  box-shadow:0 16px 30px -20px rgba(40,50,40,.18);
}
.notfound-link-en{
  font-family:var(--font-en);font-size:11px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;margin-bottom:6px;
}
.notfound-link-jp{
  font-family:var(--font-mincho);font-size:16px;font-weight:500;
  letter-spacing:.1em;color:var(--c-fg);
}
.notfound-link-arrow{
  position:absolute;right:22px;top:50%;transform:translateY(-50%);
  font-family:var(--font-en);font-size:18px;color:var(--c-accent-3);
  transition:transform .4s var(--ease-soft);
}
.notfound-link-card:hover .notfound-link-arrow{transform:translateY(-50%) translateX(4px)}
.notfound-contact{
  margin-bottom:50px;padding:32px 30px;background:#faf6ef;
  border-radius:var(--radius-md);
}
.notfound-contact-label{
  display:block;font-family:var(--font-gothic);font-size:12px;letter-spacing:.2em;
  color:var(--c-muted);margin-bottom:12px;
}
.notfound-contact-tel{
  display:inline-block;font-family:var(--font-en);font-size:30px;font-weight:500;
  color:var(--c-accent-2);letter-spacing:.05em;text-decoration:none;
}
.notfound-contact-tel:hover{opacity:.85}
.notfound-contact-hours{
  display:block;font-family:var(--font-gothic);font-size:13px;color:var(--c-muted);
  letter-spacing:.05em;margin-top:8px;
}
.notfound-home-btn{
  display:inline-block;padding:16px 50px;background:var(--c-accent);color:#fff;
  border-radius:30px;text-decoration:none;font-family:var(--font-gothic);font-size:14px;
  letter-spacing:.18em;transition:all .4s;
}
.notfound-home-btn:hover{background:var(--c-accent-2);transform:translateY(-2px)}
@media (max-width:768px){
  .notfound-page{padding:120px 0 80px}
  .notfound-links{grid-template-columns:repeat(2,1fr);gap:12px}
  .notfound-link-card{padding:18px 20px}
  .notfound-link-arrow{right:16px;font-size:15px}
  .notfound-contact-tel{font-size:24px}
}
@media (max-width:480px){
  .notfound-links{grid-template-columns:1fr}
}

/* ===== 予約フォームページ ===== */
.booking-page{padding:140px 0 100px;background:#fff;min-height:60vh;position:relative;overflow:hidden}
.booking-page .container{max-width:1080px;position:relative}
.booking-intro{text-align:center;margin-bottom:60px;position:relative}
.booking-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:22px;
}
.booking-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(28px,4vw,42px);font-weight:500;
  letter-spacing:.12em;margin-bottom:24px;color:var(--c-fg);line-height:1.5;
}
.booking-subtitle{
  font-family:var(--font-mincho);font-size:clamp(15px,1.8vw,18px);
  color:var(--c-accent-2);letter-spacing:.12em;line-height:1.8;
}
.event-card{
  background:#faf6ef;border-radius:var(--radius-md);
  padding:50px 40px;margin-bottom:80px;text-align:center;position:relative;
}
.event-date-badge{
  display:inline-block;padding:8px 26px;background:var(--c-accent);color:#fff;
  border-radius:30px;font-family:var(--font-en);font-size:13px;letter-spacing:.2em;
  margin-bottom:24px;font-style:italic;
}
.event-title{
  font-family:var(--font-mincho);font-size:clamp(22px,3vw,30px);font-weight:500;
  letter-spacing:.14em;margin-bottom:20px;color:var(--c-fg);line-height:1.5;
}
.event-description{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2;color:var(--c-fg);
  letter-spacing:.04em;margin-bottom:36px;
}
.event-meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.event-meta-item{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:26px 18px;background:#fff;border-radius:var(--radius-sm);
}
.event-meta-icon{
  width:48px;height:48px;border-radius:50%;background:var(--c-accent-3);
  color:#fff;display:inline-flex;align-items:center;justify-content:center;
}
.event-meta-icon iconify-icon{font-size:22px;color:#fff}
.event-meta-label{
  font-family:var(--font-en);font-size:10px;letter-spacing:.25em;
  color:var(--c-accent-3);font-style:italic;
}
.event-meta-value{
  font-family:var(--font-gothic);font-size:13px;letter-spacing:.04em;
  color:var(--c-muted);text-align:center;line-height:1.7;
}
.event-meta-value strong{
  display:block;font-family:var(--font-mincho);font-size:17px;
  color:var(--c-accent-2);margin-bottom:4px;font-weight:500;letter-spacing:.06em;
}
.booking-flow{margin-bottom:80px}
.booking-flow-head{text-align:center;margin-bottom:50px}
.booking-flow-head .section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:14px;
}
.booking-flow-head h2{
  font-family:var(--font-mincho);font-size:clamp(22px,2.8vw,28px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);
}
.booking-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.booking-step{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-md);
  padding:34px 28px 30px;text-align:center;position:relative;
}
.booking-step-num{
  width:42px;height:42px;border-radius:50%;
  background:var(--c-accent);color:#fff;font-family:var(--font-en);
  display:inline-flex;align-items:center;justify-content:center;font-size:18px;
  margin-bottom:16px;letter-spacing:.05em;
}
.booking-step h3{
  font-family:var(--font-mincho);font-size:17px;font-weight:500;letter-spacing:.1em;
  margin-bottom:12px;color:var(--c-fg);
}
.booking-step p{
  font-family:var(--font-gothic);font-size:13px;line-height:1.9;color:var(--c-muted);
  letter-spacing:.04em;
}
.booking-form-section{
  background:#faf6ef;border-radius:var(--radius-md);
  padding:50px 36px;margin-bottom:50px;
}
.booking-form-section-head{text-align:center;margin-bottom:36px}
.booking-form-section-head .section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;
  color:var(--c-accent-3);font-style:italic;display:block;margin-bottom:14px;
}
.booking-form-section-head h2{
  font-family:var(--font-mincho);font-size:clamp(20px,2.5vw,26px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);
}
.booking-form-section #booking-package,
.booking-form-section .booking-package{background:#fff;border-radius:var(--radius-sm);padding:24px}
.booking-notice{
  background:#fcf6e7;border-radius:var(--radius-md);
  border-left:4px solid #c9a96e;padding:24px 30px;
}
.booking-notice p{
  font-family:var(--font-gothic);font-size:13.5px;line-height:1.95;letter-spacing:.04em;
  color:var(--c-fg);margin:0;
}
.booking-notice strong{color:var(--c-accent-2);font-weight:500}
@media (max-width:880px){
  .event-card{padding:36px 22px}
  .event-meta{grid-template-columns:1fr;gap:12px}
  .booking-steps{grid-template-columns:1fr;gap:14px}
  .booking-form-section{padding:32px 18px}
}

/* ===== 想いページ ===== */
.vision-page{background:#fff;position:relative;overflow:hidden}

/* Hero */
.vision-hero{
  position:relative;height:100vh;min-height:640px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.vision-hero-bg{position:absolute;inset:0;z-index:1}
.vision-hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.vision-hero::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(20,18,15,.55) 0%,rgba(20,18,15,.35) 50%,rgba(20,18,15,.6) 100%);
}
.vision-hero-content{position:relative;z-index:3;text-align:center;color:#fff;max-width:920px;padding:0 24px}
.vision-hero-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.45em;font-style:italic;
  opacity:.9;display:block;margin-bottom:36px;
}
.vision-hero-title{
  font-family:var(--font-mincho);font-size:clamp(36px,6vw,72px);font-weight:500;
  letter-spacing:.18em;margin-bottom:40px;line-height:1.4;
}
.vision-hero-sub{
  font-family:var(--font-mincho);font-size:clamp(20px,2.5vw,30px);
  letter-spacing:.22em;opacity:.95;line-height:1.6;margin-bottom:50px;
}
.vision-hero-lead{
  font-family:var(--font-gothic);font-size:14px;line-height:2.2;letter-spacing:.1em;
  opacity:.88;max-width:640px;margin:0 auto;
}
.vision-hero-scroll{
  position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:var(--font-en);font-size:11px;letter-spacing:.35em;color:#fff;opacity:.7;
}
.vision-hero-scroll::after{
  content:"";display:block;width:1px;height:36px;background:#fff;margin:14px auto 0;
  animation:scrollLine 2.4s var(--ease) infinite;
}

/* Why */
.vision-why{padding:140px 24px;text-align:center;background:#fff;position:relative;overflow:hidden}
.vision-why-inner{max-width:780px;margin:0 auto;position:relative;z-index:2}
.vision-section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.4em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:24px;
}
.vision-why h2{
  font-family:var(--font-mincho);font-size:clamp(28px,4vw,42px);font-weight:500;
  letter-spacing:.16em;margin-bottom:56px;color:var(--c-fg);line-height:1.6;
}
.vision-why-text p{
  font-family:var(--font-mincho);font-size:clamp(15px,1.55vw,17px);
  line-height:2.5;letter-spacing:.14em;color:var(--c-fg);margin-bottom:36px;
}
.vision-why-text p:last-child{margin-bottom:0}
.vision-why-text .lead{
  font-size:clamp(18px,2vw,22px);color:var(--c-accent-2);letter-spacing:.18em;line-height:2;
}

/* Principles */
.vision-principles{background:#fff}
.vision-principle{
  display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch;
  background:#fff;
}
.vision-principle.even{background:#faf6ef}
.vision-principle.alt > .vision-principle-img{order:2}
.vision-principle-img{position:relative;min-height:560px;overflow:hidden}
.vision-principle-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  position:absolute;inset:0;transition:transform 1.4s var(--ease-soft);
}
.vision-principle:hover .vision-principle-img img{transform:scale(1.05)}
.vision-principle-content{
  padding:90px 76px;display:flex;flex-direction:column;justify-content:center;
}
.vision-principle-num{
  font-family:var(--font-en);font-size:12px;letter-spacing:.4em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:12px;
}
.vision-principle-en{
  font-family:var(--font-en);font-size:26px;letter-spacing:.22em;font-style:italic;
  color:var(--c-accent-2);display:block;margin-bottom:26px;line-height:1.2;
}
.vision-principle h3{
  font-family:var(--font-mincho);font-size:clamp(28px,3.6vw,40px);font-weight:500;
  letter-spacing:.14em;margin-bottom:36px;color:var(--c-fg);line-height:1.5;
}
.vision-principle p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.25;letter-spacing:.08em;
  color:var(--c-fg);margin-bottom:22px;
}
.vision-principle p:last-child{margin-bottom:0}
.vision-principle .point-tag{
  display:inline-block;font-family:var(--font-en);font-size:11px;letter-spacing:.25em;
  color:var(--c-accent-3);font-style:italic;border-bottom:1px solid var(--c-accent-3);
  padding-bottom:2px;margin-bottom:6px;
}

/* Process */
.vision-process{padding:140px 24px;background:#fff;position:relative;overflow:hidden}
.vision-process-inner{max-width:1080px;margin:0 auto;position:relative;z-index:2}
.vision-process-head{text-align:center;margin-bottom:80px}
.vision-process-head h2{
  font-family:var(--font-mincho);font-size:clamp(28px,3.5vw,38px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);
}
.vision-process-list{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.vision-process-step{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-md);
  padding:36px 28px 32px;position:relative;
}
.vision-process-num{
  font-family:var(--font-en);font-size:48px;letter-spacing:.04em;font-style:italic;
  color:var(--c-accent-3);line-height:1;margin-bottom:18px;display:block;opacity:.7;
}
.vision-process-step h3{
  font-family:var(--font-mincho);font-size:18px;font-weight:500;letter-spacing:.12em;
  color:var(--c-fg);margin-bottom:14px;line-height:1.5;
}
.vision-process-step p{
  font-family:var(--font-gothic);font-size:13.5px;line-height:1.95;color:var(--c-muted);
  letter-spacing:.05em;
}

/* Name */
.vision-name{
  padding:180px 24px;text-align:center;background:#1f2520;color:#fff;
  position:relative;overflow:hidden;
}
.vision-name-bg{position:absolute;inset:0;opacity:.32}
.vision-name-bg img{width:100%;height:100%;object-fit:cover}
.vision-name::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,18,15,.85),rgba(20,18,15,.92));
}
.vision-name-inner{position:relative;z-index:3;max-width:780px;margin:0 auto}
.vision-name-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.45em;font-style:italic;
  opacity:.7;display:block;margin-bottom:30px;
}
.vision-name-big{
  font-family:var(--font-mincho);font-size:clamp(70px,12vw,140px);font-weight:500;
  letter-spacing:.2em;margin-bottom:24px;line-height:1;text-indent:.2em;
}
.vision-name-yomi{
  font-family:var(--font-en);font-size:15px;letter-spacing:.35em;font-style:italic;
  opacity:.7;display:block;margin-bottom:60px;
}
.vision-name p{
  font-family:var(--font-mincho);font-size:clamp(15px,1.6vw,17px);
  line-height:2.5;letter-spacing:.12em;margin-bottom:32px;opacity:.95;
}
.vision-name p:last-child{margin-bottom:0}
.vision-name .vision-name-quote{
  font-size:clamp(17px,1.9vw,20px);letter-spacing:.18em;color:var(--c-accent-3);
  line-height:2.2;font-weight:500;
}

/* Promises */
.vision-promises{padding:140px 24px;background:#faf6ef;position:relative;overflow:hidden}
.vision-promises-inner{max-width:980px;margin:0 auto;position:relative;z-index:2}
.vision-promises-head{text-align:center;margin-bottom:80px}
.vision-promises-head h2{
  font-family:var(--font-mincho);font-size:clamp(28px,3.5vw,38px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);
}
.vision-promise{
  display:grid;grid-template-columns:130px 1fr;gap:50px;align-items:start;
  padding:42px 0;border-bottom:1px solid rgba(184,155,106,.32);
}
.vision-promise:last-child{border-bottom:none}
.vision-promise-num{
  font-family:var(--font-en);font-size:54px;letter-spacing:.04em;font-style:italic;
  color:var(--c-accent-3);line-height:1;
}
.vision-promise-body h3{
  font-family:var(--font-mincho);font-size:22px;font-weight:500;letter-spacing:.14em;
  color:var(--c-fg);margin-bottom:14px;line-height:1.5;
}
.vision-promise-body p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.05;letter-spacing:.06em;
  color:var(--c-fg);
}

/* Closing CTA */
.vision-cta{
  padding:140px 24px;background:#fff;text-align:center;position:relative;overflow:hidden;
}
.vision-cta-inner{max-width:780px;margin:0 auto;position:relative;z-index:2}
.vision-cta h2{
  font-family:var(--font-mincho);font-size:clamp(26px,3.6vw,40px);font-weight:500;
  letter-spacing:.16em;color:var(--c-fg);margin-bottom:34px;line-height:1.5;
}
.vision-cta p{
  font-family:var(--font-gothic);font-size:15px;line-height:2.2;color:var(--c-fg);
  letter-spacing:.08em;margin-bottom:44px;
}
.vision-cta-buttons{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}
.vision-cta-buttons a{
  display:inline-block;padding:18px 50px;font-family:var(--font-gothic);
  font-size:14px;letter-spacing:.18em;text-decoration:none;border-radius:30px;
  transition:all .4s;
}
.vision-cta-buttons .btn-pri{background:var(--c-accent);color:#fff}
.vision-cta-buttons .btn-pri:hover{background:var(--c-accent-2);opacity:1;transform:translateY(-2px)}
.vision-cta-buttons .btn-sec{background:#fff;color:var(--c-fg);border:1px solid var(--c-accent-3)}
.vision-cta-buttons .btn-sec:hover{background:var(--c-accent-3);color:#fff;opacity:1}

@media (max-width:880px){
  .vision-hero{height:90vh;min-height:560px}
  .vision-why,.vision-name,.vision-promises,.vision-cta,.vision-process{padding:90px 24px}
  .vision-name{padding:120px 24px}
  .vision-principle{grid-template-columns:1fr}
  .vision-principle.alt > .vision-principle-img{order:0}
  .vision-principle-img{min-height:340px}
  .vision-principle-content{padding:60px 30px}
  .vision-promise{grid-template-columns:80px 1fr;gap:24px;padding:30px 0}
  .vision-promise-num{font-size:38px}
  .vision-process-list{grid-template-columns:1fr;gap:16px}
}

/* ===== 6つのことページ ===== */
.promises-page{background:#fff;padding:140px 0 100px;position:relative;overflow:hidden}
.promises-page .container{max-width:1080px;position:relative}
.promises-intro{text-align:center;margin-bottom:90px;position:relative}
.promises-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:24px;
}
.promises-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(28px,4.2vw,44px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);line-height:1.5;margin-bottom:30px;
}
.promises-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.2;color:var(--c-fg);
  letter-spacing:.06em;max-width:720px;margin:0 auto;
}
.promise-list{position:relative}
.promise-item{
  display:block;padding:70px 0;border-bottom:1px solid var(--c-line);
  scroll-margin-top:110px;
}
.promise-item:last-child{border-bottom:none;padding-bottom:30px}
.promise-banner{
  width:100%;aspect-ratio:16/6.5;overflow:hidden;
  border-radius:var(--radius-md);margin-bottom:48px;position:relative;
  box-shadow:0 20px 50px -22px rgba(40,50,40,.28);
}
.promise-banner img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.4s var(--ease-soft);
}
.promise-item:hover .promise-banner img{transform:scale(1.04)}
.promise-body{
  display:grid;grid-template-columns:220px 1fr;gap:60px;align-items:start;
}
.promise-num-block{
  display:flex;flex-direction:column;align-items:flex-start;gap:18px;
  padding-top:8px;
}
.promise-num{
  font-family:var(--font-en);font-size:96px;letter-spacing:.02em;line-height:1;
  color:var(--c-accent-3);opacity:.85;font-weight:500;
}
.promise-icon{
  width:56px;height:56px;border-radius:50%;
  background:#faf6ef;color:var(--c-accent-2);
  display:flex;align-items:center;justify-content:center;
}
.promise-icon iconify-icon{font-size:26px}
.promise-content{padding-top:14px}
.promise-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:10px;
  border-bottom:1px solid var(--c-accent-3);padding-bottom:3px;width:max-content;
}
.promise-content h3{
  font-family:var(--font-mincho);font-size:clamp(26px,3.2vw,34px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin:14px 0 24px;line-height:1.5;
}
.promise-lead-line{
  font-family:var(--font-mincho);font-size:clamp(15px,1.55vw,18px);
  color:var(--c-accent-2);letter-spacing:.12em;line-height:2;margin-bottom:28px;
}
.promise-content p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.15;letter-spacing:.06em;
  color:var(--c-fg);margin-bottom:18px;
}
.promise-content p:last-child{margin-bottom:0}
.promise-tags{
  display:flex;gap:8px;flex-wrap:wrap;margin-top:28px;
}
.promise-tag{
  padding:6px 14px;background:#faf6ef;border-radius:20px;
  font-family:var(--font-gothic);font-size:12px;letter-spacing:.06em;
  color:var(--c-accent-2);
}
.promises-cta{
  margin-top:90px;padding:60px 50px;background:#faf6ef;
  border-radius:var(--radius-md);text-align:center;position:relative;
}
.promises-cta h2{
  font-family:var(--font-mincho);font-size:clamp(22px,2.8vw,30px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin-bottom:18px;line-height:1.6;
}
.promises-cta p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2;color:var(--c-fg);
  margin-bottom:28px;letter-spacing:.05em;
}
.promises-cta-buttons{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.promises-cta-buttons a{
  display:inline-block;padding:14px 38px;font-family:var(--font-gothic);
  font-size:14px;letter-spacing:.15em;text-decoration:none;border-radius:30px;
  transition:all .4s;
}
.promises-cta-buttons .btn-pri{background:var(--c-accent);color:#fff}
.promises-cta-buttons .btn-pri:hover{background:var(--c-accent-2);opacity:1}
.promises-cta-buttons .btn-sec{background:#fff;color:var(--c-fg);border:1px solid var(--c-accent-3)}
.promises-cta-buttons .btn-sec:hover{background:var(--c-accent-3);color:#fff;opacity:1}
@media (max-width:880px){
  .promise-banner{aspect-ratio:16/9;margin-bottom:30px}
  .promise-body{grid-template-columns:1fr;gap:18px}
  .promise-num-block{flex-direction:row;align-items:center;gap:20px}
  .promise-num{font-size:64px}
  .promise-content{padding-top:0}
  .promise-item{padding:50px 0}
  .promises-cta{padding:40px 24px}
}

/* ===== サービスハブページ ===== */
.service-hub-page{background:#fff;padding:140px 0 100px;position:relative;overflow:hidden}
.service-hub-page .container{max-width:1100px;position:relative}
.service-hub-intro{text-align:center;margin-bottom:80px}
.service-hub-intro .section-en{
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:24px;
}
.service-hub-intro .section-title{
  font-family:var(--font-mincho);font-size:clamp(28px,4vw,42px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);margin-bottom:30px;line-height:1.5;
}
.service-hub-lead{
  font-family:var(--font-gothic);font-size:15px;line-height:2.15;color:var(--c-fg);
  letter-spacing:.06em;max-width:720px;margin:0 auto;
}
.service-card-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:36px;margin-bottom:80px;
}
.service-hub-card{
  display:block;background:#fff;border-radius:var(--radius-md);overflow:hidden;
  border:1px solid var(--c-line);text-decoration:none;color:inherit;
  transition:transform .5s var(--ease-soft),box-shadow .5s var(--ease-soft);
}
.service-hub-card:hover{
  transform:translateY(-5px);box-shadow:0 24px 50px -22px rgba(40,50,40,.25);opacity:1;
}
.service-hub-card-img{aspect-ratio:16/10;overflow:hidden;position:relative}
.service-hub-card-img img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s var(--ease-soft);
}
.service-hub-card:hover .service-hub-card-img img{transform:scale(1.06)}
.service-hub-card-num{
  position:absolute;top:20px;left:24px;
  font-family:var(--font-en);font-size:14px;letter-spacing:.3em;color:#fff;
  background:rgba(0,0,0,.4);padding:5px 14px;border-radius:20px;
  backdrop-filter:blur(6px);font-style:italic;
}
.service-hub-card-body{padding:32px 36px 38px}
.service-hub-card-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:10px;
}
.service-hub-card h3{
  font-family:var(--font-mincho);font-size:24px;font-weight:500;letter-spacing:.12em;
  color:var(--c-fg);margin-bottom:18px;line-height:1.5;
}
.service-hub-card p{
  font-family:var(--font-gothic);font-size:14px;line-height:1.95;color:var(--c-muted);
  letter-spacing:.04em;margin-bottom:22px;
}
.service-hub-card-arrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-en);font-size:12px;letter-spacing:.2em;
  color:var(--c-accent-2);font-style:italic;
}
.service-hub-card-arrow::after{
  content:"→";transition:transform .4s;
}
.service-hub-card:hover .service-hub-card-arrow::after{transform:translateX(6px)}

/* ===== サービス詳細ページ（共通スタイル） ===== */
.service-detail-page{background:#fff;position:relative;overflow:hidden}
.service-detail-hero{
  position:relative;height:60vh;min-height:420px;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.service-detail-hero-bg{position:absolute;inset:0;z-index:1}
.service-detail-hero-bg img{width:100%;height:100%;object-fit:cover;display:block}
.service-detail-hero::after{
  content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(20,18,15,.5) 0%,rgba(20,18,15,.55) 100%);
}
.service-detail-hero-content{
  position:relative;z-index:3;text-align:center;color:#fff;
  max-width:780px;padding:0 24px;
}
.service-detail-hero-num{
  font-family:var(--font-en);font-size:13px;letter-spacing:.4em;font-style:italic;
  opacity:.85;display:block;margin-bottom:24px;
}
.service-detail-hero-en{
  font-family:var(--font-en);font-size:clamp(20px,2.5vw,28px);letter-spacing:.25em;
  font-style:italic;opacity:.92;display:block;margin-bottom:16px;
}
.service-detail-hero h1{
  font-family:var(--font-mincho);font-size:clamp(30px,4.5vw,48px);font-weight:500;
  letter-spacing:.18em;margin-bottom:24px;line-height:1.5;
}
.service-detail-hero-lead{
  font-family:var(--font-mincho);font-size:clamp(15px,1.8vw,18px);
  letter-spacing:.14em;line-height:2;opacity:.95;
}
.service-detail-section{padding:110px 24px;position:relative}
.service-detail-section.bg-cream{background:#faf6ef}
.service-detail-section-inner{max-width:1080px;margin:0 auto;position:relative}
.service-detail-section-head{text-align:center;margin-bottom:60px}
.service-detail-section-head .section-en{
  font-family:var(--font-en);font-size:13px;letter-spacing:.3em;font-style:italic;
  color:var(--c-accent-3);display:block;margin-bottom:14px;
}
.service-detail-section-head h2{
  font-family:var(--font-mincho);font-size:clamp(26px,3.4vw,36px);font-weight:500;
  letter-spacing:.14em;color:var(--c-fg);line-height:1.5;
}
.service-offer{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.service-offer-item{
  background:#fff;padding:34px 32px 32px;border-radius:var(--radius-md);
  border:1px solid var(--c-line);transition:transform .5s,box-shadow .5s,border-color .5s;
}
.service-offer-item:hover{
  transform:translateY(-3px);box-shadow:0 16px 36px -16px rgba(40,50,40,.18);
  border-color:var(--c-accent-3);
}
.service-offer-item .icon{
  width:50px;height:50px;border-radius:50%;background:#faf6ef;color:var(--c-accent-2);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.service-offer-item .icon iconify-icon{font-size:24px}
.service-offer-item h3{
  font-family:var(--font-mincho);font-size:17px;font-weight:500;letter-spacing:.1em;
  color:var(--c-fg);margin-bottom:12px;line-height:1.5;
}
.service-offer-item p{
  font-family:var(--font-gothic);font-size:13.5px;line-height:1.95;color:var(--c-muted);
  letter-spacing:.04em;
}
.service-approach{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.service-approach-img{
  aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-md);
  box-shadow:0 20px 50px -25px rgba(40,50,40,.3);
}
.service-approach-img img{width:100%;height:100%;object-fit:cover;display:block}
.service-approach-text p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:2.15;letter-spacing:.06em;
  color:var(--c-fg);margin-bottom:22px;
}
.service-approach-text p:last-child{margin-bottom:0}
.service-detail-cta{
  margin:0 auto;max-width:980px;padding:60px 50px;background:#faf6ef;
  border-radius:var(--radius-md);text-align:center;
}
.service-detail-cta h2{
  font-family:var(--font-mincho);font-size:clamp(22px,2.8vw,28px);font-weight:500;
  letter-spacing:.12em;color:var(--c-fg);margin-bottom:18px;line-height:1.6;
}
.service-detail-cta p{
  font-family:var(--font-gothic);font-size:14.5px;line-height:1.95;color:var(--c-fg);
  margin-bottom:30px;letter-spacing:.05em;
}
.service-detail-cta-buttons{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
.service-detail-cta-buttons a{
  display:inline-block;padding:14px 36px;font-family:var(--font-gothic);
  font-size:14px;letter-spacing:.15em;text-decoration:none;border-radius:30px;
  transition:all .4s;
}
.service-detail-cta-buttons .btn-pri{background:var(--c-accent);color:#fff}
.service-detail-cta-buttons .btn-pri:hover{background:var(--c-accent-2);opacity:1}
.service-detail-cta-buttons .btn-sec{background:#fff;color:var(--c-fg);border:1px solid var(--c-accent-3)}
.service-detail-cta-buttons .btn-sec:hover{background:var(--c-accent-3);color:#fff;opacity:1}
@media (max-width:880px){
  .service-card-grid{grid-template-columns:1fr;gap:24px;margin-bottom:50px}
  .service-detail-hero{height:50vh;min-height:340px}
  .service-detail-section{padding:70px 24px}
  .service-offer{grid-template-columns:1fr;gap:16px}
  .service-approach{grid-template-columns:1fr;gap:36px}
  .service-detail-cta{padding:40px 22px}
}
