/* =====================================================================
   AMOÉ TOKYO — pages.css  (ページ固有スタイル)
   各ページ専用のスタイルのみ。共通部分は style.css / components.css。
   ※ 同名の共通セレクタ(.page-hero/.page-cta/nav 等)は components.css に統一済み。
   ===================================================================== */


/* ===================== PAGE: index ===================== */
.page-index .hero{min-height:100vh;position:relative;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding-top:96px;}
.page-index .hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#e8ddd0 0%,#f1e6dd 40%,#e3d3cb 100%);}
.page-index .hero-bg::before{content:'PHOTO / VIDEO';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--sans);font-size:13px;letter-spacing:.5em;color:rgba(43,39,35,0.22);}
.page-index .hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;}
.page-index .hero-bg::before{z-index:0;}
.page-index .scroll-hint{position:relative;z-index:2;}
.page-index .hero-inner{position:relative;z-index:2;padding:0 24px;max-width:900px;}
.page-index .hero .kicker{font-size:12px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:30px;opacity:0;animation:fadeUp 1.1s .2s forwards;}
.page-index .hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(38px,6vw,82px);line-height:1.12;font-style:italic;letter-spacing:.01em;opacity:0;animation:fadeUp 1.1s .45s forwards;}
.page-index .hero .sub{font-family:var(--mincho);font-size:clamp(14px,1.6vw,18px);color:var(--ink-soft);margin-top:28px;letter-spacing:.14em;opacity:0;animation:fadeUp 1.1s .75s forwards;}
.page-index .hero .hero-cta{margin-top:42px;opacity:0;animation:fadeUp 1.1s 1s forwards;display:flex;flex-direction:column;align-items:center;gap:20px;}
.page-index .hero .hero-shop{display:inline-block;background:var(--ink);color:var(--ivory);padding:16px 46px;text-decoration:none;font-size:12px;letter-spacing:.25em;text-transform:uppercase;transition:background .4s;}
.page-index .hero .hero-shop:hover{background:var(--gold);}
.page-index .scroll-hint{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.4em;color:var(--ink-soft);text-transform:uppercase;opacity:0;animation:fadeIn 1.2s 1.4s forwards;}
.page-index .scroll-hint::after{content:'';display:block;width:1px;height:42px;background:var(--gold-soft);margin:14px auto 0;animation:lineGrow 2s 1.6s ease-in-out infinite;}
@keyframes fadeIn{to{opacity:1;}}
@keyframes lineGrow{0%,100%{transform:scaleY(.4);opacity:.4;}50%{transform:scaleY(1);opacity:1;}}
.page-index section{padding:120px 48px;position:relative;}
.page-index .lead{font-family:var(--mincho);font-size:16px;color:var(--ink-soft);line-height:2.1;margin-top:22px;}
.page-index .learn{display:inline-flex;align-items:center;gap:10px;margin-top:34px;font-family:var(--sans);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink);text-decoration:none;transition:gap .4s;}
.page-index .learn .ln{width:36px;height:1px;background:var(--gold);transition:width .4s;}
.page-index .learn:hover{gap:16px;}
.page-index .learn:hover .ln{width:52px;}
.page-index .intro{text-align:center;max-width:760px;margin:0 auto;}
.page-index .intro .lead{font-size:17px;}
.page-index .gallery-head{text-align:center;margin-bottom:56px;}
.page-index .gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;max-width:1300px;margin:0 auto;}
.page-index .g-item{aspect-ratio:3/4;background:var(--ivory-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;overflow:hidden;transition:transform .6s;position:relative;}
.page-index .g-item.has-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.page-index .g-item span{font-size:10px;letter-spacing:.3em;color:rgba(43,39,35,0.22);}
.page-index .g-item:nth-child(2){margin-top:36px;}
.page-index .g-item:nth-child(4){margin-top:36px;}
.page-index .g-item:hover{transform:translateY(-8px);}
.page-index .gallery-foot{text-align:center;margin-top:56px;}
.page-index .artists-intro{padding:120px 48px;}
.page-index .artists-intro .hosp-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1200px;margin:0 auto;}
.page-index .artists-intro .hosp-img{aspect-ratio:4/3;background:var(--ivory-deep);display:flex;align-items:center;justify-content:center;border:1px solid var(--line);position:relative;}
.page-index .artists-intro .hosp-img span{font-size:11px;letter-spacing:.4em;color:rgba(43,39,35,0.25);}
.page-index .artists-intro .hosp-img::after{content:'';position:absolute;inset:14px;border:1px solid var(--gold-soft);pointer-events:none;z-index:2;}
.page-index .artists-intro .hosp-img.has-image{background:none;overflow:hidden;}
.page-index .artists-intro .hosp-img.has-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 60%;}
.page-index .hosp{background:var(--ivory-deep);}
.page-index .hosp-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1200px;margin:0 auto;}
.page-index .hosp-img{aspect-ratio:4/3;background:var(--ivory);display:flex;align-items:center;justify-content:center;border:1px solid var(--line);position:relative;}
.page-index .hosp-img span{font-size:11px;letter-spacing:.4em;color:rgba(43,39,35,0.25);}
.page-index .hosp-img::after{content:'';position:absolute;inset:14px;border:1px solid var(--gold-soft);pointer-events:none;z-index:2;}
.page-index .hosp-img.has-image{background:none;overflow:hidden;}
.page-index .hosp-img.has-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.page-index .voices{text-align:center;}
.page-index .voices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1100px;margin:55px auto 0;}
.page-index .voice{background:var(--ivory);padding:40px 32px;border:1px solid var(--line);text-align:left;}
.page-index .voice .stars{color:var(--gold);letter-spacing:.2em;font-size:13px;}
.page-index .voice p{font-family:var(--mincho);font-size:14px;color:var(--ink-soft);margin:18px 0;line-height:2;}
.page-index .voice .who{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.page-index .voices-foot{text-align:center;margin-top:50px;}
.page-index .social-sec{text-align:center;}
.page-index .social-row{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;max-width:880px;margin:54px auto 0;}
.page-index .social-card{flex:1;min-width:200px;border:1px solid var(--line);background:var(--ivory);padding:40px 24px;transition:transform .5s,box-shadow .5s;text-decoration:none;color:inherit;display:block;}
.page-index .social-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(43,39,35,0.07);}
.page-index .social-card .s-pf{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);}
.page-index .social-card .s-num{font-family:var(--serif);font-style:italic;font-size:42px;color:var(--ink);line-height:1.1;margin-top:12px;}
.page-index .news{background:var(--ivory-deep);}
.page-index .news-head{text-align:center;margin-bottom:50px;}
.page-index .news-list{max-width:860px;margin:0 auto;}
.page-index .news-item{display:grid;grid-template-columns:140px 1fr auto;gap:30px;align-items:center;padding:26px 0;border-bottom:1px solid var(--line);transition:padding-left .4s;cursor:pointer;text-decoration:none;color:var(--ink);}
.page-index .news-item:first-child{border-top:1px solid var(--line);}
.page-index .news-item:hover{padding-left:14px;}
.page-index .news-item .date{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--gold);}
.page-index .news-item .ttl{font-family:var(--mincho);font-size:15px;}
.page-index .news-item .arrow{color:var(--gold);font-size:18px;}
.page-index .news-foot{text-align:center;margin-top:50px;}
.page-index .artist-cta{background:var(--ink);color:var(--ivory);text-align:center;padding:90px 48px;}
.page-index .artist-cta .sec-label{color:var(--gold-soft);}
.page-index .artist-cta h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(24px,3vw,38px);margin:16px 0 24px;}
.page-index .artist-cta p{font-family:var(--mincho);font-size:14px;color:rgba(247,243,236,0.7);max-width:560px;margin:0 auto 34px;line-height:2;}
.page-index .artist-cta a{display:inline-block;border:1px solid var(--gold-soft);color:var(--gold-soft);padding:14px 40px;text-decoration:none;font-size:12px;letter-spacing:.25em;text-transform:uppercase;transition:background .4s,color .4s;}
.page-index .artist-cta a:hover{background:var(--gold-soft);color:var(--ink);}
@media(max-width:900px){
  .page-index section{padding:80px 24px;}
  .page-index .hosp-inner{grid-template-columns:1fr;gap:40px;}
  .page-index .artists-intro .hosp-inner{grid-template-columns:1fr;gap:40px;}
  .page-index .artists-intro{padding:80px 24px;}
  .page-index .voices-grid{grid-template-columns:1fr;gap:30px;}
  .page-index .gallery-grid{grid-template-columns:repeat(2,1fr);}
  .page-index .g-item:nth-child(2), .page-index .g-item:nth-child(4){margin-top:0;}
  .page-index .news-item{grid-template-columns:80px 1fr auto;gap:14px;}
}


/* ===================== PAGE: our-story ===================== */
.page-our-story .chapter{max-width:1180px;margin:0 auto;padding:90px 48px;}
.page-our-story .chapter.center{max-width:780px;text-align:center;}
.page-our-story .sec-title-jp{font-family:var(--mincho);font-size:clamp(16px,2vw,20px);margin-top:14px;font-weight:500;letter-spacing:.08em;color:var(--ink-soft);}
.page-our-story .body-jp{font-family:var(--mincho);font-size:16px;color:var(--ink-soft);line-height:2.2;margin-top:26px;}
.page-our-story .body-jp.center{max-width:640px;margin-left:auto;margin-right:auto;}
.page-our-story .mission-band{background:var(--ivory-deep);text-align:center;padding:120px 24px;}
.page-our-story .mission-band .mission-en{font-family:var(--serif);font-style:italic;font-size:clamp(28px,4.5vw,52px);line-height:1.35;max-width:900px;margin:0 auto;}
.page-our-story .mission-band .mission-jp{font-family:var(--mincho);font-size:17px;color:var(--ink-soft);line-height:2.3;margin-top:36px;}
.page-our-story .split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.page-our-story .split.reverse .split-img{order:2;}
.page-our-story .split-img{aspect-ratio:4/5;background:var(--ivory-deep);display:flex;align-items:center;justify-content:center;border:1px solid var(--line);position:relative;}
.page-our-story .split-img span{font-size:11px;letter-spacing:.4em;color:rgba(43,39,35,0.25);}
.page-our-story .split-img::after{content:'';position:absolute;inset:16px;border:1px solid var(--gold-soft);pointer-events:none;z-index:2;}
.page-our-story .split-img.has-image{background:none;overflow:hidden;}
.page-our-story .split-img.has-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.page-our-story .pullquote{text-align:center;max-width:840px;margin:0 auto;padding:100px 48px;}
.page-our-story .pullquote .mark{font-family:var(--serif);font-size:80px;color:var(--gold-soft);line-height:0.5;}
.page-our-story .pullquote p{font-family:var(--serif);font-style:italic;font-size:clamp(24px,3.4vw,38px);line-height:1.45;margin:30px 0;}
.page-our-story .pullquote .attr{font-family:var(--mincho);font-size:13px;color:var(--gold);letter-spacing:.2em;}
/* テストモニアルの日本語は他の日本語と同じ明朝体に揃える（serif italic を打ち消す） */
.page-our-story .pullquote p.body-jp{font-family:var(--mincho);font-style:normal;font-size:17px;line-height:2;color:var(--ink-soft);}
.page-our-story .values{background:var(--ivory-deep);text-align:center;padding:110px 48px;}
.page-our-story .values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:50px;max-width:1100px;margin:56px auto 0;}
.page-our-story .vcard .vnum{font-family:var(--serif);font-style:italic;font-size:38px;color:var(--gold-soft);}
.page-our-story .vcard h3{font-family:var(--mincho);font-size:18px;font-weight:500;margin:16px 0 14px;letter-spacing:.05em;}
.page-our-story .vcard p{font-size:13px;color:var(--ink-soft);line-height:1.95;letter-spacing:.03em;}
.page-our-story .story-cta{text-align:center;padding:120px 48px;}
.page-our-story .story-cta h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(26px,3.5vw,44px);line-height:1.25;}
.page-our-story .story-cta .btns{margin-top:46px;display:flex;gap:20px;justify-content:center;flex-wrap:wrap;}
@media(max-width:900px){
  .page-our-story .chapter{padding:60px 24px;}
  .page-our-story .split{grid-template-columns:1fr;gap:40px;}
  .page-our-story .split.reverse .split-img{order:0;}
  .page-our-story .values-grid{grid-template-columns:1fr;gap:40px;}
}


/* ===================== PAGE: collection ===================== */
.page-collection .filters{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:0 auto 50px;padding:0 24px;}
.page-collection .filters button{background:none;border:1px solid var(--line);color:var(--ink-soft);font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:10px 24px;cursor:pointer;transition:all .35s;border-radius:1px;}
.page-collection .filters button:hover{border-color:var(--gold-soft);color:var(--ink);}
.page-collection .filters button.active{background:var(--ink);border-color:var(--ink);color:var(--ivory);}
.page-collection .gallery{max-width:1300px;margin:0 auto;padding:0 48px 110px;}
.page-collection .gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.page-collection .g-item{aspect-ratio:3/4;background:var(--ivory-deep);border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;transition:transform .6s,box-shadow .6s;position:relative;cursor:pointer;text-decoration:none;color:inherit;}
.page-collection .g-item:hover{transform:translateY(-8px);box-shadow:0 20px 40px rgba(43,39,35,0.08);}
.page-collection .g-item .ph{font-size:10px;letter-spacing:.3em;color:rgba(43,39,35,0.25);text-transform:uppercase;}
.page-collection .g-item .tag{position:absolute;bottom:0;left:0;right:0;padding:16px;background:linear-gradient(transparent,rgba(43,39,35,0.45));opacity:0;transition:opacity .4s;}
.page-collection .g-item .tag span{color:var(--ivory);font-family:var(--mincho);font-size:13px;letter-spacing:.1em;}
.page-collection .g-item:hover .tag{opacity:1;}
.page-collection .g-style{position:absolute;top:14px;left:14px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);background:var(--ivory);padding:5px 12px;border:1px solid var(--line);}
@media(max-width:900px){
  .page-collection .gallery{padding:0 24px 70px;}
  .page-collection .gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px;}
  .page-collection .meta-row{grid-template-columns:100px 1fr;gap:14px;}
}


/* ===================== PAGE: artists ===================== */
.page-artists .artists{max-width:1200px;margin:0 auto;padding:40px 48px 60px;}
.page-artists .artist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.page-artists .a-card{cursor:pointer;text-align:center;}
.page-artists .a-photo{aspect-ratio:3/4;background:var(--ivory-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;margin-bottom:22px;}
.page-artists .a-photo span{font-size:10px;letter-spacing:.3em;color:rgba(43,39,35,0.25);text-transform:uppercase;}
.page-artists .a-photo::after{content:'';position:absolute;inset:14px;border:1px solid var(--gold-soft);pointer-events:none;opacity:0;transition:opacity .4s;}
.page-artists .a-card:hover .a-photo::after{opacity:1;}
.page-artists .a-card .role{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);}
.page-artists .a-card .name{font-family:var(--serif);font-style:italic;font-size:30px;margin:8px 0 4px;line-height:1;}
.page-artists .a-card .loc{font-family:var(--mincho);font-size:12px;color:var(--ink-soft);letter-spacing:.1em;}
.page-artists .a-card .a-tags{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px;}
.page-artists .a-card .a-tags span{border:1px solid var(--line);color:var(--ink-soft);font-size:11px;letter-spacing:.08em;padding:5px 13px;border-radius:1px;}
.page-artists .a-card.soon .a-photo{background:repeating-linear-gradient(45deg,var(--ivory-deep),var(--ivory-deep) 12px,var(--ivory) 12px,var(--ivory) 24px);}
.page-artists .a-card.soon{cursor:default;}
.page-artists .a-card.soon .name{color:var(--ink-soft);}
.page-artists .feature{background:var(--ivory-deep);padding:110px 48px;}
.page-artists .feature-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:0.85fr 1.15fr;gap:70px;align-items:center;}
.page-artists .feature-img{aspect-ratio:4/5;background:var(--ivory);display:flex;align-items:center;justify-content:center;border:1px solid var(--line);position:relative;}
.page-artists .feature-img span{font-size:11px;letter-spacing:.4em;color:rgba(43,39,35,0.25);}
.page-artists .feature-img::after{content:'';position:absolute;inset:16px;border:1px solid var(--gold-soft);pointer-events:none;z-index:2;}
.page-artists .feature-img.has-logo{background:#e8d5b8;overflow:hidden;}
.page-artists .feature-img.has-logo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.page-artists .a-photo.has-logo{overflow:hidden;background:#e8d5b8;}
.page-artists .a-photo.has-logo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.page-artists .feature-info .pin{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);}
.page-artists .feature-info .name{font-family:var(--serif);font-style:italic;font-size:clamp(38px,5vw,56px);margin:8px 0 4px;line-height:1;}
.page-artists .feature-info .name-jp{font-family:var(--mincho);font-size:13px;color:var(--ink-soft);letter-spacing:.2em;}
.page-artists .feature-info .bio{font-family:var(--mincho);font-size:15px;color:var(--ink-soft);line-height:2.1;margin-top:28px;}
.page-artists .feature-meta{margin-top:36px;display:grid;gap:0;}
.page-artists .meta-row{display:grid;grid-template-columns:130px 1fr;gap:20px;align-items:start;padding:18px 0;border-bottom:1px solid var(--line);}
.page-artists .meta-row:first-child{border-top:1px solid var(--line);}
.page-artists .meta-row .label{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);padding-top:3px;}
.page-artists .meta-row .val{font-family:var(--mincho);font-size:14px;color:var(--ink);line-height:1.9;}
.page-artists .tags{display:flex;flex-wrap:wrap;gap:10px;}
.page-artists .tags span{border:1px solid var(--gold-soft);color:var(--ink-soft);font-size:12px;letter-spacing:.1em;padding:6px 16px;border-radius:1px;}
.page-artists .feature-info .view-work{margin-top:32px;display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--ink);text-decoration:none;}
.page-artists .feature-info .view-work .ln{width:34px;height:1px;background:var(--gold);transition:width .4s;}
.page-artists .feature-info .view-work:hover .ln{width:50px;}
.page-artists .join{background:var(--ink);color:var(--ivory);text-align:center;padding:100px 48px;}
.page-artists .join .sec-label{color:var(--gold-soft);}
.page-artists .join h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(24px,3vw,40px);margin:14px 0 22px;}
.page-artists .join p{font-family:var(--mincho);font-size:14px;color:rgba(247,243,236,0.7);max-width:560px;margin:0 auto 34px;line-height:2;}
.page-artists .join a{display:inline-block;border:1px solid var(--gold-soft);color:var(--gold-soft);padding:15px 40px;text-decoration:none;font-size:12px;letter-spacing:.25em;text-transform:uppercase;transition:all .4s;}
.page-artists .join a:hover{background:var(--gold-soft);color:var(--ink);}
@media(max-width:900px){
  .page-artists .artists{padding:30px 24px 40px;}
  .page-artists .artist-grid{grid-template-columns:1fr 1fr;gap:20px;}
  .page-artists .feature{padding:70px 24px;}
  .page-artists .feature-inner{grid-template-columns:1fr;gap:40px;}
  .page-artists .meta-row{grid-template-columns:100px 1fr;gap:14px;}
}


/* ===================== PAGE: craft ===================== */
.page-craft .body-jp{font-family:var(--mincho);font-size:16px;color:var(--ink-soft);line-height:2.2;}
.page-craft .philo{max-width:760px;margin:0 auto;text-align:center;padding:40px 48px 100px;}
.page-craft .philo p{font-family:var(--serif);font-style:italic;font-size:clamp(22px,3vw,32px);line-height:1.5;color:var(--ink);}
.page-craft .philo .jp-note{font-family:var(--mincho);font-size:16px;color:var(--ink-soft);line-height:2.2;margin-top:30px;}
.page-craft .video-sec{background:var(--ink);color:var(--ivory);padding:110px 48px;text-align:center;}
.page-craft .video-sec .sec-label{color:var(--gold-soft);}
.page-craft .video-sec .sec-title{color:var(--ivory);}
.page-craft .craft-video{max-width:1000px;margin:48px auto 0;aspect-ratio:16/9;background:#3a352f;border:1px solid rgba(205,184,146,0.3);display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;}
.page-craft .play-btn{width:80px;height:80px;border:1px solid var(--gold-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .4s,transform .4s;}
.page-craft .craft-video:hover .play-btn{background:rgba(205,184,146,0.18);transform:scale(1.08);}
.page-craft .play-btn::after{content:'';border-left:18px solid var(--gold-soft);border-top:11px solid transparent;border-bottom:11px solid transparent;margin-left:5px;}
.page-craft .video-cap{font-family:var(--mincho);font-size:13px;color:rgba(247,243,236,0.55);letter-spacing:.15em;margin-top:24px;}
.page-craft .steps-sec{padding:110px 48px;}
.page-craft .steps-head{text-align:center;margin-bottom:70px;}
.page-craft .steps{max-width:1150px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.page-craft .step{text-align:center;position:relative;}
.page-craft .step-img{aspect-ratio:1;background:var(--ivory-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:24px;position:relative;overflow:hidden;}
.page-craft .step-img img{width:100%;height:100%;object-fit:cover;display:block;}
.page-craft .step-img span{font-size:10px;letter-spacing:.3em;color:rgba(43,39,35,0.25);text-transform:uppercase;}
.page-craft .step-img::after{content:'';position:absolute;inset:12px;border:1px solid var(--gold-soft);pointer-events:none;}
.page-craft .step .n{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--gold);}
.page-craft .step h3{font-family:var(--mincho);font-size:16px;font-weight:500;margin:8px 0 12px;letter-spacing:.05em;}
.page-craft .step p{font-size:13px;color:var(--ink-soft);line-height:1.9;letter-spacing:.02em;}
.page-craft .flow-sec{background:var(--ivory-deep);padding:110px 48px;}
.page-craft .flow-head{text-align:center;margin-bottom:64px;}
.page-craft .flow{max-width:820px;margin:0 auto;}
.page-craft .flow-item{display:grid;grid-template-columns:64px 1fr;gap:30px;padding:32px 0;border-bottom:1px solid var(--line);align-items:start;}
.page-craft .flow-item:last-child{border-bottom:none;}
.page-craft .flow-item .fnum{font-family:var(--serif);font-style:italic;font-size:34px;color:var(--gold-soft);line-height:1;}
.page-craft .flow-item h3{font-family:var(--mincho);font-size:18px;font-weight:500;letter-spacing:.05em;}
.page-craft .flow-item p{font-family:var(--mincho);font-size:14px;color:var(--ink-soft);line-height:2;margin-top:10px;}
.page-craft .hosp-sec{padding:110px 48px;}
.page-craft .hosp-head{text-align:center;margin-bottom:64px;}
.page-craft .hosp-grid{max-width:760px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:40px;}
.page-craft .hcard{text-align:center;}
.page-craft .hcard-img{aspect-ratio:4/3;background:var(--ivory-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:24px;position:relative;}
.page-craft .hcard-img span{font-size:10px;letter-spacing:.3em;color:rgba(43,39,35,0.25);text-transform:uppercase;}
.page-craft .hcard h3{font-family:var(--mincho);font-size:17px;font-weight:500;margin-bottom:12px;letter-spacing:.05em;}
.page-craft .hcard p{font-size:13px;color:var(--ink-soft);line-height:1.95;}
@media(max-width:900px){
  .page-craft .video-sec, .page-craft .steps-sec, .page-craft .flow-sec, .page-craft .hosp-sec{padding:70px 24px;}
  .page-craft .steps{grid-template-columns:1fr 1fr;gap:30px;}
  .page-craft .hosp-grid{grid-template-columns:1fr;gap:40px;}
  .page-craft .flow-item{grid-template-columns:48px 1fr;gap:20px;}
}


/* ===================== PAGE: social ===================== */
.page-social .stats{max-width:1000px;margin:0 auto;padding:20px 48px 90px;display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.page-social .stat-card{text-decoration:none;color:inherit;display:block;text-align:center;border:1px solid var(--line);padding:44px 24px;background:var(--ivory);transition:transform .5s,box-shadow .5s;}
.page-social .stat-card:hover{transform:translateY(-6px);box-shadow:0 18px 36px rgba(43,39,35,0.07);}
.page-social .stat-card .pf{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);}
.page-social .stat-card .num{font-family:var(--serif);font-style:italic;font-size:48px;color:var(--ink);line-height:1.1;margin:14px 0 4px;}
.page-social .stat-card .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);}
.page-social .stat-card .handle{font-family:var(--mincho);font-size:13px;color:var(--ink-soft);margin-top:8px;}
.page-social .plat{padding:100px 48px;}
.page-social .plat.alt{background:var(--ivory-deep);}
.page-social .plat-inner{max-width:1200px;margin:0 auto;}
.page-social .plat-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:44px;flex-wrap:wrap;gap:20px;}
.page-social .plat-head .left .pf-label{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.page-social .plat-head .left h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(26px,3.5vw,40px);line-height:1.1;}
.page-social .plat-head .left .desc{font-family:var(--mincho);font-size:14px;color:var(--ink-soft);margin-top:10px;}
.page-social .pf-btn{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--ink);color:var(--ink);padding:13px 30px;text-decoration:none;font-size:11px;letter-spacing:.22em;text-transform:uppercase;transition:all .4s;white-space:nowrap;}
.page-social .pf-btn:hover{background:var(--ink);color:var(--ivory);}
.page-social .ig-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.page-social .ig-item{aspect-ratio:1;background:var(--ivory-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;}
.page-social .plat.alt .ig-item{background:var(--ivory);}
.page-social .ig-item span{font-size:9px;letter-spacing:.2em;color:rgba(43,39,35,0.25);}
.page-social .ig-item::after{content:'❤';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(43,39,35,0.4);color:var(--ivory);font-size:20px;opacity:0;transition:opacity .4s;}
.page-social .ig-item:hover::after{opacity:1;}
.page-social .tt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.page-social .tt-item{aspect-ratio:9/16;background:var(--ivory);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;overflow:hidden;}
.page-social .tt-item span{font-size:9px;letter-spacing:.2em;color:rgba(43,39,35,0.25);}
.page-social .tt-item .pl{position:absolute;width:46px;height:46px;border:1px solid var(--gold-soft);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .4s,background .4s;}
.page-social .tt-item:hover .pl{transform:scale(1.12);background:rgba(176,141,87,0.12);}
.page-social .tt-item .pl::after{content:'';border-left:12px solid var(--gold);border-top:8px solid transparent;border-bottom:8px solid transparent;margin-left:3px;}
.page-social .tt-item .views{position:absolute;bottom:10px;left:10px;font-size:10px;letter-spacing:.1em;color:var(--ink-soft);}
.page-social .red-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.page-social .red-item{background:var(--ivory);border:1px solid var(--line);overflow:hidden;cursor:pointer;transition:transform .5s;}
.page-social .plat.alt .red-item{background:var(--ivory-deep);}
.page-social .red-item:hover{transform:translateY(-5px);}
.page-social .red-thumb{aspect-ratio:3/4;background:var(--ivory-deep);display:flex;align-items:center;justify-content:center;}
.page-social .plat.alt .red-thumb{background:var(--ivory);}
.page-social .red-thumb span{font-size:9px;letter-spacing:.2em;color:rgba(43,39,35,0.25);}
.page-social .red-cap{padding:14px;}
.page-social .red-cap p{font-family:var(--mincho);font-size:12px;color:var(--ink);line-height:1.7;}
.page-social .red-cap .meta{font-size:10px;letter-spacing:.1em;color:var(--gold);margin-top:8px;}
@media(max-width:900px){
  .page-social .stats{grid-template-columns:1fr;gap:18px;padding:20px 24px 60px;}
  .page-social .plat{padding:60px 24px;}
  .page-social .ig-grid, .page-social .tt-grid, .page-social .red-grid{grid-template-columns:repeat(2,1fr);}
}


/* ===================== PAGE: journal ===================== */
.page-journal .jfilters{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:0 auto 60px;padding:0 24px;}
.page-journal .jfilters button, .page-journal .jfilters a{text-decoration:none;background:none;border:1px solid var(--line);color:var(--ink-soft);font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:9px 22px;cursor:pointer;transition:all .35s;border-radius:1px;}
.page-journal .jfilters button:hover, .page-journal .jfilters a:hover{border-color:var(--gold-soft);color:var(--ink);}
.page-journal .jfilters button.active, .page-journal .jfilters a.active{background:var(--ink);border-color:var(--ink);color:var(--ivory);}
.page-journal .featured{max-width:1200px;margin:0 auto 90px;padding:0 48px;}
.page-journal .feat-card{display:grid;grid-template-columns:1.1fr 1fr;gap:0;border:1px solid var(--line);background:var(--ivory);cursor:pointer;transition:box-shadow .5s;}
.page-journal .feat-card:hover{box-shadow:0 24px 50px rgba(43,39,35,0.08);}
.page-journal .feat-img{aspect-ratio:16/12;background:var(--ivory-deep);display:flex;align-items:center;justify-content:center;}
.page-journal .feat-img span{font-size:11px;letter-spacing:.3em;color:rgba(43,39,35,0.25);text-transform:uppercase;}
.page-journal .feat-body{padding:60px 56px;display:flex;flex-direction:column;justify-content:center;}
.page-journal .feat-body .cat{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);}
.page-journal .feat-body .date{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft);margin:14px 0;}
.page-journal .feat-body h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(26px,3vw,38px);line-height:1.25;}
.page-journal .feat-body p{font-family:var(--mincho);font-size:14px;color:var(--ink-soft);line-height:2;margin-top:20px;}
.page-journal .feat-body .more{margin-top:28px;display:inline-flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--ink);}
.page-journal .feat-body .more .ln{width:34px;height:1px;background:var(--gold);transition:width .4s;}
.page-journal .feat-card:hover .more .ln{width:50px;}
.page-journal .articles{max-width:1200px;margin:0 auto;padding:0 48px 110px;}
.page-journal .art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px 30px;}
.page-journal .art-card{cursor:pointer;}
.page-journal .art-thumb{aspect-ratio:3/2;background:var(--ivory-deep);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;margin-bottom:22px;overflow:hidden;}
.page-journal .art-thumb span{font-size:10px;letter-spacing:.3em;color:rgba(43,39,35,0.25);text-transform:uppercase;}
.page-journal .art-thumb-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .6s;}
.page-journal .art-card:hover .art-thumb-inner{transform:scale(1.05);}
.page-journal .art-card .cat{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);}
.page-journal .art-card .date{font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-soft);margin:10px 0;}
.page-journal .art-card h3{font-family:var(--mincho);font-size:17px;font-weight:500;line-height:1.6;letter-spacing:.02em;}
.page-journal .art-card p{font-family:var(--mincho);font-size:13px;color:var(--ink-soft);line-height:1.9;margin-top:12px;}
.page-journal .load-more{text-align:center;margin-top:70px;}
.page-journal .load-btn{border:1px solid var(--ink);color:var(--ink);padding:15px 44px;text-decoration:none;font-size:12px;letter-spacing:.22em;text-transform:uppercase;transition:all .4s;cursor:pointer;background:none;font-family:var(--sans);}
.page-journal .load-btn:hover{background:var(--ink);color:var(--ivory);}
.page-journal .news-letter{background:var(--ivory-deep);text-align:center;padding:100px 48px;}
.page-journal .news-letter h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(24px,3vw,38px);}
.page-journal .news-letter p{font-family:var(--mincho);font-size:14px;color:var(--ink-soft);margin:18px auto 36px;max-width:480px;line-height:2;}
.page-journal .nl-form{display:flex;gap:0;max-width:460px;margin:0 auto;border:1px solid var(--ink);}
.page-journal .nl-form input{flex:1;border:none;background:transparent;padding:16px 22px;font-family:var(--sans);font-size:13px;letter-spacing:.05em;color:var(--ink);outline:none;}
.page-journal .nl-form button{background:var(--ink);color:var(--ivory);border:none;padding:0 32px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:background .4s;}
.page-journal .nl-form button:hover{background:var(--gold);}
@media(max-width:900px){
  .page-journal .featured{padding:0 24px;margin-bottom:60px;}
  .page-journal .feat-card{grid-template-columns:1fr;}
  .page-journal .feat-body{padding:40px 28px;}
  .page-journal .articles{padding:0 24px 70px;}
  .page-journal .art-grid{grid-template-columns:1fr;gap:40px;}
  .page-journal .news-letter{padding:70px 24px;}
  .page-journal .nl-form{flex-direction:column;border:none;gap:12px;}
  .page-journal .nl-form input{border:1px solid var(--ink);}
  .page-journal .nl-form button{padding:15px;}
}


/* ===================== PAGE: contact ===================== */
.page-contact .contact-wrap{max-width:1080px;margin:0 auto;padding:0 48px 40px;display:grid;grid-template-columns:1.25fr 1fr;gap:64px;align-items:start;}
.page-contact .field{margin-bottom:22px;}
.page-contact .field label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:9px;}
.page-contact .field input, .page-contact .field select, .page-contact .field textarea{width:100%;background:var(--ivory);border:1px solid var(--line);padding:14px 16px;font-family:var(--sans);font-size:14px;color:var(--ink);border-radius:1px;transition:border-color .3s;}
.page-contact .field input:focus, .page-contact .field select:focus, .page-contact .field textarea:focus{outline:none;border-color:var(--gold-soft);}
.page-contact .field textarea{resize:vertical;min-height:140px;line-height:1.8;}
.page-contact .submit-btn{background:var(--ink);color:var(--ivory);border:none;padding:16px 42px;font-family:var(--sans);font-size:12px;letter-spacing:.25em;text-transform:uppercase;cursor:pointer;transition:background .4s;border-radius:1px;}
.page-contact .submit-btn:hover{background:var(--gold);}
.page-contact .form-note{margin-top:18px;font-family:var(--mincho);font-size:13px;color:var(--gold);line-height:1.9;display:none;}
.page-contact .contact-info h3{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--ink);margin-bottom:24px;}
.page-contact .info-block{margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid var(--line);}
.page-contact .info-block:last-child{border-bottom:none;}
.page-contact .info-block .ilabel{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.page-contact .info-block a, .page-contact .info-block p{font-family:var(--sans);font-size:14px;color:var(--ink-soft);line-height:1.9;text-decoration:none;display:block;}
.page-contact .info-block a:hover{color:var(--ink);}
@media(max-width:820px){
  .page-contact .contact-wrap{grid-template-columns:1fr;gap:48px;}
}


/* ===================== JOURNAL: WP連携 + 個別記事(.page-article) ===================== */
/* カード全体をリンク化したときのリセット */
.page-journal .feat-card{text-decoration:none;color:inherit;}
.page-journal .art-card{text-decoration:none;color:inherit;display:block;}
/* サムネイルに実画像を流し込む */
.page-journal .feat-img img,
.page-journal .art-thumb-inner img{width:100%;height:100%;object-fit:cover;display:block;}
.page-journal .feat-img{overflow:hidden;}
/* アーカイブのページネーション(the_posts_pagination) */
.page-journal .pagination{max-width:1200px;margin:60px auto 0;padding:0 48px;text-align:center;}
.page-journal .pagination .nav-links{display:inline-flex;gap:8px;flex-wrap:wrap;justify-content:center;}
.page-journal .pagination .page-numbers{display:inline-block;min-width:40px;padding:9px 13px;border:1px solid var(--line);color:var(--ink-soft);text-decoration:none;font-size:12px;letter-spacing:.08em;border-radius:1px;transition:all .3s;}
.page-journal .pagination .page-numbers.current{background:var(--ink);color:var(--ivory);border-color:var(--ink);}
.page-journal .pagination .page-numbers:hover{border-color:var(--gold-soft);color:var(--ink);}

/* ---- 個別記事ページ ---- */
.page-article .article-hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:140px 24px 32px;}
.page-article .article-hero .breadcrumb{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:24px;}
.page-article .article-hero .breadcrumb a{color:var(--ink-soft);text-decoration:none;}
.page-article .article-hero .breadcrumb a:hover{color:var(--gold);}
.page-article .article-hero .cat{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;}
.page-article .article-hero h1{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(30px,4.5vw,54px);line-height:1.18;max-width:900px;}
.page-article .article-hero .date{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--ink-soft);margin-top:20px;}
.page-article .article-cover{max-width:1000px;margin:28px auto 60px;padding:0 24px;}
.page-article .article-cover .cover-inner{aspect-ratio:16/9;overflow:hidden;background:var(--ivory-deep);border:1px solid var(--line);}
.page-article .article-cover img{width:100%;height:100%;object-fit:cover;display:block;}
.page-article .article-body{max-width:720px;margin:0 auto;padding:0 24px 64px;}
.page-article .article-body p{font-family:var(--mincho);font-size:16px;line-height:2.1;color:var(--ink-soft);margin-bottom:1.6em;}
.page-article .article-body h2{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(24px,3vw,34px);margin:1.6em 0 .6em;color:var(--ink);}
.page-article .article-body h3{font-family:var(--mincho);font-size:19px;font-weight:600;margin:1.4em 0 .5em;color:var(--ink);}
.page-article .article-body img{max-width:100%;height:auto;margin:1.5em 0;border-radius:1px;}
.page-article .article-body a{color:var(--gold);text-decoration:underline;}
.page-article .article-body ul,.page-article .article-body ol{margin:0 0 1.6em 1.4em;color:var(--ink-soft);font-family:var(--mincho);line-height:2;}
.page-article .article-body blockquote{border-left:2px solid var(--gold);padding-left:24px;margin:1.6em 0;font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink);}
.page-article .article-nav{max-width:720px;margin:0 auto;padding:30px 24px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:24px;font-size:11px;letter-spacing:.18em;}
.page-article .article-nav a{color:var(--ink-soft);text-decoration:none;transition:color .3s;max-width:47%;line-height:1.6;}
.page-article .article-nav a:hover{color:var(--gold);}
.page-article .article-nav .next{text-align:right;margin-left:auto;}
.page-article .article-nav .nlabel{display:block;font-size:9px;color:var(--gold);margin-bottom:6px;letter-spacing:.25em;text-transform:uppercase;}
@media(max-width:900px){
  .page-journal .pagination{padding:0 24px;}
  .page-article .article-hero{padding:118px 24px 26px;}
  .page-article .article-cover{margin:18px auto 40px;}
}



/* =====================================================================
   Contact Form 7 連携（テーマ追加分）— 既存 .contact デザインに馴染ませる
   ===================================================================== */
.page-contact .wpcf7-form-control-wrap{display:block;}          /* input幅100%を有効化 */
.page-contact .wpcf7-form .field{margin-bottom:22px;}
.page-contact .wpcf7-not-valid-tip{color:#b3503e;font-size:12px;margin-top:6px;}
.page-contact .wpcf7-response-output{margin:18px 0 0!important;border-radius:1px;font-family:var(--mincho);font-size:13px;padding:12px 16px!important;}
.page-contact .wpcf7-spinner{margin:0 0 0 12px;}
