/* SITE CRAFT Affiliate Visual Reset - front page only */
:root{
  --scav-ink:#142426;
  --scav-text:#2c4446;
  --scav-muted:#6b7f82;
  --scav-accent:#0b91a0;
  --scav-accent-deep:#066b76;
  --scav-mint:#749991;
  --scav-mint-deep:#4f766f;
  --scav-deep:#202b29;
  --scav-ease:cubic-bezier(.22,1,.36,1);
  --scav-shadow:0 20px 44px rgba(12,42,48,.13);
}
body.home,body.front-page{overflow-x:hidden;background:#fff;color:var(--scav-ink);}
body.home .sc-main,body.front-page .sc-main{max-width:none;width:100%;padding:0;background:#fff;overflow:hidden;}

/* Kill old HOME-only header overrides from main.css and rebuild top header */
body.home .sc-header,body.front-page .sc-header{
  display:block!important;position:fixed!important;top:0!important;left:0!important;right:0!important;z-index:10050!important;
  background:transparent!important;border:0!important;box-shadow:none!important;color:#fff!important;opacity:1!important;visibility:visible!important;
  transition:background .26s var(--scav-ease), color .26s var(--scav-ease), box-shadow .26s var(--scav-ease), border-color .26s var(--scav-ease);
}
html.sc-scrolled body.home .sc-header,html.sc-scrolled body.front-page .sc-header{
  background:#fff!important;color:#13292b!important;border-bottom:1px solid rgba(18,43,47,.08)!important;box-shadow:0 8px 26px rgba(14,45,50,.06)!important;
}
body.home .sc-header__inner,body.front-page .sc-header__inner{
  height:58px!important;width:min(1120px,calc(100% - 24px))!important;max-width:none!important;margin:0 auto!important;padding:0!important;
  display:flex!important;align-items:center!important;justify-content:space-between!important;
}
body.home .sc-brand,body.front-page .sc-brand{display:block!important;min-width:0!important;}
body.home .sc-brand__link,body.front-page .sc-brand__link{display:flex!important;align-items:center!important;color:inherit!important;text-decoration:none!important;max-width:calc(100vw - 96px)!important;}
body.home .sc-brand__name,body.front-page .sc-brand__name{
  display:block!important;font-size:11px!important;line-height:1.25!important;font-weight:900!important;letter-spacing:.12em!important;color:inherit!important;
  white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;text-shadow:0 10px 24px rgba(0,0,0,.46)!important;
}
html.sc-scrolled body.home .sc-brand__name,html.sc-scrolled body.front-page .sc-brand__name{text-shadow:none!important;}
body.home .sc-header__right,body.front-page .sc-header__right{display:flex!important;align-items:center!important;gap:10px!important;}
body.home .sc-menuBtn,body.front-page .sc-menuBtn,
html.sc-homeScrolled body.home .sc-menuBtn,html.sc-homeScrolled body.front-page .sc-menuBtn{
  display:grid!important;place-items:center!important;position:relative!important;top:auto!important;right:auto!important;left:auto!important;bottom:auto!important;
  width:42px!important;height:42px!important;min-width:42px!important;min-height:42px!important;padding:0!important;margin:0!important;
  background:transparent!important;border:0!important;border-radius:50%!important;box-shadow:none!important;color:inherit!important;appearance:none!important;cursor:pointer!important;z-index:10060!important;
}
body.home .sc-menuBtn::before,body.front-page .sc-menuBtn::before{content:"";position:absolute;inset:0;border-radius:50%;background:transparent;transition:background .2s ease;}
body.home .sc-menuBtn:hover::before,body.front-page .sc-menuBtn:hover::before{background:rgba(255,255,255,.10);}
html.sc-scrolled body.home .sc-menuBtn:hover::before,html.sc-scrolled body.front-page .sc-menuBtn:hover::before{background:rgba(12,36,40,.06);}
body.home .sc-menuBtn__lines,body.front-page .sc-menuBtn__lines,
body.home .sc-menuBtn__lines::before,body.front-page .sc-menuBtn__lines::before,
body.home .sc-menuBtn__lines::after,body.front-page .sc-menuBtn__lines::after{
  content:"";display:block!important;width:24px!important;height:2px!important;background:currentColor!important;border-radius:999px!important;position:relative!important;box-shadow:none!important;opacity:1!important;
  transition:transform .24s ease, background .24s ease, opacity .24s ease;
}
body.home .sc-menuBtn__lines::before,body.front-page .sc-menuBtn__lines::before{position:absolute!important;left:0!important;top:-7px!important;}
body.home .sc-menuBtn__lines::after,body.front-page .sc-menuBtn__lines::after{position:absolute!important;left:0!important;top:7px!important;}
html.sc-menuOpen body.home .sc-menuBtn__lines,html.sc-menuOpen body.front-page .sc-menuBtn__lines{background:transparent!important;}
html.sc-menuOpen body.home .sc-menuBtn__lines::before,html.sc-menuOpen body.front-page .sc-menuBtn__lines::before{transform:translateY(7px) rotate(45deg);}
html.sc-menuOpen body.home .sc-menuBtn__lines::after,html.sc-menuOpen body.front-page .sc-menuBtn__lines::after{transform:translateY(-7px) rotate(-45deg);}

/* opening preloader removed in Motion Stable. */

/* hero */
.scav-page{background:#fff;overflow:hidden;}
.scav-hero{position:relative;width:100vw;width:100dvw;margin-left:calc(50% - 50vw);margin-left:calc(50% - 50dvw);min-height:100svh;background:#122326;color:#fff;overflow:hidden;display:grid;place-items:center;}
.scav-hero__slider,.scav-hero__slide{position:absolute;inset:0;}
.scav-hero__slide{opacity:0;background-image:var(--scav-bg);background-size:cover;background-position:center;transform:scale(1.12);transition:opacity 1.35s ease;will-change:opacity,transform;}
.scav-hero__slide.is-active{opacity:1;animation:scavHeroMoveA 10.5s linear forwards;}
.scav-hero__slide:nth-child(2n).is-active{animation-name:scavHeroMoveB;}
.scav-hero__slide:nth-child(3n).is-active{animation-name:scavHeroMoveC;}
.scav-hero__slide:nth-child(4n).is-active{animation-name:scavHeroMoveD;}
@keyframes scavHeroMoveA{from{transform:scale(1.10) translate3d(-2%,1%,0)}to{transform:scale(1.30) translate3d(5%,-3%,0)}}
@keyframes scavHeroMoveB{from{transform:scale(1.12) translate3d(4%,-2%,0)}to{transform:scale(1.28) translate3d(-5%,2%,0)}}
@keyframes scavHeroMoveC{from{transform:scale(1.09) translate3d(0,-4%,0)}to{transform:scale(1.29) translate3d(-3%,5%,0)}}
@keyframes scavHeroMoveD{from{transform:scale(1.11) translate3d(-4%,-1%,0)}to{transform:scale(1.31) translate3d(3%,3%,0)}}
.scav-hero__shade{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.28),rgba(0,0,0,.32) 28%,rgba(0,0,0,.46) 58%,rgba(0,0,0,.70));}
.scav-hero__content{position:relative;z-index:2;width:min(86vw,760px);padding:112px 0 120px;text-align:center;display:grid;place-items:center;}
.scav-hero__title{margin:0;font-size:clamp(28px,8.2vw,54px);line-height:1.28;font-weight:900;letter-spacing:.06em;text-shadow:0 18px 42px rgba(0,0,0,.54);}
.scav-hero__copy{display:none!important;}
.scav-heroNews{position:absolute;z-index:3;left:50%;bottom:18px;transform:translateX(-50%);width:min(88vw,520px);min-height:44px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.95);color:#183235!important;text-decoration:none!important;display:flex;gap:10px;align-items:center;box-shadow:0 16px 42px rgba(0,0,0,.18);font-size:11px;line-height:1.45;}
.scav-heroNews time{flex:0 0 auto;color:var(--scav-accent);font-weight:900;}
.scav-heroNews span{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:800;}

/* layout */
.scav-wrap{width:min(1060px,calc(100% - 34px));margin:0 auto;}
.scav-button{display:inline-grid;place-items:center;height:44px;min-width:184px;padding:0 26px;border-radius:999px;background:var(--scav-accent);color:#fff!important;text-decoration:none!important;font-size:12px;font-weight:900;letter-spacing:.05em;box-shadow:0 16px 30px rgba(11,145,160,.22);transition:transform .25s ease,box-shadow .25s ease,background .25s ease;}
.scav-button:hover{transform:translateY(-1px);background:#0aa0af;box-shadow:0 20px 38px rgba(11,145,160,.30);}
.scav-button--light{background:#0a98a6;}
.scav-intro{padding:86px 0 66px;display:grid;gap:32px;justify-items:center;text-align:center;background:#fff;}
.scav-intro__text{display:grid;gap:18px;justify-items:center;}
.scav-intro__headline{margin:0;display:grid;gap:5px;color:var(--scav-accent);font-size:clamp(28px,8vw,44px);line-height:1.32;font-weight:900;letter-spacing:.05em;}
.scav-intro__headline span{display:block;}
.scav-lead{margin:0;max-width:35em;color:#566d71;font-size:12px;line-height:2.12;font-weight:700;letter-spacing:.035em;}

/* rails: visible CSS animation */
.scav-rail{width:100vw;margin-left:calc(50% - 50vw);overflow:hidden;}
.scav-rail__track{display:flex;width:max-content;will-change:transform;animation:scavRailMove 36s linear infinite;}
.scav-rail:hover .scav-rail__track,.scav-rail:active .scav-rail__track{animation-play-state:paused;}
.scav-rail__group{display:flex;gap:14px;padding:0 7px 8px 11px;}
@keyframes scavRailMove{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.scav-card{flex:0 0 66vw;min-width:66vw;max-width:270px;}
.scav-card__link{display:block;color:inherit;text-decoration:none!important;}
.scav-card__media{display:block;position:relative;aspect-ratio:1.48/1;overflow:hidden;border-radius:12px;background:#e8efee;box-shadow:var(--scav-shadow);}
.scav-card__img,.scav-card__ph svg{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--scav-ease),filter .7s var(--scav-ease);}
.scav-card__link:hover .scav-card__img{transform:scale(1.06);filter:brightness(.97);}
.scav-card__body{display:grid;gap:8px;padding:13px 2px 0;}
.scav-card__meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:10px;line-height:1.4;color:#728385;font-weight:800;}
.scav-card__meta span{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:rgba(11,146,160,.09);color:#4a6b6f;}
.scav-card__title{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;font-size:13px;line-height:1.56;font-weight:900;letter-spacing:.012em;}
.scav-card--dark{color:#fff;}
.scav-card--dark .scav-card__media{box-shadow:0 20px 46px rgba(0,0,0,.24);}
.scav-card--dark .scav-card__meta{color:rgba(255,255,255,.78);}
.scav-card--dark .scav-card__meta span{background:rgba(255,255,255,.16);color:#fff;}
.scav-card--dark .scav-card__title{text-shadow:0 12px 28px rgba(0,0,0,.32);}

/* sections */
.scav-feature{position:relative;isolation:isolate;overflow:hidden;padding:82px 0 78px;}
.scav-feature::before{content:"";position:absolute;inset:0;z-index:-2;background-image:var(--scav-bg-image);background-size:cover;background-position:center;opacity:.20;transform:scale(1.06);}
.scav-feature::after{content:"";position:absolute;inset:0;z-index:-1;}
.scav-feature--green{background:#739890;color:#fff;}
.scav-feature--green::after{background:linear-gradient(135deg,rgba(92,133,126,.92),rgba(61,92,86,.89));}
.scav-feature--dark{background:#232d2b;color:#fff;}
.scav-feature--dark::after{background:linear-gradient(135deg,rgba(35,47,45,.93),rgba(19,26,26,.94));}
.scav-feature__inner{display:grid;gap:28px;justify-items:center;}
.scav-guide{padding:82px 0 76px;display:grid;gap:26px;background:#fff;}
.scav-sectionHead{width:min(680px,100%);display:grid;gap:15px;justify-items:start;text-align:left;}
.scav-sectionHead h2{margin:0;color:var(--scav-accent);font-size:clamp(42px,12vw,62px);line-height:1.02;font-weight:900;letter-spacing:.04em;}
.scav-sectionHead p{margin:0;max-width:30em;color:#576f72;font-size:12px;line-height:2.06;font-weight:700;letter-spacing:.03em;}
.scav-sectionHead--light h2{color:#fff;}
.scav-sectionHead--light p{color:rgba(255,255,255,.84);}

.scav-pickup{padding:60px 0 56px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.scav-pickup__item{position:relative;min-height:112px;border-radius:14px;overflow:hidden;background:#54706d;display:grid;place-items:center;color:#fff!important;text-decoration:none!important;box-shadow:0 16px 34px rgba(11,42,48,.12);}
.scav-pickup__item::before{content:"";position:absolute;inset:0;background:rgba(0,46,48,.34);z-index:1;}
.scav-pickup__img,.scav-pickup__ph svg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease;}
.scav-pickup__item:hover .scav-pickup__img{transform:scale(1.05);}
.scav-pickup__item span{position:relative;z-index:2;padding:0 14px;text-align:center;font-size:13px;line-height:1.55;font-weight:900;text-shadow:0 10px 22px rgba(0,0,0,.32);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;overflow:hidden;}

/* footer top refinement on home only */
body.home .sc-footer__top,body.front-page .sc-footer__top{position:relative;overflow:hidden;border-radius:0!important;background:#d7eef1!important;min-height:190px;display:grid;place-items:center;}
body.home .sc-footer__top::before,body.front-page .sc-footer__top::before{content:"";position:absolute;inset:0;background-image:var(--sc-footer-bg-image);background-size:cover;background-position:center;opacity:.26;}
body.home .sc-footer__top::after,body.front-page .sc-footer__top::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(230,246,248,.70),rgba(199,232,236,.74));}
body.home .sc-footer__stack,body.front-page .sc-footer__stack{position:relative;z-index:1;display:grid;gap:18px;justify-items:center;padding:36px 20px;}
body.home .sc-footer__siteName,body.front-page .sc-footer__siteName{font-size:18px;line-height:1.5;font-weight:900;color:#183236;text-align:center;}
body.home .sc-footer__menu,body.front-page .sc-footer__menu{display:grid;gap:12px;justify-items:center;}
body.home .sc-footer__link,body.front-page .sc-footer__link{min-width:180px;padding:12px 20px;border-radius:999px;background:#fff;color:#173438;text-decoration:none!important;box-shadow:0 10px 22px rgba(20,58,64,.08);font-size:12px;font-weight:900;letter-spacing:.05em;text-align:center;}
body.home .sc-footer__bottom,body.front-page .sc-footer__bottom{background:#fff!important;}

/* reveal animations */
.scav-motion{opacity:1;transform:none;}
.js-ready .scav-motion .scav-sectionHead,
.js-ready .scav-motion .scav-rail,
.js-ready .scav-motion > .scav-button,
.js-ready .scav-motion .scav-intro__text,
.js-ready .scav-motion .scav-pickup__item{opacity:.001;transform:translateY(28px) scale(.985);filter:blur(3px);transition:opacity .68s var(--scav-ease),transform .82s var(--scav-ease),filter .82s var(--scav-ease);}
.js-ready .scav-motion .scav-rail{transition-delay:.10s;}
.js-ready .scav-motion > .scav-button{transition-delay:.18s;}
.js-ready .scav-motion .scav-pickup__item:nth-child(2){transition-delay:.07s;}
.js-ready .scav-motion .scav-pickup__item:nth-child(3){transition-delay:.14s;}
.js-ready .scav-motion .scav-pickup__item:nth-child(4){transition-delay:.21s;}
.js-ready .scav-motion.is-in .scav-sectionHead,
.js-ready .scav-motion.is-in .scav-rail,
.js-ready .scav-motion.is-in > .scav-button,
.js-ready .scav-motion.is-in .scav-intro__text,
.js-ready .scav-motion.is-in .scav-pickup__item{opacity:1;transform:none;filter:none;}

@media(min-width:768px){
  body.home .sc-header__inner,body.front-page .sc-header__inner{height:64px!important;width:min(1120px,calc(100% - 32px))!important;}
  body.home .sc-brand__name,body.front-page .sc-brand__name{font-size:12px!important;letter-spacing:.15em!important;}
  .scav-intro{padding:104px 0 84px;}
  .scav-intro__headline{display:flex;gap:.34em;}
  .scav-rail__group{padding-left:12px;padding-right:12px;gap:18px;}
  .scav-card{flex-basis:300px;min-width:300px;max-width:300px;}
  .scav-pickup{grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;}
  .scav-pickup__item{min-height:132px;}
}
@media(prefers-reduced-motion:reduce){
  .scav-preloader{display:none!important;}
  .scav-hero__slide,.scav-hero__slide.is-active,.scav-rail__track,.scav-motion,.js-ready .scav-motion *{animation:none!important;transition:none!important;transform:none!important;opacity:1!important;filter:none!important;}
}

/* =========================================================
   Section scroll motion from reference video
   - Applies to the three main editorial sections only.
   - Base layout remains visible without JS; motion is additive.
   ========================================================= */
.js-ready .scav-feature.scav-motion,
.js-ready .scav-guide.scav-motion{
  opacity:.72;
  transform:translate3d(0,72px,0) scale(.982);
  filter:blur(2px);
  clip-path:inset(9% 0 9% 0);
  transition:
    opacity .95s cubic-bezier(.22,1,.36,1),
    transform 1.28s cubic-bezier(.22,1,.36,1),
    filter 1.1s cubic-bezier(.22,1,.36,1),
    clip-path 1.32s cubic-bezier(.22,1,.36,1);
  will-change:opacity,transform,clip-path,filter;
}
.js-ready .scav-guide.scav-motion{
  clip-path:inset(0 9% 0 9%);
  transform:translate3d(0,68px,0) scale(.988);
}
.js-ready .scav-feature.scav-motion.is-in,
.js-ready .scav-guide.scav-motion.is-in{
  opacity:1;
  transform:translate3d(0,0,0) scale(1);
  filter:blur(0);
  clip-path:inset(0 0 0 0);
}

/* Background breath/wipe. 参考動画の大きい面が開く感じ */
.js-ready .scav-feature.scav-motion::before{
  opacity:.08;
  transform:scale(1.18) translate3d(0,30px,0);
  filter:blur(8px) saturate(.82);
  transition:opacity 1.35s cubic-bezier(.22,1,.36,1), transform 1.75s cubic-bezier(.22,1,.36,1), filter 1.45s cubic-bezier(.22,1,.36,1);
}
.js-ready .scav-feature.scav-motion.is-in::before{
  opacity:.26;
  transform:scale(1.06) translate3d(0,0,0);
  filter:blur(0) saturate(1);
}

/* Heading: expands and settles instead of popping in. */
.js-ready .scav-motion .scav-sectionHead{
  opacity:.001!important;
  transform:translate3d(34px,44px,0) scale(.965)!important;
  filter:blur(6px)!important;
  clip-path:inset(0 0 100% 0)!important;
  transition:
    opacity .76s cubic-bezier(.22,1,.36,1),
    transform 1.06s cubic-bezier(.22,1,.36,1),
    filter .96s cubic-bezier(.22,1,.36,1),
    clip-path 1.08s cubic-bezier(.22,1,.36,1)!important;
}
.js-ready .scav-guide.scav-motion .scav-sectionHead{
  transform:translate3d(-34px,42px,0) scale(.965)!important;
}
.js-ready .scav-motion.is-in .scav-sectionHead{
  opacity:1!important;
  transform:translate3d(0,0,0) scale(1)!important;
  filter:blur(0)!important;
  clip-path:inset(0 0 0 0)!important;
}
.js-ready .scav-motion .scav-sectionHead h2{
  letter-spacing:.20em;
  transform:translateY(8px);
  transition:letter-spacing 1.08s cubic-bezier(.22,1,.36,1), transform 1.08s cubic-bezier(.22,1,.36,1);
}
.js-ready .scav-motion.is-in .scav-sectionHead h2{
  letter-spacing:.04em;
  transform:translateY(0);
}
.js-ready .scav-motion .scav-sectionHead p{
  opacity:.001;
  transform:translate3d(0,18px,0);
  transition:opacity .84s cubic-bezier(.22,1,.36,1) .20s, transform .96s cubic-bezier(.22,1,.36,1) .20s;
}
.js-ready .scav-motion.is-in .scav-sectionHead p{
  opacity:1;
  transform:none;
}

/* Rail and cards: reference-like delayed horizontal entrance */
.js-ready .scav-motion .scav-rail{
  opacity:.001!important;
  transform:translate3d(52px,38px,0) scale(.985)!important;
  filter:blur(5px)!important;
  transition:
    opacity .84s cubic-bezier(.22,1,.36,1) .20s,
    transform 1.08s cubic-bezier(.22,1,.36,1) .20s,
    filter 1.0s cubic-bezier(.22,1,.36,1) .20s!important;
}
.js-ready .scav-guide.scav-motion .scav-rail{
  transform:translate3d(-52px,38px,0) scale(.985)!important;
}
.js-ready .scav-motion.is-in .scav-rail{
  opacity:1!important;
  transform:translate3d(0,0,0) scale(1)!important;
  filter:blur(0)!important;
}
.js-ready .scav-motion .scav-card{
  opacity:.001;
  transform:translate3d(30px,22px,0) scale(.94);
  transition:opacity .72s cubic-bezier(.22,1,.36,1), transform .9s cubic-bezier(.22,1,.36,1);
}
.js-ready .scav-motion.is-in .scav-card{
  opacity:1;
  transform:translate3d(0,0,0) scale(1);
}
.js-ready .scav-motion.is-in .scav-rail__group:first-child .scav-card:nth-child(1){transition-delay:.26s;}
.js-ready .scav-motion.is-in .scav-rail__group:first-child .scav-card:nth-child(2){transition-delay:.34s;}
.js-ready .scav-motion.is-in .scav-rail__group:first-child .scav-card:nth-child(3){transition-delay:.42s;}
.js-ready .scav-motion.is-in .scav-rail__group:first-child .scav-card:nth-child(4){transition-delay:.50s;}

/* CTA appears last, like the reference sections. */
.js-ready .scav-motion > .scav-button,
.js-ready .scav-feature__inner > .scav-button{
  opacity:.001!important;
  transform:translate3d(0,26px,0) scale(.92)!important;
  transition:opacity .62s cubic-bezier(.22,1,.36,1) .48s, transform .86s cubic-bezier(.22,1,.36,1) .48s, box-shadow .25s ease, background .25s ease!important;
}
.js-ready .scav-motion.is-in > .scav-button,
.js-ready .scav-motion.is-in .scav-feature__inner > .scav-button{
  opacity:1!important;
  transform:translate3d(0,0,0) scale(1)!important;
}

/* Start auto rail only after the section enters the viewport. */
.scav-rail__track{animation-play-state:paused;}
.scav-motion.is-in .scav-rail__track{animation-play-state:running;}

@media (prefers-reduced-motion:reduce){
  .js-ready .scav-feature.scav-motion,
  .js-ready .scav-guide.scav-motion,
  .js-ready .scav-motion .scav-sectionHead,
  .js-ready .scav-motion .scav-rail,
  .js-ready .scav-motion .scav-card,
  .js-ready .scav-motion > .scav-button,
  .js-ready .scav-feature__inner > .scav-button{
    opacity:1!important;transform:none!important;filter:none!important;clip-path:none!important;transition:none!important;
  }
}

/* =========================================================
   Final requested fixes
   - Footer center alignment
   - Single close button when drawer is open
   - Article-first meta description display below section headings
   - Site title intro heading tuning
   ========================================================= */
body.home .sc-footer__top.sc-container,
body.front-page .sc-footer__top.sc-container{
  width:100%!important;
  max-width:none!important;
  margin:0!important;
  padding:0!important;
}
body.home .sc-footer__stack,
body.front-page .sc-footer__stack{
  width:min(420px,92vw)!important;
  margin:0 auto!important;
  text-align:center!important;
  align-items:center!important;
  justify-content:center!important;
}
body.home .sc-footer__brandLink,
body.front-page .sc-footer__brandLink{
  display:block!important;
  text-align:center!important;
  width:100%!important;
}
body.home .sc-footer__nav,
body.front-page .sc-footer__nav,
body.home .sc-footer__menu,
body.front-page .sc-footer__menu{
  width:min(300px,88vw)!important;
  margin:0 auto!important;
  padding:0!important;
  list-style:none!important;
  display:grid!important;
  justify-items:center!important;
}
body.home .sc-footer__item,
body.front-page .sc-footer__item{
  width:100%!important;
  margin:0!important;
  padding:0!important;
  list-style:none!important;
}
body.home .sc-footer__link,
body.front-page .sc-footer__link{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:100%!important;
  box-sizing:border-box!important;
}
body.home .sc-footer__bottomInner,
body.front-page .sc-footer__bottomInner{
  justify-content:center!important;
  text-align:center!important;
}

/* Drawer has its own close button. Hide the transformed header button to avoid double X. */
html.sc-menuOpen body.home .sc-header .sc-menuBtn,
html.sc-menuOpen body.front-page .sc-header .sc-menuBtn{
  opacity:0!important;
  pointer-events:none!important;
}

/* The blue heading under FV should be the site title, not split article copy. */
.scav-intro__headline{
  max-width:min(760px,92vw);
  word-break:keep-all;
  overflow-wrap:anywhere;
}
.scav-intro__headline span{
  display:block;
}

/* Section descriptions use the source article meta description. Show it fully. */
.scav-sectionHead p,
.scav-sectionHead--light p{
  max-width:38em!important;
  white-space:normal!important;
  overflow:visible!important;
  display:block!important;
  -webkit-line-clamp:unset!important;
  line-clamp:unset!important;
}

/* =========================================================
   Motion Stable fixes
   - Keep section-motion-fix page motion.
   - Remove the green preloader completely.
   - Prevent mobile jitter by excluding the horizontal rail and cards
     from section-level translate / scale / blur / clip-path effects.
   ========================================================= */
.scav-preloader,
[data-scav-preloader]{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
.js-ready .scav-motion .scav-rail,
.js-ready .scav-motion.is-in .scav-rail,
.js-ready .scav-guide.scav-motion .scav-rail,
.js-ready .scav-guide.scav-motion.is-in .scav-rail,
.js-ready .scav-feature.scav-motion .scav-rail,
.js-ready .scav-feature.scav-motion.is-in .scav-rail,
.js-ready .scav-motion .scav-card,
.js-ready .scav-motion.is-in .scav-card{
  opacity:1!important;
  transform:none!important;
  filter:none!important;
  clip-path:none!important;
  transition:none!important;
}
.scav-rail,
.scav-card{
  backface-visibility:hidden;
  transform-style:flat;
}
.scav-rail__track{
  will-change:transform;
  transform:translate3d(0,0,0);
}
/* Keep the original CSS marquee behavior. */
.scav-motion.is-in .scav-rail__track{
  animation-play-state:running;
}



/* =========================================================
   Manual rail control + slower auto movement
   - CSS animation remains the auto-scroll source.
   - The rail itself is horizontally scrollable for touch/drag users.
   - While the user interacts, auto movement pauses and then resumes.
   ========================================================= */
.scav-rail{
  overflow-x:auto!important;
  overflow-y:hidden!important;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior-x:contain;
  touch-action:pan-x pan-y;
  cursor:grab;
  scrollbar-width:none;
}
.scav-rail::-webkit-scrollbar{display:none;}
.scav-rail:active,
.scav-rail.is-user-scrolling{cursor:grabbing;}
.scav-rail__track{
  animation-duration:36s!important;
}
.scav-rail:hover .scav-rail__track,
.scav-rail:focus-within .scav-rail__track,
.scav-rail:active .scav-rail__track,
.scav-rail.is-user-scrolling .scav-rail__track{
  animation-play-state:paused!important;
}

/* =========================================================
   Header tap + section jitter final fixes
   - Do not change layout/design/article selection.
   - Re-enable pointer events that old HOME CSS disabled before scroll.
   - Keep section reveal as one-shot to prevent IO boundary re-trigger jitter.
   ========================================================= */
body.home .sc-header,
body.front-page .sc-header,
body.home .sc-header__inner,
body.front-page .sc-header__inner,
body.home .sc-brand,
body.front-page .sc-brand,
body.home .sc-brand__link,
body.front-page .sc-brand__link,
body.home .sc-menuBtn,
body.front-page .sc-menuBtn{
  pointer-events:auto!important;
}
body.home .sc-brand__link,
body.front-page .sc-brand__link,
body.home .sc-menuBtn,
body.front-page .sc-menuBtn{
  -webkit-tap-highlight-color:rgba(0,0,0,0);
  touch-action:manipulation;
}


/* =========================================================
   1.4.8 requested visual tuning only
   - Keep current structure/SITEcraft article selection/motion.
   - Change only labels, vertical editorial headings, layer strength,
     header/footer brand typography, and rail speed.
   ========================================================= */
.scav-heroNews__label{
  flex:0 0 auto;
  color:var(--scav-accent);
  font-weight:900;
  letter-spacing:.06em;
}

/* Top-left site name: article-page sized, serif, deep blue + gold, with ellipsis for long site names. */
body.home .sc-brand__link,
body.front-page .sc-brand__link{
  max-width:min(245px,calc(100vw - 96px))!important;
}
body.home .sc-brand__name,
body.front-page .sc-brand__name{
  max-width:100%!important;
  font-family:"Noto Serif JP","Yu Mincho","Hiragino Mincho ProN",serif!important;
  font-size:1.05rem!important;
  line-height:1.2!important;
  letter-spacing:.025em!important;
  font-weight:900!important;
  color:#0b2545!important;
  background:linear-gradient(90deg,#0b2545 0%,#0b2545 62%,#b58a2a 100%)!important;
  -webkit-background-clip:text!important;
  background-clip:text!important;
  -webkit-text-fill-color:transparent!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  text-shadow:none!important;
}

/* FV下：先頭記事タイトル + 冒頭文を縦書きにする。左=見出し、右=文章。 */
.scav-intro{
  padding:78px 0 68px;
}
.scav-intro__text{
  width:min(620px,100%);
  display:grid!important;
  grid-template-columns:auto auto;
  grid-template-areas:
    "title lead"
    "button button";
  justify-content:center!important;
  align-items:start!important;
  column-gap:26px!important;
  row-gap:26px!important;
  text-align:left!important;
}
.scav-intro__headline{
  grid-area:title;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  justify-self:end;
  max-height:18em;
  margin:0!important;
  color:var(--scav-accent)!important;
  font-size:clamp(22px,6.5vw,32px)!important;
  line-height:1.55!important;
  letter-spacing:.08em!important;
}
.scav-intro__headline span{
  display:block!important;
}
.scav-intro .scav-lead{
  grid-area:lead;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  justify-self:start;
  max-width:none!important;
  max-height:18em;
  color:#425c60;
  font-size:12px;
  line-height:2.05;
  letter-spacing:.06em;
}
.scav-intro .scav-button{
  grid-area:button;
  justify-self:center;
}

/* 厳選紹介・おすすめ：セクション説明を縦書きへ。新着は横書きのまま。 */
.scav-sectionHead--vertical{
  width:min(620px,100%)!important;
  display:grid!important;
  grid-template-columns:auto auto;
  grid-template-areas:"title lead";
  justify-content:center!important;
  align-items:start!important;
  column-gap:28px!important;
  text-align:left!important;
}
.scav-sectionHead--vertical h2{
  grid-area:title;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  justify-self:end;
  max-height:8.5em;
  font-size:clamp(28px,8.8vw,48px)!important;
  line-height:1.18!important;
  letter-spacing:.09em!important;
}
.scav-sectionHead--vertical p{
  grid-area:lead;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  justify-self:start;
  max-width:none!important;
  max-height:18em;
  font-size:12px!important;
  line-height:2.05!important;
  letter-spacing:.06em!important;
}

/* 背景レイヤーを薄くする：厳選紹介/新着のみ。 */
.scav-feature--green::before{opacity:.30!important;}
.scav-feature--green::after{background:linear-gradient(135deg,rgba(92,133,126,.74),rgba(61,92,86,.70))!important;}
.scav-feature--dark::before{opacity:.30!important;}
.scav-feature--dark::after{background:linear-gradient(135deg,rgba(35,47,45,.82),rgba(19,26,26,.84))!important;}
.js-ready .scav-feature.scav-motion.is-in::before{opacity:.30!important;}

/* 横スクロールを少し遅くする。 */
.scav-rail__track{
  animation-duration:44s!important;
}

/* Footer site name typography also follows the same brand treatment. */
body.home .sc-footer__siteName,
body.front-page .sc-footer__siteName{
  display:block!important;
  max-width:min(245px,84vw)!important;
  font-family:"Noto Serif JP","Yu Mincho","Hiragino Mincho ProN",serif!important;
  font-size:1.05rem!important;
  line-height:1.25!important;
  letter-spacing:.025em!important;
  font-weight:900!important;
  color:#0b2545!important;
  background:linear-gradient(90deg,#0b2545 0%,#0b2545 62%,#b58a2a 100%)!important;
  -webkit-background-clip:text!important;
  background-clip:text!important;
  -webkit-text-fill-color:transparent!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}

@media(min-width:768px){
  .scav-intro__text{column-gap:40px!important;}
  .scav-sectionHead--vertical{column-gap:42px!important;}
}
@media(max-width:390px){
  .scav-intro__text,
  .scav-sectionHead--vertical{column-gap:20px!important;}
  .scav-intro__headline{font-size:clamp(20px,6.1vw,27px)!important;}
  .scav-sectionHead--vertical h2{font-size:clamp(26px,8.3vw,40px)!important;}
}


/* =========================================================
   1.4.9 requested fine tuning only
   - Do not change article selection / layout outside requested points.
   ========================================================= */

/* Header brand: keep current design, make the title visibly heavier. */
body.home .sc-brand__name,
body.front-page .sc-brand__name{
  font-weight:950!important;
  -webkit-text-stroke:.22px rgba(11,37,69,.32);
  text-shadow:0 0 .01px rgba(11,37,69,.45)!important;
}

/* Vertical sections: right = heading, left = description. */
.scav-intro__text{
  grid-template-columns:auto auto!important;
  grid-template-areas:
    "lead title"
    "button button"!important;
}
.scav-sectionHead--vertical{
  grid-template-columns:auto auto!important;
  grid-template-areas:"lead title"!important;
}

/* Top intro title: article title should read as roughly three vertical lines. */
.scav-intro__headline{
  width:calc(1.55em * 3 + 6px)!important;
  max-width:calc(1.55em * 3 + 6px)!important;
  max-height:8.9em!important;
  overflow:visible!important;
  line-height:1.55!important;
  font-size:clamp(20px,5.75vw,28px)!important;
}
.scav-intro .scav-lead{
  max-height:17.5em!important;
}

/* Horizontal rails: a very small additional slowdown. */
.scav-rail__track{
  animation-duration:48s!important;
}

/* Requested: make selected background layers half as strong as the previous version. */
.scav-feature--green::before{opacity:.15!important;}
.scav-feature--green::after{background:linear-gradient(135deg,rgba(92,133,126,.37),rgba(61,92,86,.35))!important;}
.scav-feature--dark::before{opacity:.15!important;}
.scav-feature--dark::after{background:linear-gradient(135deg,rgba(35,47,45,.41),rgba(19,26,26,.42))!important;}
.js-ready .scav-feature.scav-motion.is-in::before{opacity:.15!important;}

/* Footer layer: front page also half as strong. */
body.home .sc-footer__top::before,
body.front-page .sc-footer__top::before{opacity:.13!important;}
body.home .sc-footer__top::after,
body.front-page .sc-footer__top::after{background:linear-gradient(to bottom,rgba(230,246,248,.35),rgba(199,232,236,.37))!important;}

@media(max-width:430px){
  .scav-intro__text{column-gap:18px!important;}
  .scav-sectionHead--vertical{column-gap:18px!important;}
  .scav-intro__headline{
    width:calc(1.52em * 3 + 4px)!important;
    max-width:calc(1.52em * 3 + 4px)!important;
    max-height:9.2em!important;
    font-size:clamp(19px,5.8vw,25px)!important;
  }
}

/* =========================================================
   1.4.10 requested layer lightening only
   - 厳選紹介・新着記事セクションの背景色レイヤーだけをさらに薄くする。
   - Other layout / motion / SITEcraft article selection is untouched.
   ========================================================= */
.scav-feature--green::before,
.js-ready .scav-feature--green.scav-motion.is-in::before{opacity:.07!important;}
.scav-feature--green::after,
.js-ready .scav-feature--green.scav-motion.is-in::after{background:linear-gradient(135deg,rgba(92,133,126,.20),rgba(61,92,86,.18))!important;}
.scav-feature--dark::before,
.js-ready .scav-feature--dark.scav-motion.is-in::before{opacity:.07!important;}
.scav-feature--dark::after,
.js-ready .scav-feature--dark.scav-motion.is-in::after{background:linear-gradient(135deg,rgba(35,47,45,.23),rgba(19,26,26,.22))!important;}


/* =========================================================
   1.4.11 requested layer 30% only
   - 厳選紹介・新着記事セクションの背景色レイヤーを、現状を100%とした場合の約30%まで薄くする。
   - Other layout / motion / SITEcraft article selection is untouched.
   ========================================================= */
.scav-feature--green{
  background:#b6d2cc!important;
}
.scav-feature--green::before,
.js-ready .scav-feature--green.scav-motion.is-in::before{
  opacity:.26!important;
}
.scav-feature--green::after,
.js-ready .scav-feature--green.scav-motion.is-in::after{
  background:linear-gradient(135deg,rgba(92,133,126,.060),rgba(61,92,86,.054))!important;
}
.scav-feature--dark{
  background:#5f6b68!important;
}
.scav-feature--dark::before,
.js-ready .scav-feature--dark.scav-motion.is-in::before{
  opacity:.24!important;
}
.scav-feature--dark::after,
.js-ready .scav-feature--dark.scav-motion.is-in::after{
  background:linear-gradient(135deg,rgba(35,47,45,.069),rgba(19,26,26,.066))!important;
}

/* =========================================================
   1.4.12 requested background correction only
   - Do not brighten the feature sections.
   - Keep the thin color layer, but return the section base colors to the previous dark/green tone.
   - Background images are now supplied per section from the article used for that section text.
   ========================================================= */
.scav-feature--green{
  background:#739890!important;
}
.scav-feature--dark{
  background:#232d2b!important;
}
.scav-feature--green::before,
.js-ready .scav-feature--green.scav-motion.is-in::before{
  opacity:.26!important;
}
.scav-feature--green::after,
.js-ready .scav-feature--green.scav-motion.is-in::after{
  background:linear-gradient(135deg,rgba(92,133,126,.060),rgba(61,92,86,.054))!important;
}
.scav-feature--dark::before,
.js-ready .scav-feature--dark.scav-motion.is-in::before{
  opacity:.24!important;
}
.scav-feature--dark::after,
.js-ready .scav-feature--dark.scav-motion.is-in::after{
  background:linear-gradient(135deg,rgba(35,47,45,.069),rgba(19,26,26,.066))!important;
}

/* =========================================================
   1.4.13 requested footer layer only
   - Front page footer overlay also uses a very thin black layer.
   ========================================================= */
body.home .sc-footer__top::after,
body.front-page .sc-footer__top::after{
  background:linear-gradient(to bottom,rgba(0,0,0,.08),rgba(0,0,0,.10))!important;
}
