/*
Theme Name: S-passo
Theme URI: https://s-passo.jp/
Author: S-passo
Description: 自立型Web制作スタジオ「S-passo」のためのWordPressテーマ。余白を大きく取ったミニマルな構成、モノクロ＋アクセント1色、英字セクションラベルと番号で構成する編集的なレイアウト。全文字・全画像はカスタマイザーで編集でき、有効化時に主要ページを自動生成します。ACF不要、モバイル完全対応。
Version: 3.15.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: spasso
*/

/* ============================================================
   0. Design Tokens
   ============================================================ */
:root{
  --ink:#15161a;          /* 主要テキスト・ほぼ黒 */
  --ink-2:#56585f;        /* 副次テキスト */
  --ink-3:#6a6c73;        /* 補助・キャプション（AA相当までコントラスト確保） */
  --paper:#f4f2ec;        /* 背景・温かみのあるオフホワイト */
  --paper-2:#ffffff;      /* コントラスト面 */
  --line:#e2ded3;         /* 紙面上のヘアライン */
  --line-2:#cfcabd;       /* やや濃いヘアライン */
  --accent:#d8442e;       /* アクセント1色（カスタマイザーで変更可・朱赤＝雑誌特集/和の編集調） */
  --accent-ink:#ffffff;   /* アクセント上の文字 */

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --radius:0px;           /* 角は立てる（編集的・非AI的） */

  --ff-jp:"Zen Kaku Gothic New","Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  --ff-lat:"Space Grotesk","Zen Kaku Gothic New",sans-serif;
  --ff-head:"Shippori Mincho","Zen Kaku Gothic New",serif;

  --t-fast:.25s cubic-bezier(.22,1,.36,1);
  --t-mid:.5s cubic-bezier(.22,1,.36,1);
  --t-slow:.9s cubic-bezier(.22,1,.36,1);
}

/* ============================================================
   1. Reset / Base
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--ff-jp);
  font-weight:400;
  line-height:1.85;
  letter-spacing:.02em;
  font-feature-settings:"palt" 1;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:0;background:none;}
ul,ol{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4,p,figure{margin:0;}
::selection{background:var(--accent);color:var(--accent-ink);}

/* ============================================================
   2. Layout primitives
   ============================================================ */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.wrap--narrow{max-width:920px;}
.faq__more{margin-top:clamp(28px,4vw,44px);text-align:center;}
.section--faq-page .faq{margin-top:0;margin-inline:auto;}
/* 予約フォームをページ見出し直下にぴったり寄せる（見出しの下余白を相殺） */
/* 全セクションページで、ヒーロー直後の本文開始位置（文頭）を統一＋少し余白 */
.page-hero + .section{padding-top:clamp(40px,4vw,60px);}
.section{padding-block:clamp(72px,11vw,168px);}
.section--tight{padding-block:clamp(56px,8vw,104px);}

/* セクション見出しブロック（英字ラベル＋番号＋大見出し） */
.eyebrow{
  font-family:var(--ff-lat);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--ink-2);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;
  background:var(--accent);
  display:inline-block;
}
.sec-no{
  font-family:var(--ff-lat);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.2em;
  color:var(--ink-3);
}
.sec-head{
  font-weight:700;
  font-size:clamp(1.9rem,4.6vw,3.4rem);
  line-height:1.28;
  letter-spacing:.01em;
}
.sec-head .em{color:var(--accent);}
.lead{
  color:var(--ink-2);
  font-size:clamp(1.05rem,1.5vw,1.22rem);
  line-height:2;
  max-width:42em;
}

/* リンク矢印 */
.arrow-link{
  display:inline-flex;align-items:center;gap:.85em;
  font-family:var(--ff-lat);
  font-weight:600;
  font-size:.82rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding-block:.6em;
  border-bottom:1px solid var(--ink);
  transition:gap var(--t-fast),border-color var(--t-fast),color var(--t-fast);
}
.arrow-link .ar{transition:transform var(--t-fast);}
.arrow-link:hover{gap:1.3em;color:var(--accent);border-color:var(--accent);}
.arrow-link:hover .ar{transform:translateX(4px);}

/* ボタン（下から色がせり上がるフィルアップ演出） */
.btn{
  display:inline-flex;align-items:center;gap:.8em;
  font-family:var(--ff-lat);
  font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
  padding:1.05em 1.9em;
  color:var(--paper);
  background-color:var(--ink);
  background-image:linear-gradient(var(--fill,var(--accent)),var(--fill,var(--accent)));
  background-repeat:no-repeat;
  background-position:50% 100%;
  background-size:100% 0%;
  transition:background-size .45s cubic-bezier(.22,1,.36,1),color var(--t-fast),transform var(--t-fast),border-color var(--t-fast);
}
.btn .ar{transition:transform var(--t-fast);}
.btn:hover{background-size:100% 100%;transform:translateY(-2px);}
.btn:hover .ar{transform:translateX(4px);}
.btn--accent{background-color:var(--accent);color:var(--accent-ink);--fill:var(--ink);}
.btn--accent:hover{color:var(--paper);}
.btn--ghost{background-color:transparent;color:var(--ink);border:1px solid var(--line-2);--fill:var(--ink);}
.btn--ghost:hover{color:var(--paper);border-color:var(--ink);}

/* ============================================================
   3. Header
   ============================================================ */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(16px,2.2vw,26px) var(--gutter);
  transition:background var(--t-mid),box-shadow var(--t-mid),padding var(--t-mid);
}
.site-header.is-solid{
  background:rgba(244,242,236,.9);
  background:color-mix(in srgb,var(--paper) 88%,transparent);
  backdrop-filter:saturate(140%) blur(10px);
  box-shadow:0 1px 0 var(--line);
  padding-block:14px;
}
.brand .custom-logo,.site-header .custom-logo{max-height:34px;width:auto;}
.brand{
  display:inline-flex;align-items:center;color:var(--ink);
}
/* インラインSVGロゴ */
.sp-logo{height:23px;width:auto;display:block;}
.sp-logo .b{fill:currentColor;}
.sp-logo .b-acc{fill:var(--accent);}
.sp-logo .wm{fill:currentColor;font-family:"Space Grotesk",sans-serif;font-weight:800;font-size:31px;letter-spacing:-.5px;}
.footer-brand .sp-logo{height:30px;}

.nav{display:flex;align-items:center;gap:clamp(20px,2.4vw,40px);}
.nav__menu{display:flex;align-items:center;gap:clamp(18px,2vw,34px);}
.nav__menu a{
  font-size:.86rem;font-weight:500;letter-spacing:.06em;position:relative;
  padding-block:.3em;
}
.nav__menu a::after{
  content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--accent);
  transition:width var(--t-fast);
}
.nav__menu a:hover::after,.nav__menu .current-menu-item>a::after{width:100%;}
.nav__cta{padding:.75em 1.4em;font-size:.78rem;}

.nav-toggle{display:none;width:30px;height:18px;position:relative;}
.nav-toggle span{position:absolute;left:0;width:100%;height:1.6px;background:var(--ink);transition:transform var(--t-fast),opacity var(--t-fast);}
.nav-toggle span:nth-child(1){top:0;}
.nav-toggle span:nth-child(2){top:50%;transform:translateY(-50%);}
.nav-toggle span:nth-child(3){bottom:0;}
.nav-toggle.is-active span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg);}
.nav-toggle.is-active span:nth-child(2){opacity:0;}
.nav-toggle.is-active span:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg);}
.nav-open .site-header .brand{color:#fff;}
.nav-open .nav-toggle span{background:#fff;}

/* 上部が暗いビュー：スクロール前のヘッダーを白文字に */
.sp-dark-top .site-header:not(.is-solid) .brand{color:#fff;}
.sp-dark-top .site-header:not(.is-solid) .nav__menu a{color:#fff;}
.sp-dark-top .site-header:not(.is-solid) .nav-toggle span{background:#fff;}

/* ヘッダー電話（制作会社らしい導線） */
.header-tel{display:flex;flex-direction:column;align-items:flex-end;line-height:1.15;text-align:right;margin-right:6px;}
.header-tel__label{font-size:.62rem;letter-spacing:.08em;color:var(--ink-3);}
.header-tel__num{font-family:var(--ff-lat);font-weight:800;font-size:1.18rem;letter-spacing:.01em;color:var(--ink);transition:color var(--t-fast);}
.header-tel:hover .header-tel__num{color:var(--accent);}
.sp-dark-top .site-header:not(.is-solid) .header-tel__num{color:#fff;}
.sp-dark-top .site-header:not(.is-solid) .header-tel__label{color:rgba(255,255,255,.7);}
@media (max-width:1200px){.header-tel{display:none;}}

/* モバイルメニュー */
.mobile-nav__backdrop{
  position:fixed;inset:0;z-index:98;
  background:rgba(12,13,16,.5);backdrop-filter:saturate(120%) blur(2px);
  opacity:0;visibility:hidden;transition:opacity var(--t-mid),visibility var(--t-mid);
}
.mobile-nav__backdrop[hidden]{display:none;}
body.nav-open .mobile-nav__backdrop{opacity:1;visibility:visible;}
.mobile-nav{
  position:fixed;top:0;right:0;bottom:0;left:auto;z-index:99;
  width:min(88%,400px);
  background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;justify-content:flex-start;
  padding:calc(var(--gutter) + 64px) var(--gutter) var(--gutter);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  transform:translateX(100%);
  transition:transform var(--t-mid);
  visibility:hidden;
  box-shadow:-30px 0 80px -40px rgba(0,0,0,.6);
}
.mobile-nav.is-open{transform:translateX(0);visibility:visible;}
body.nav-open .site-header{z-index:101;}
.mobile-nav a{display:block;}
.mobile-nav__menu{margin-bottom:8px;}
.mobile-nav__menu li{overflow:hidden;border-bottom:1px solid rgba(255,255,255,.1);}
.mobile-nav__menu a{
  font-size:clamp(1.15rem,5.4vw,1.5rem);font-weight:700;line-height:1.4;letter-spacing:.01em;
  padding:.7em 0;
  transform:translateY(110%);transition:transform .5s cubic-bezier(.22,1,.36,1);
}
.mobile-nav.is-open .mobile-nav__menu a{transform:translateY(0);}
.mobile-nav__menu .num{font-family:var(--ff-lat);font-size:.72rem;color:var(--accent);letter-spacing:.2em;margin-right:.8em;font-weight:600;}
.mobile-nav__foot{margin-top:auto;padding-top:32px;display:flex;gap:20px;flex-wrap:wrap;font-family:var(--ff-lat);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);}
.mobile-nav__foot a:hover{color:var(--paper);}
.mobile-nav__tel{flex:1 0 100%;font-family:var(--ff-lat);font-weight:800;font-size:1.5rem;letter-spacing:.01em;text-transform:none;color:var(--paper);}
.mobile-nav__hours{flex:1 0 100%;text-transform:none;letter-spacing:.03em;color:rgba(255,255,255,.6);font-size:.82rem;margin-top:-.6em;}
.mobile-nav__contact{flex:1 0 100%;justify-content:center;margin:.6em 0 .4em;text-transform:none;letter-spacing:.04em;color:var(--paper);}

/* ============================================================
   4. Hero
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--gutter) clamp(40px,6vw,72px);
  overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:-2;}
.hero__bg img,.hero__bg video{width:100%;height:100%;object-fit:cover;}
.hero__bg.has-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18),rgba(0,0,0,.42));}
.hero.has-media{color:var(--paper);}
.hero.has-media .hero__eyebrow{color:rgba(255,255,255,.82);}
.hero.has-media .hero__sub{color:rgba(255,255,255,.88);text-shadow:0 1px 24px rgba(0,0,0,.45);}
.hero.has-media .hero__title{text-shadow:0 2px 50px rgba(0,0,0,.4);}

.hero__top{position:absolute;top:0;left:0;right:0;padding:clamp(96px,13vw,150px) var(--gutter) 0;
  display:flex;justify-content:space-between;align-items:flex-start;gap:24px;}
.hero__index{font-family:var(--ff-lat);font-size:.74rem;letter-spacing:.2em;color:var(--ink-3);text-transform:uppercase;text-align:right;line-height:2.1;}
.hero.has-media .hero__index{color:rgba(255,255,255,.7);}

.hero__inner{max-width:var(--maxw);width:100%;margin-inline:auto;}
.hero__eyebrow{
  font-family:var(--ff-lat);font-size:.74rem;font-weight:600;letter-spacing:.34em;
  text-transform:uppercase;color:var(--ink-2);margin-bottom:1.6em;display:flex;align-items:center;gap:.8em;
}
.hero__eyebrow::before{content:"";width:34px;height:1px;background:var(--accent);}
.hero__eyebrow--m{display:none;}
.hero__title{
  font-weight:700;
  font-size:clamp(2.6rem,9vw,6.4rem);
  line-height:1.12;
  letter-spacing:.005em;
}
.hero__title .em{color:var(--accent);}
.hero.has-media .hero__title .em{color:#fff;text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:.12em;text-decoration-thickness:.08em;}

/* キネティック：行マスクで立ち上げ */
.hero__title.is-kinetic .ln{display:block;overflow:hidden;padding-block:.02em;}
.hero__title.is-kinetic .ln__i{display:inline-block;transform:translateY(115%);animation:lineUp .95s cubic-bezier(.19,1,.22,1) forwards;}
.hero__title.is-kinetic .ln:nth-child(1) .ln__i{animation-delay:.12s;}
.hero__title.is-kinetic .ln:nth-child(2) .ln__i{animation-delay:.26s;}
.hero__title.is-kinetic .ln:nth-child(3) .ln__i{animation-delay:.40s;}
@keyframes lineUp{to{transform:translateY(0);}}

/* 背景のゆっくりとしたドリフト（Ken Burns） */
.hero__bg img{animation:kenburns 18s ease-in-out infinite alternate;transform-origin:60% 40%;will-change:transform;}
@keyframes kenburns{0%{transform:scale(1.04) translate(0,0);}100%{transform:scale(1.13) translate(-1.5%,-1.5%);}}

/* 回転ワード */
.hero__rotator{margin-top:1.6em;display:flex;align-items:baseline;gap:.5em;flex-wrap:wrap;font-weight:700;font-size:clamp(1.05rem,2.4vw,1.7rem);letter-spacing:.02em;}
.hero__rotator-label{font-family:var(--ff-lat);font-size:.7em;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);}
.hero.has-media .hero__rotator-label{color:color-mix(in srgb,var(--accent) 58%,#fff);}
.rotator{position:relative;display:inline-block;min-width:7em;}
.rotator__word{display:inline-block;color:var(--accent);transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .4s;}
.hero.has-media .rotator__word{color:#fff;border-bottom:2px solid var(--accent);}
.rotator__word.is-out{transform:translateY(-60%);opacity:0;}
.rotator__word.is-in-word{animation:wordIn .5s cubic-bezier(.22,1,.36,1);}
@keyframes wordIn{from{transform:translateY(60%);opacity:0;}to{transform:translateY(0);opacity:1;}}
.hero__rotator-tail{color:inherit;}

@media (prefers-reduced-motion:reduce){
  .hero__title.is-kinetic .ln__i{transform:none;animation:none;}
  .hero__bg img{animation:none;}
}
.hero__sub{margin-top:1.8em;max-width:38em;color:var(--ink-2);font-size:clamp(.98rem,1.5vw,1.16rem);line-height:2.1;}
.hero__actions{margin-top:2.6em;display:flex;flex-wrap:wrap;gap:16px;}
.hero__scroll{
  position:absolute;right:var(--gutter);bottom:clamp(40px,6vw,72px);
  font-family:var(--ff-lat);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;
  writing-mode:vertical-rl;display:flex;align-items:center;gap:14px;color:var(--ink-3);
}
.hero.has-media .hero__scroll{color:rgba(255,255,255,.75);}
.hero__scroll::after{content:"";width:1px;height:54px;background:currentColor;animation:scrollline 2.2s ease-in-out infinite;transform-origin:top;}
@keyframes scrollline{0%,100%{transform:scaleY(.35);opacity:.4;}50%{transform:scaleY(1);opacity:1;}}

/* ============================================================
   4b. Hero ショーケース（動くデモサイト）
   ============================================================ */
.hero--showcase{justify-content:center;padding-top:clamp(112px,14vh,150px);padding-bottom:clamp(40px,6vw,64px);}
.hero--showcase .hero__index{display:none;}
.hero__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.02fr);gap:clamp(28px,5vw,72px);align-items:center;width:100%;max-width:var(--maxw);margin-inline:auto;}
.hero--showcase .hero__title{font-size:clamp(1.95rem,3.4vw,3.1rem);line-height:1.22;letter-spacing:0;}
.hero--showcase .hero__sub{max-width:26em;font-size:clamp(1rem,1.3vw,1.12rem);}
.hero__col-demo{height:min(76vh,660px);position:relative;}

/* Studio風 大きめCTA（丸い矢印アイコン付き） */
.btn--hero{padding:1.05em 1.05em 1.05em 1.9em;font-size:.92rem;gap:1.05em;}
.btn--hero .btn__t{position:relative;z-index:1;}
.btn__ico{width:2.1em;height:2.1em;flex:none;border-radius:50%;display:grid;place-items:center;font-size:1em;line-height:1;
  background:rgba(255,255,255,.2);transition:transform var(--t-fast),background var(--t-fast);position:relative;z-index:1;}
.btn--accent.btn--hero .btn__ico{background:#fff;color:var(--accent);}
.btn--ghost.btn--hero .btn__ico{background:rgba(255,255,255,.16);color:#fff;}
.btn--hero:hover .btn__ico{transform:translateX(3px);}

.demo-stack{height:100%;}
.demo-cols{display:flex;gap:20px;justify-content:center;height:100%;}
.demo-col{width:300px;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 9%,#000 91%,transparent 100%);
  mask-image:linear-gradient(180deg,transparent 0,#000 9%,#000 91%,transparent 100%);}
.demo-col--b{margin-top:64px;}
.demo-track{display:flex;flex-direction:column;gap:20px;animation:vscroll 34s linear infinite;will-change:transform;}
.demo-col--b .demo-track{animation-duration:46s;animation-direction:reverse;}
.demo-stack:hover .demo-track{animation-play-state:paused;}
.demo-col--c{margin-top:32px;}
.demo-col--c .demo-track{animation-duration:40s;}
.section--demos{overflow:hidden;}
.demos-stage{height:clamp(440px,60vh,620px);margin-top:clamp(34px,5vw,58px);position:relative;}
.demos-stage:hover .demo-track{animation-play-state:paused;}
.demos-stage .demo-cols{height:100%;}
@keyframes vscroll{from{transform:translateY(0);}to{transform:translateY(-50%);}}

/* ブラウザ枠 */
.browser{width:300px;flex:none;border-radius:14px;overflow:hidden;background:#fff;
  box-shadow:0 32px 64px -32px rgba(6,8,20,.8);border:1px solid rgba(255,255,255,.06);}
.browser__bar{height:34px;background:#ededf0;display:flex;align-items:center;gap:6px;padding:0 12px;}
.browser__bar i{width:9px;height:9px;border-radius:50%;background:#cfcfd6;flex:none;}
.browser__bar i:nth-child(1){background:#ff5f57;}
.browser__bar i:nth-child(2){background:#febc2e;}
.browser__bar i:nth-child(3){background:#28c840;}
.browser__url{margin-left:8px;height:16px;flex:1;max-width:62%;background:#dcdce1;border-radius:8px;}
.browser__view{height:452px;overflow:hidden;background:#fff;}
.mini-scale{width:1000px;transform:scale(.30);transform-origin:top left;}

/* ミニ完成サイト（1000px設計をスケール表示） */
.mini{width:1000px;background:#fff;color:#16171c;font-family:var(--ff-jp);}
.mini--dark{background:#0f1118;color:#fff;}
.mini--cream{background:#f3efe6;color:#1d1a15;}
.m-nav{display:flex;align-items:center;justify-content:space-between;padding:36px 48px;}
.m-logo{font-family:var(--ff-lat);font-weight:800;font-size:36px;display:inline-flex;align-items:center;gap:9px;}
.m-logo em{width:13px;height:13px;border-radius:50%;background:#16171c;display:inline-block;}
.mini--dark .m-logo em{background:#fff;}
.m-logo em.acc{background:var(--accent);}
.m-nav-links{display:flex;gap:30px;font-size:22px;font-weight:500;opacity:.7;}
.m-nav-cta{font-family:var(--ff-lat);font-weight:700;font-size:21px;background:#16171c;color:#fff;padding:14px 30px;border-radius:999px;}
.mini--dark .m-nav-cta{background:#fff;color:#0f1118;}
.m-nav-cta.acc{background:var(--accent);color:#fff;}
.m-sec{padding:32px 48px;}
.m-hero{padding:48px;}
.m-eyebrow{font-family:var(--ff-lat);font-weight:700;font-size:20px;letter-spacing:3px;text-transform:uppercase;opacity:.5;}
.m-eyebrow.acc{color:var(--accent);opacity:1;}
.m-h1{font-weight:800;font-size:88px;line-height:1.06;letter-spacing:-1.5px;margin:24px 0;}
.m-mark{color:var(--accent);}
.m-mark.acc{color:var(--accent);}
.m-sub{font-size:27px;line-height:1.7;opacity:.6;max-width:17em;}
.m-actions{display:flex;gap:18px;margin-top:36px;}
.m-btn{font-family:var(--ff-lat);font-weight:700;font-size:23px;background:#16171c;color:#fff;padding:19px 38px;border-radius:999px;}
.m-btn.warm{background:#7a4a2b;}
.m-btn-o{font-family:var(--ff-lat);font-weight:700;font-size:23px;padding:19px 38px;border-radius:999px;border:2px solid rgba(0,0,0,.16);}
.m-img{height:330px;margin:12px 48px 0;border-radius:20px;background:linear-gradient(135deg,#23252e,#565b6e);}
.m-img--mono{background:linear-gradient(135deg,#262932,#5a6072);}
.m-img--acc{height:300px;margin:36px 48px;background:linear-gradient(135deg,#1f3bff,#0a1130);}
.m-img--warm{height:380px;margin:0;border-radius:0;background:linear-gradient(135deg,#c9a079,#7a4a2b);display:flex;align-items:flex-end;padding:46px;}
.m-imgh{color:#fff;font-weight:800;font-size:78px;line-height:1.04;letter-spacing:-1px;}
.m-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.m-grid2{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.m-card{height:210px;border-radius:16px;background:#f0f0f3;}
.m-card.d{background:#191c26;}
.m-stats{display:flex;gap:54px;margin-top:34px;}
.m-stat b{font-size:62px;font-weight:800;line-height:1;}
.m-stat u{display:block;text-decoration:none;font-size:21px;opacity:.55;margin-top:8px;}
.m-list{padding-top:8px;padding-bottom:8px;}
.m-list-row{display:flex;justify-content:space-between;align-items:center;font-size:31px;padding:28px 0;border-bottom:1px solid rgba(0,0,0,.1);}
.m-list-row b{font-family:var(--ff-lat);}
.m-foot{display:flex;justify-content:space-between;padding:40px 48px;font-size:21px;opacity:.5;font-family:var(--ff-lat);}

@media (prefers-reduced-motion:reduce){
  .demo-track{animation:none;}
}

/* マーキー（クライアント/キーワード帯） */
.marquee{border-block:1px solid var(--line);overflow:hidden;padding-block:18px;background:var(--paper);}
.marquee__track{display:flex;gap:3.5rem;white-space:nowrap;width:max-content;animation:marquee 32s linear infinite;}
.marquee:hover .marquee__track{animation-play-state:paused;}
.marquee__item{font-family:var(--ff-lat);font-weight:600;font-size:1rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);display:inline-flex;align-items:center;gap:3.5rem;}
.marquee__item::after{content:"✳";color:var(--accent);font-size:.8em;}
@keyframes marquee{to{transform:translateX(-50%);}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none;}}

/* ============================================================
   5. Statement（実体は「18. ステートメント帯」に統合済み）
   ============================================================ */

/* ============================================================
   6. Services
   ============================================================ */
.section--services{background:var(--paper-2);}
.head-row{display:grid;grid-template-columns:1fr;gap:1.4rem;margin-bottom:clamp(40px,5vw,72px);}
/* 見出しフォント（編集的な明朝） */
.sec-head,.hero__title,.cta__title,.statement__head,.page-hero__ja,.feature-svc__ja,.svc__title,.svc-card__ja,.hp-feat__title,.reason__title,.about-split__body .sec-head{font-family:var(--ff-head);}
/* 制作実績：横スクロール（カルーセル） */
.works-scroller{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(280px,calc(33.333% - 24px));gap:clamp(20px,2.4vw,36px);overflow-x:auto;overflow-y:hidden;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;padding-bottom:20px;scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;}
.works-scroller>.work-card{scroll-snap-align:start;}
.works-scroller::-webkit-scrollbar{height:6px;}
.works-scroller::-webkit-scrollbar-thumb{background:var(--line-2);}
.works-scroller::-webkit-scrollbar-track{background:transparent;}
@media (max-width:860px){.works-scroller{grid-auto-columns:minmax(240px,72%);}}
/* ホームページ制作：特徴の罫線グリッド */
.hp-feats{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line);border-left:1px solid var(--line);margin-top:clamp(28px,3.5vw,48px);}
.hp-feat{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(26px,3vw,44px);}
.hp-feat__no{font-family:var(--ff-lat);font-size:.8rem;font-weight:600;letter-spacing:.14em;color:var(--accent);}
.hp-feat__title{font-weight:700;font-size:clamp(1.18rem,2vw,1.5rem);line-height:1.5;margin:.55em 0 .5em;}
.hp-feat__desc{color:var(--ink-2);font-size:.97rem;line-height:1.95;}
@media (max-width:680px){.hp-feats{grid-template-columns:1fr;}}
/* 数値バンド（得られる理由ページ） */
.stat-band{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);}
.stat{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(28px,4vw,52px);text-align:center;}
.stat__num{display:block;font-family:var(--ff-head);font-weight:700;font-size:clamp(2rem,4vw,3.2rem);line-height:1.12;color:var(--accent);}
.stat__label{display:block;margin-top:.7em;color:var(--ink-2);font-size:.92rem;letter-spacing:.02em;}
@media (max-width:680px){.stat-band{grid-template-columns:1fr;}}
/* 制作プラン：3プランカード */
.plan-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px);}
.plan-card{position:relative;border:1px solid var(--line);background:var(--paper-2);padding:clamp(26px,2.6vw,38px);display:flex;flex-direction:column;}
.plan-card--feature{border-color:var(--accent);box-shadow:0 24px 60px -34px color-mix(in srgb,var(--accent) 50%,transparent);}
.plan-card__pick{position:absolute;top:-1px;right:-1px;background:var(--accent);color:#fff;font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.1em;padding:.5em 1em;}
.plan-card__name{font-family:var(--ff-lat);font-weight:600;letter-spacing:.04em;color:var(--ink-2);font-size:.95rem;}
.plan-card__price{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.6rem,2.6vw,2.2rem);line-height:1.2;margin:.3em 0 .2em;}
.plan-card__tag{color:var(--accent);font-size:.86rem;font-weight:600;}
.plan-card__spec{margin:1.4em 0;border-top:1px solid var(--line);}
.plan-card__row{display:flex;justify-content:space-between;gap:12px;padding:.7em 0;border-bottom:1px solid var(--line);font-size:.9rem;}
.plan-card__row dt{color:var(--ink-3);}
.plan-card__row dd{font-weight:600;text-align:right;}
.plan-card__btn{margin-top:auto;justify-content:center;}
.plan-note{margin-top:1.6em;color:var(--ink-3);font-size:.84rem;line-height:1.8;}
@media (max-width:860px){.plan-cards{grid-template-columns:1fr;}}
/* 悩み解決カード */
.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);}
.problem{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(24px,2.6vw,38px);}
.problem__q{display:flex;gap:.6em;font-family:var(--ff-head);font-weight:700;font-size:clamp(1.05rem,1.6vw,1.2rem);line-height:1.5;}
.problem__qmark{font-family:var(--ff-lat);color:var(--accent);font-weight:700;}
.problem__a{margin-top:.9em;color:var(--ink-2);font-size:.94rem;line-height:1.95;}
@media (max-width:860px){.problem-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:560px){.problem-grid{grid-template-columns:1fr;}}
/* お問い合わせ：3つのCTA */
.contact-trio{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line);}
.ctrio{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(28px,3vw,44px);display:flex;flex-direction:column;gap:.5em;}
.ctrio__en{font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);}
.ctrio__title{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.15rem,1.8vw,1.4rem);}
.ctrio__lead{color:var(--ink-2);font-size:.92rem;line-height:1.9;}
.ctrio__tel{font-family:var(--ff-lat);font-weight:700;font-size:clamp(1.5rem,2.4vw,2rem);letter-spacing:.01em;color:var(--ink);}
.ctrio__hours{color:var(--ink-3);font-size:.84rem;}
.ctrio .arrow-link{margin-top:auto;}
@media (max-width:860px){.contact-trio{grid-template-columns:1fr;}}
/* 採用バンド */
.recruit{display:flex;align-items:center;justify-content:space-between;gap:clamp(24px,4vw,56px);flex-wrap:wrap;border:1px solid var(--line);padding:clamp(32px,4vw,56px);}
.recruit__body{flex:1 1 320px;}
.recruit__body .sec-head{margin:.3em 0;}
/* 制作の流れ：左に写真・右に文章 */
.flow-steps{list-style:none;display:flex;flex-direction:column;gap:clamp(56px,8vw,110px);}
.flow-step{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;}
.flow-step__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--line);border:1px solid var(--line);}
.flow-step__media img{width:100%;height:100%;object-fit:cover;}
.flow-step__no{position:absolute;left:0;bottom:0;background:var(--accent);color:#fff;font-family:var(--ff-lat);font-weight:700;font-size:.92rem;letter-spacing:.22em;padding:.65em 1.25em;}
.flow-step__title{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.35rem,2.4vw,1.95rem);line-height:1.5;letter-spacing:.01em;margin-bottom:.55em;}
.flow-step__desc{color:var(--ink-2);line-height:2;}
@media (max-width:760px){.flow-step{grid-template-columns:1fr;gap:18px;}}
/* 比較表（プラン・他社一般比較） */
.cmp-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);}
.cmp-table{width:100%;border-collapse:collapse;min-width:600px;}
.cmp-table th,.cmp-table td{border-bottom:1px solid var(--line);border-right:1px solid var(--line);padding:clamp(14px,1.5vw,20px) clamp(14px,1.7vw,22px);text-align:center;vertical-align:middle;font-size:.95rem;}
.cmp-table tr>*:last-child{border-right:0;}
.cmp-table thead th{vertical-align:bottom;background:var(--paper);border-bottom:2px solid var(--line-2);}
.cmp-table tbody th{position:sticky;left:0;z-index:1;text-align:left;color:var(--ink-3);font-weight:600;white-space:nowrap;background:var(--paper);}
.cmp-table tbody tr:nth-child(even) td{background:color-mix(in srgb,var(--ink) 2.5%,transparent);}
.cmp-table td{font-weight:600;color:var(--ink);}
.cmp-name{display:block;font-family:var(--ff-lat);font-weight:600;color:var(--ink-2);font-size:.84rem;letter-spacing:.06em;text-transform:uppercase;}
.cmp-price{display:block;font-family:var(--ff-head);font-weight:700;font-size:clamp(1.35rem,2.2vw,1.9rem);line-height:1.15;margin:.25em 0;}
.cmp-tag{display:block;color:var(--ink-3);font-size:.8rem;font-weight:600;}
.cmp-table .is-pick{background:color-mix(in srgb,var(--accent) 8%,transparent) !important;}
.cmp-table thead th.is-pick{position:relative;border-top:3px solid var(--accent);border-bottom-color:var(--accent);padding-top:2.8em;}
.cmp-table thead th.is-pick .cmp-price{color:var(--accent);}
.cmp-table thead th.is-pick .cmp-tag{color:var(--accent);}
.cmp-table thead th.is-pick::before{content:"おすすめ";position:absolute;top:0;left:0;right:0;background:var(--accent);color:#fff;font-family:var(--ff-lat);font-size:.7rem;font-weight:600;letter-spacing:.12em;padding:.45em 0;}
.cmp-cta-row td{padding-top:clamp(16px,1.8vw,22px);padding-bottom:clamp(16px,1.8vw,22px);}
.cmp-cta-row .arrow-link{justify-content:center;}
.cmp-table--vs{min-width:480px;}
.cmp-table--vs tbody th,.cmp-table--vs td{text-align:left;}
/* 2年総額の行を強調 */
.cmp-table .cmp-total td,.cmp-table .cmp-total th{font-weight:800;}
.cmp-table .cmp-total{background:color-mix(in srgb,var(--accent) 5%,transparent);}
.cmp-table .cmp-total td.is-pick{color:var(--accent);}
/* PC=表 / スマホ=カード 切り替え */
.cmp-mobile{display:none;}
@media (max-width:680px){
  .cmp-desktop{display:none;}
  .cmp-mobile{display:grid;grid-template-columns:1fr;gap:16px;}
}
/* 他社比較カード（スマホ） */
.vs-card{position:relative;border:1px solid var(--line);background:var(--paper-2);padding:24px;}
.vs-card--pick{border-color:var(--accent);box-shadow:0 24px 60px -34px color-mix(in srgb,var(--accent) 50%,transparent);}
.vs-card__sub{display:block;color:var(--ink-3);font-size:.84rem;margin:.1em 0 .2em;}
.plan-card__row.is-total dt,.plan-card__row.is-total dd{color:var(--accent);font-weight:800;}
.vs-card--pick .plan-card__name{color:var(--accent);}
/* 他社比較は常に横並びの表（スマホでも収める） */
.cmp-table--vs{table-layout:fixed;width:100%;min-width:0;}
.cmp-table--vs thead th{text-align:center;}
.cmp-table--vs tbody th,.cmp-table--vs td{text-align:center;}
.cmp-table--vs tbody th{text-align:left;}
@media (max-width:680px){
  .cmp-vs .cmp-table th,.cmp-vs .cmp-table td{padding:10px 7px;font-size:.74rem;line-height:1.5;}
  .cmp-vs .cmp-table tbody th{font-size:.7rem;white-space:normal;}
  .cmp-vs .cmp-name{font-size:.82rem;}
  .cmp-vs .cmp-tag{font-size:.62rem;line-height:1.3;letter-spacing:0;}
  .cmp-vs thead th.is-pick{padding-top:2.2em;}
  .cmp-vs thead th.is-pick::before{font-size:.6rem;}
}
/* お支払い */
.pay-list{border-top:1px solid var(--line);max-width:760px;}
.pay-row{display:grid;grid-template-columns:200px 1fr;gap:16px;padding:1em 0;border-bottom:1px solid var(--line);}
.pay-row dt{color:var(--ink-3);font-weight:600;}
.pay-row dd{color:var(--ink);}
@media (max-width:560px){.pay-row{grid-template-columns:1fr;gap:4px;}}
/* 無料相談バンド（全ページ下部） */
.section--contact-band{background:var(--paper-2);border-top:1px solid var(--line);}
/* 写真＋文章の交互レイアウト（理由・サービス概要 など） */
.media-rows{display:flex;flex-direction:column;gap:clamp(56px,8vw,110px);}
.media-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center;color:inherit;}
.media-row__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--line);border:1px solid var(--line);}
.media-row__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.media-row--link:hover .media-row__media img{transform:scale(1.05);}
.media-row__no{position:absolute;left:0;top:0;background:var(--accent);color:#fff;font-family:var(--ff-lat);font-weight:700;font-size:1.3rem;line-height:1;letter-spacing:.04em;padding:.5em .78em;}
.media-row__en{display:block;font-family:var(--ff-lat);font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.7em;}
.media-row__title{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.35rem,2.6vw,2.05rem);line-height:1.5;letter-spacing:.01em;margin-bottom:.55em;}
.media-row__desc{color:var(--ink-2);line-height:2;}
.media-row__cta{display:inline-flex;align-items:center;gap:.5em;margin-top:1.2em;font-family:var(--ff-lat);font-size:.8rem;font-weight:600;letter-spacing:.1em;color:var(--accent);}
.media-row__cta .ar{transition:transform var(--t-fast);}
.media-row--link:hover .media-row__cta .ar{transform:translateX(4px);}
.media-row:nth-child(even) .media-row__media{order:2;}
@media (max-width:760px){.media-row{grid-template-columns:1fr;gap:18px;}.media-row:nth-child(even) .media-row__media{order:0;}}

/* 選ばれる理由・制作の流れ：編集的でプロ仕様の字組み */
.media-rows{counter-reset:mrow;}
.media-row{counter-increment:mrow;}
.flow-steps{counter-reset:fstep;}
.flow-step{counter-increment:fstep;}
.media-row__no,.flow-step__no{display:none;}
.media-row__media img,.flow-step__media img{filter:grayscale(.12);transition:transform 1.2s cubic-bezier(.2,.7,.2,1),filter .6s ease;}
.media-row:hover .media-row__media img,.flow-step:hover .flow-step__media img{transform:scale(1.04);filter:grayscale(0);}
/* 番号：墨色＋短い朱赤の罫で、控えめだが芯のある見出し */
.media-row__body::before{
  content:counter(mrow,decimal-leading-zero);
  display:inline-block;font-family:var(--ff-lat);font-weight:700;font-size:1rem;
  letter-spacing:.16em;color:var(--ink);border-bottom:2px solid var(--accent);
  padding-bottom:.5em;margin-bottom:1.3em;
}
.flow-step__body::before{
  content:"STEP " counter(fstep,decimal-leading-zero);
  display:inline-block;font-family:var(--ff-lat);font-weight:700;font-size:.82rem;
  letter-spacing:.2em;color:var(--ink);border-bottom:2px solid var(--accent);
  padding-bottom:.5em;margin-bottom:1.3em;
}
.media-row__title{font-size:clamp(1.3rem,2.6vw,2rem);line-height:1.5;letter-spacing:.01em;margin-bottom:.55em;}
.flow-step__title{font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.5;letter-spacing:.01em;margin-bottom:.55em;}
.media-row__desc,.flow-step__desc{line-height:2;color:var(--ink-2);font-size:1.06rem;}
.media-row__btn{display:inline-flex;align-items:center;gap:.5em;margin-top:1.5em;padding:.72em 1.5em;border:1px solid var(--ink);font-family:var(--ff-lat);font-size:.76rem;font-weight:600;letter-spacing:.12em;color:var(--ink);transition:background var(--t-fast),color var(--t-fast);}
.media-row__btn:hover{background:var(--ink);color:var(--paper);}
.media-row__btn .ar{transition:transform var(--t-fast);}
.media-row__btn:hover .ar{transform:translateX(3px);}
/* サービス背景写真モード時：特徴グリッドも白文字に */
.section--services.section--media .hp-feats,
.section--services.section--media .hp-feat{border-color:rgba(255,255,255,.24);}
.section--services.section--media .hp-feat__title{color:#fff;}
.section--services.section--media .hp-feat__desc{color:rgba(255,255,255,.8);}
/* 中央寄せ見出し（制作実績・デモ など） */
.head-row--center{justify-items:center;text-align:center;}
.head-row--center .head-row__top{justify-content:center;}
.head-row--center .lead{margin-inline:auto;}
/* 実デモのクリック可能グリッド */
.demo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,32px);margin-top:clamp(34px,5vw,58px);}
.demo-item{display:block;color:inherit;border:1px solid var(--line);background:var(--paper-2);overflow:hidden;transition:transform var(--t-mid),box-shadow var(--t-mid);}
.demo-item:hover{transform:translateY(-6px);box-shadow:0 30px 60px -36px rgba(20,24,60,.5);}
.demo-item__media{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--line);}
.demo-item__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.demo-item:hover .demo-item__media img{transform:scale(1.05);}
.demo-item__bar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:.95em 1.1em;border-top:1px solid var(--line);}
.demo-item__title{font-weight:700;font-size:.98rem;line-height:1.5;}
.demo-item__ar{font-family:var(--ff-lat);color:var(--ink-3);transition:transform var(--t-fast),color var(--t-fast);}
a.demo-item:hover .demo-item__ar{transform:translate(3px,-3px);color:var(--accent);}
@media (max-width:860px){.demo-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:680px){
  .demo-grid{display:flex;grid-template-columns:none;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;margin:clamp(34px,5vw,58px) calc(var(--gutter)*-1) 0;padding:2px var(--gutter) 16px;scrollbar-width:none;}
  .demo-grid::-webkit-scrollbar{display:none;}
  .demo-item{flex:0 0 82%;scroll-snap-align:center;}
}
/* デモサイトページ：事例ギャラリー */
.demo-cases{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,300px));justify-content:center;gap:clamp(28px,3.5vw,52px);margin-top:clamp(28px,4vw,46px);}
.demo-case__frame{display:block;width:100%;max-width:300px;margin-inline:auto;}
.demo-case .browser{width:100%;max-width:300px;box-shadow:0 26px 56px -36px rgba(20,24,60,.5);transition:transform var(--t-mid),box-shadow var(--t-mid);}
.demo-case:hover .browser{transform:translateY(-6px);box-shadow:0 36px 70px -40px rgba(20,24,60,.6);}
.demo-case--img .demo-case__frame{aspect-ratio:16/10;border:1px solid var(--line);overflow:hidden;background:var(--line);}
.demo-case--img .demo-case__frame img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.demo-case--img:hover .demo-case__frame img{transform:scale(1.05);}
.demo-case__body{padding:1.05em .2em 0;max-width:300px;margin-inline:auto;width:100%;}
.demo-case__cat{display:block;font-family:var(--ff-lat);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);}
.demo-case__title{font-family:var(--ff-head);font-weight:700;font-size:1.12rem;line-height:1.5;margin-top:.3em;}
.demo-case__title a{color:inherit;display:inline-flex;align-items:center;gap:.3em;}
.demo-case__ar{font-family:var(--ff-lat);color:var(--ink-3);transition:transform var(--t-fast),color var(--t-fast);}
.demo-case__title a:hover .demo-case__ar{transform:translate(3px,-3px);color:var(--accent);}
.demo-cases__note{margin-top:clamp(28px,4vw,44px);color:var(--ink-3);font-size:.86rem;text-align:center;}
.demo-cases__more{margin-top:clamp(26px,3.4vw,40px);text-align:center;}
.demo-cases--wide{grid-template-columns:repeat(auto-fit,minmax(260px,320px));}
.head-row__top{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.head-row__lead{max-width:40em;}
/* セクション見出しブロックをリンク化 */
.head-link{display:grid;gap:1.4rem;color:inherit;}
.head-link .sec-head{transition:color var(--t-fast);}
.head-link:hover .sec-head{color:var(--accent);}
.head-go{display:inline-flex;align-items:center;gap:.7em;color:var(--ink-3);font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.16em;transition:color var(--t-fast);}
.head-go .ar{transition:transform var(--t-fast);}
.head-link:hover .head-go{color:var(--accent);}
.head-link:hover .head-go .ar{transform:translateX(4px);}

.svc-list{border-top:1px solid var(--line);}
.svc{
  display:grid;grid-template-columns:90px 1fr minmax(auto,30em) auto;
  gap:clamp(16px,3vw,48px);align-items:start;
  padding-block:clamp(28px,3.4vw,46px);
  border-bottom:1px solid var(--line);
  position:relative;
  transition:padding-left var(--t-fast);
}
.svc:hover{padding-left:12px;}
.svc__no{font-family:var(--ff-lat);font-size:.86rem;font-weight:600;letter-spacing:.12em;color:var(--accent);padding-top:.5em;}
.svc__title{font-weight:700;font-size:clamp(1.3rem,2.4vw,1.85rem);line-height:1.4;}
.svc__title .en{display:block;font-family:var(--ff-lat);font-size:.74rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.7em;}
.svc__desc{color:var(--ink-2);font-size:.98rem;line-height:2;}
.svc__mark{align-self:center;width:40px;height:40px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast),transform var(--t-fast);}
.svc:hover .svc__mark{background:var(--accent);border-color:var(--accent);color:#fff;transform:rotate(45deg);}

/* ホーム「サービス」：背景写真モード（暗幕＋白文字） */
.section--services.section--media{position:relative;background-color:#0d0e12;overflow:hidden;}
.section--services.section--media .section__scrim{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(10,12,20,.74),rgba(10,12,20,.6));}
.section--services.section--media .wrap{position:relative;z-index:1;}
.section--services.section--media .eyebrow{color:rgba(255,255,255,.82);}
.section--services.section--media .eyebrow::before{background:var(--accent);}
.section--services.section--media .sec-no,
.section--services.section--media .head-go{color:rgba(255,255,255,.55);}
.section--services.section--media .sec-head{color:#fff;}
.section--services.section--media .head-link:hover .sec-head,
.section--services.section--media .head-link:hover .head-go{color:#fff;}
.section--services.section--media .lead{color:rgba(255,255,255,.8);}
.section--services.section--media .svc-list{border-top-color:rgba(255,255,255,.28);}
.section--services.section--media .svc{border-bottom-color:rgba(255,255,255,.18);}
.section--services.section--media .svc__title{color:#fff;}
.section--services.section--media .svc__title .en{color:rgba(255,255,255,.6);}
.section--services.section--media .svc__desc{color:rgba(255,255,255,.74);}
.section--services.section--media a.svc--link:hover .svc__title{color:#fff;}
.section--services.section--media .svc__mark{border-color:rgba(255,255,255,.45);color:#fff;}
.section--services.section--media .arrow-link{color:#fff;border-color:rgba(255,255,255,.5);}
.section--services.section--media .arrow-link:hover{color:#fff;border-color:#fff;}

/* ============================================================
   7. Works
   ============================================================ */
.works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,3.5vw,56px) clamp(24px,3vw,40px);}
.work-card{display:block;}
.work-card__media{position:relative;overflow:hidden;background:var(--line);aspect-ratio:4/3;border:1px solid var(--line);}
.work-card__media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;filter:grayscale(.2);transition:transform var(--t-slow),filter var(--t-mid);}
.work-card:hover .work-card__media img{transform:scale(1.04);filter:grayscale(0);}
/* 上辺をアクセント色がワイプ */
.work-card__media::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t-mid);z-index:3;}
.work-card:hover .work-card__media::before{transform:scaleX(1);}
/* View ラベル（アクセントのチップがせり上がる） */
.work-card__media::after{content:"View Project ↗";position:absolute;left:0;bottom:0;z-index:2;background:var(--accent);color:#fff;font-family:var(--ff-lat);font-size:.66rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding:.5em .8em;opacity:0;transform:translateY(100%);transition:opacity var(--t-mid),transform var(--t-mid);}
.work-card:hover .work-card__media::after{opacity:1;transform:translateY(0);}
.work-card__media .ph{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--ff-lat);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);font-size:.8rem;}
.work-card__no{position:absolute;top:14px;left:16px;z-index:2;font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.14em;color:var(--ink);background:rgba(255,255,255,.85);padding:.15em .5em;transition:color var(--t-fast),background var(--t-fast);}
.work-card:hover .work-card__no{color:#fff;background:var(--accent);}
.work-card__body{position:relative;display:flex;flex-direction:column;gap:.34em;margin-top:1.05em;padding-bottom:.95em;border-bottom:1px solid var(--line);}
/* ベースラインをアクセントがワイプ */
.work-card__body::after{content:"";position:absolute;left:0;bottom:-1px;width:100%;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform var(--t-mid);}
.work-card:hover .work-card__body::after{transform:scaleX(1);}
.work-card__cat{font-family:var(--ff-lat);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);transition:color var(--t-fast);}
.work-card:hover .work-card__cat{color:var(--accent);}
.work-card__title{font-family:var(--ff-head);font-weight:600;font-size:clamp(1.08rem,1.7vw,1.32rem);line-height:1.5;color:var(--ink);transition:transform var(--t-mid);}
.work-card__title::after{content:"↗";display:inline-block;margin-left:.35em;font-family:var(--ff-lat);font-weight:600;color:var(--accent);opacity:0;transform:translateX(-4px);transition:opacity var(--t-mid),transform var(--t-mid);}
.work-card:hover .work-card__title{transform:translateX(3px);}
.work-card:hover .work-card__title::after{opacity:1;transform:translateX(0);}
.work-card__year{font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.1em;color:var(--ink-3);margin-top:.15em;display:block;}

/* ============================================================
   8. News
   ============================================================ */
.section--news{background:var(--paper-2);}
.news-list{border-top:1px solid var(--line);}
.news-row{
  display:grid;grid-template-columns:140px 150px 1fr auto;gap:clamp(14px,2.4vw,40px);align-items:center;
  padding-block:clamp(20px,2.4vw,30px);border-bottom:1px solid var(--line);
  transition:padding-left var(--t-fast),color var(--t-fast);
}
.news-row:hover{padding-left:10px;}
.news-row__date{font-family:var(--ff-lat);font-size:.82rem;letter-spacing:.08em;color:var(--ink-3);}
.news-row__cat{justify-self:start;font-family:var(--ff-lat);font-size:.68rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);border:1px solid currentColor;padding:.35em .9em;border-radius:0;}
.news-row__title{font-weight:500;font-size:clamp(1rem,1.6vw,1.18rem);line-height:1.6;}
.news-row:hover .news-row__title{color:var(--accent);}
.news-row__ar{color:var(--ink-3);transition:transform var(--t-fast),color var(--t-fast);}
.news-row:hover .news-row__ar{transform:translateX(5px);color:var(--accent);}

/* ============================================================
   9. About strip
   ============================================================ */
.about-split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,96px);align-items:center;}
.about-split__media{position:relative;aspect-ratio:3/4;background:var(--line);overflow:hidden;}
.about-split__media img{width:100%;height:100%;object-fit:cover;}
.about-split__media .ph{position:absolute;inset:0;display:grid;place-items:center;color:var(--ink-3);font-family:var(--ff-lat);letter-spacing:.2em;text-transform:uppercase;font-size:.8rem;}
.about-split__body .sec-head{margin:0 0 1em;}
.about-head-link{display:block;}
.about-head-link .head-row__top{margin-bottom:.9em;}
.about-split__sign{margin-top:2.4em;font-family:var(--ff-lat);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);}

/* ============================================================
   10. CTA
   ============================================================ */
.cta{background:#0d0e12 center/cover no-repeat;color:var(--paper);text-align:center;position:relative;overflow:hidden;}
.cta::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,14,18,.55),rgba(13,14,18,.78));z-index:0;}
.cta .wrap{position:relative;z-index:1;}
.cta__eyebrow{justify-content:center;color:rgba(255,255,255,.7);}
.cta__eyebrow::before{background:var(--accent);}
.cta__title{font-weight:700;font-size:clamp(2rem,6vw,4.6rem);line-height:1.18;margin:.5em 0 .8em;}
.cta__title .em{color:var(--accent);}
.cta__sub{color:rgba(255,255,255,.78);max-width:36em;margin:0 auto 2.4em;line-height:2;}
.cta__tel{margin-top:clamp(28px,4vw,42px);display:flex;flex-direction:column;align-items:center;gap:.25em;position:relative;z-index:1;}
.cta__tel-label{font-family:var(--ff-lat);font-size:.7rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6);}
.cta__tel-num{font-family:var(--ff-lat);font-weight:800;font-size:clamp(1.7rem,3.6vw,2.5rem);color:#fff;letter-spacing:.02em;transition:color var(--t-fast);}
.cta__tel-num:hover{color:color-mix(in srgb,var(--accent) 58%,#fff);}
.cta__tel-hours{font-size:.82rem;color:rgba(255,255,255,.55);}
.cta .btn--accent{--fill:var(--paper);}
.cta .btn--accent:hover{color:var(--ink);}

/* ============================================================
   11. Footer
   ============================================================ */
.site-footer{background:var(--paper);border-top:1px solid var(--line);}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(32px,4vw,64px);padding-block:clamp(56px,7vw,96px);}
.footer-brand .brand{font-size:1.6rem;}
.footer-brand p{margin-top:1.4em;color:var(--ink-2);max-width:24em;font-size:.92rem;line-height:2;}
.footer-col h4{font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1.4em;}
.footer-col li{margin-bottom:.9em;}
.footer-col a{font-size:.92rem;color:var(--ink);transition:color var(--t-fast);}
.footer-col a:hover{color:var(--accent);}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding-block:24px;border-top:1px solid var(--line);font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.1em;color:var(--ink-3);}
.footer-bottom .to-top{display:inline-flex;align-items:center;gap:.6em;text-transform:uppercase;}
.footer-bottom .to-top:hover{color:var(--accent);}

/* ============================================================
   12. Page hero（下層ページ共通）
   ============================================================ */
.page-hero{min-height:clamp(380px,42vw,520px);display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(110px,14vw,150px) var(--gutter) clamp(44px,5vw,72px);border-bottom:1px solid var(--line);}
.page-hero--media{position:relative;color:#fff;border-color:transparent;background-size:cover;background-position:center;}
.page-hero__scrim{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(12,16,28,.5),rgba(12,16,28,.66));}
.page-hero--media .page-hero__inner{position:relative;z-index:1;}
.page-hero--media .page-hero__en{color:#fff;}
.page-hero--media .crumbs a:hover{color:#fff;}
.page-hero__inner{max-width:var(--maxw);margin-inline:auto;}
.page-hero__en{font-family:var(--ff-lat);font-weight:700;font-size:clamp(2.6rem,9vw,6rem);line-height:1;letter-spacing:.01em;text-transform:uppercase;}
.page-hero__ja{margin-top:.8em;font-family:var(--ff-lat);font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);}
.page-hero__lead{margin-top:1.8em;max-width:44em;color:var(--ink-2);line-height:2.1;}
.crumbs{font-family:var(--ff-lat);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:2.2em;}
.crumbs a:hover{color:var(--accent);}
.crumbs span{margin-inline:.6em;}

/* 本文（固定ページ・投稿） */
.entry{max-width:46em;margin-inline:auto;padding-block:clamp(48px,6vw,80px);}
.entry p{margin-bottom:1.6em;line-height:2.1;font-size:1.06rem;}
.entry h2{font-size:clamp(1.4rem,3vw,1.9rem);font-weight:700;margin:2.2em 0 .9em;line-height:1.5;padding-top:.4em;border-top:1px solid var(--line);}
.entry h3{font-size:1.2rem;font-weight:700;margin:1.8em 0 .7em;}
.entry a{color:var(--accent);text-decoration:underline;text-underline-offset:.18em;}
.entry img{margin:2em 0;}
.entry ul,.entry ol{margin:0 0 1.6em 1.2em;}
.entry li{margin-bottom:.6em;line-height:1.9;}
.entry blockquote{border-left:2px solid var(--accent);padding-left:1.4em;margin:2em 0;color:var(--ink-2);font-style:italic;}

/* 投稿メタ */
.post-meta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;font-family:var(--ff-lat);font-size:.74rem;letter-spacing:.1em;color:var(--ink-3);}
.post-meta .cat{color:var(--accent);text-transform:uppercase;letter-spacing:.14em;font-weight:600;}

/* Worksページのフィルタ風見出し */
.works-page-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,3vw,48px) clamp(20px,2.4vw,32px);}

/* News一覧（アーカイブ） */
.archive-list{max-width:var(--maxw);margin-inline:auto;}

/* ページャ */
.pager{display:flex;justify-content:center;gap:10px;margin-top:64px;font-family:var(--ff-lat);font-size:.84rem;}
.pager .page-numbers{display:grid;place-items:center;min-width:44px;height:44px;border:1px solid var(--line-2);transition:all var(--t-fast);letter-spacing:.05em;}
.pager .page-numbers:hover,.pager .current{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.pager .current{background:var(--accent);border-color:var(--accent);}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,88px);align-items:start;max-width:var(--maxw);margin-inline:auto;}
.contact-info dl{display:grid;grid-template-columns:auto 1fr;gap:1.2em 2em;margin:0;}
.contact-info dt{font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);padding-top:.3em;}
.contact-info dd{margin:0;font-size:1.08rem;line-height:1.8;}
.contact-info dd a{color:var(--accent);}
.contact-form-note{background:var(--paper-2);border:1px solid var(--line);padding:clamp(24px,3vw,40px);}

/* ============================================================
   13. Reveal animation
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);}
.reveal.is-in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}
.reveal[data-d="4"]{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================
   14b. Editorial polish（角を立てる・罫線主体／非AI的）
   ============================================================ */
:root{--radius-m:0px;--radius-l:0px;}
/* ボタン・ナビCTAは角を立てる */
.btn{border-radius:0;}
.nav__cta{border-radius:0;}
/* メディア・カードも角を立てる */
.work-card__media,.about-split__media,.contact-form-note,.price-card,.svc-card,.feature-svc__media{border-radius:0;}
.about-split__media{border-radius:0;}
/* カードの浮き上がりは残す（影はシャープ・控えめに） */
.work-card__media{transition:transform var(--t-mid),box-shadow var(--t-mid);}
.work-card:hover .work-card__media{transform:translateY(-6px);box-shadow:0 22px 44px -26px rgba(20,24,60,.42);}

/* ============================================================
   15. サービスページ（一覧／詳細）
   ============================================================ */
/* ホームのサービス行リンク */
.svc--link{color:inherit;text-decoration:none;}
a.svc--link:hover .svc__title{color:var(--accent);}

/* 一覧：主役ブロック */
.feature-svc{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,4vw,64px);align-items:center;color:inherit;border:1px solid var(--line);border-radius:var(--radius-l);overflow:hidden;background:var(--paper-2);transition:transform var(--t-mid),box-shadow var(--t-mid);}
.feature-svc:hover{transform:translateY(-5px);box-shadow:0 30px 60px -34px rgba(20,24,60,.45);}
.feature-svc__media{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:0;}
.feature-svc__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.feature-svc:hover .feature-svc__media img{transform:scale(1.06);}
.feature-svc__tag{position:absolute;top:16px;left:16px;background:var(--accent);color:#fff;font-family:var(--ff-lat);font-size:.68rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:.5em 1em;border-radius:0;}
.feature-svc__body{padding:clamp(24px,3vw,48px) clamp(24px,3vw,48px) clamp(24px,3vw,48px) 0;}
.feature-svc__en{font-family:var(--ff-lat);font-size:.78rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);}
.feature-svc__ja{font-weight:700;font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.4;margin:.5em 0 .7em;}
.feature-svc__lead{color:var(--ink-2);line-height:2;margin-bottom:1.4em;}
.feature-svc__list{display:flex;flex-direction:column;gap:.7em;margin-bottom:1.8em;}
.feature-svc__list li{position:relative;padding-left:1.7em;color:var(--ink);font-size:.96rem;line-height:1.6;}
.feature-svc__list li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;background:var(--accent);border-radius:50%;}
.feature-svc__cta{display:inline-flex;align-items:center;gap:.7em;font-family:var(--ff-lat);font-weight:600;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:.4em;transition:gap var(--t-fast),color var(--t-fast),border-color var(--t-fast);}
.feature-svc:hover .feature-svc__cta{color:var(--accent);border-color:var(--accent);gap:1.1em;}

/* 一覧：その他カード */
.svc-cards{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,32px);}
.svc-card{position:relative;display:block;color:inherit;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-m);padding:clamp(26px,3vw,44px);transition:transform var(--t-mid),box-shadow var(--t-mid),background var(--t-mid);overflow:hidden;}
.svc-card::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 100% at 100% 0,color-mix(in srgb,var(--accent) 6%,transparent),transparent 60%);opacity:0;transition:opacity var(--t-mid);}
.svc-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -36px rgba(20,24,60,.5);}
.svc-card:hover::after{opacity:1;}
.svc-card__no{font-family:var(--ff-lat);font-size:.8rem;font-weight:700;letter-spacing:.12em;color:var(--accent);}
.svc-card__en{display:block;font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:1.2em;}
.svc-card__ja{font-weight:700;font-size:clamp(1.2rem,2vw,1.55rem);line-height:1.45;margin:.4em 0 .7em;}
.svc-card__desc{color:var(--ink-2);font-size:.95rem;line-height:1.95;}
.svc-card__cta{display:inline-flex;align-items:center;gap:.6em;margin-top:1.6em;font-family:var(--ff-lat);font-weight:600;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);}
.svc-card:hover .svc-card__cta{gap:1.1em;}

/* 詳細ページ */
.svc-detail{display:grid;grid-template-columns:1fr 360px;gap:clamp(36px,5vw,80px);align-items:start;}
.feature-list{counter-reset:fl;border-top:1px solid var(--line);}
.feature-list li{display:flex;gap:1.2em;align-items:flex-start;padding:1.2em 0;border-bottom:1px solid var(--line);}
.feature-list__no{font-family:var(--ff-lat);font-size:.82rem;font-weight:700;letter-spacing:.1em;color:var(--accent);padding-top:.15em;}
.feature-list__txt{font-size:1.05rem;line-height:1.7;}
.svc-detail__side{position:sticky;top:104px;}
.price-card{background:var(--ink);color:var(--paper);border-radius:var(--radius-l);padding:clamp(26px,3vw,38px);}
.price-card__tag{font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 58%,#fff);}
.price-card__note{font-weight:700;font-size:1.2rem;line-height:1.6;margin-top:.8em;}
.price-card .arrow-link{color:rgba(255,255,255,.7);border-color:rgba(255,255,255,.3);}
.price-card .arrow-link:hover{color:#fff;border-color:#fff;}

/* 他サービス導線 */
.other-svc{display:grid;grid-template-columns:1fr 1fr;gap:2px;border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;background:var(--line);}
.other-svc__item{background:var(--paper);padding:clamp(22px,2.6vw,34px);display:flex;flex-direction:column;gap:.4em;color:inherit;transition:background var(--t-fast);}
.other-svc__item:hover{background:var(--paper-2);}
.other-svc__en{font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);}
.other-svc__ja{font-weight:700;font-size:clamp(1.1rem,1.8vw,1.4rem);line-height:1.4;}
.other-svc__ar{font-family:var(--ff-lat);color:var(--ink-3);transition:transform var(--t-fast),color var(--t-fast);}
.other-svc__item:hover .other-svc__ar{transform:translateX(5px);color:var(--accent);}

/* ============================================================
   16. 料金（買い切り型）
   ============================================================ */
.price-cards{display:grid;grid-template-columns:1.25fr 1fr;gap:clamp(16px,2.2vw,26px);margin-top:clamp(28px,4vw,48px);}
.price-box{border:1px solid var(--line);border-radius:var(--radius-l);padding:clamp(28px,3.4vw,46px);background:var(--paper-2);position:relative;overflow:hidden;display:flex;flex-direction:column;}
.price-box--init{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.price-box--init::after{content:"";position:absolute;right:-30%;top:-40%;width:80%;height:120%;background:radial-gradient(closest-side,color-mix(in srgb,var(--accent) 50%,transparent),transparent);opacity:.5;pointer-events:none;}
.price-box__head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:clamp(22px,3vw,34px);position:relative;z-index:1;}
.price-box__label{font-family:var(--ff-lat);font-size:.82rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.65;}
.price-box__badge{background:var(--accent);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.02em;padding:.55em 1em;border-radius:0;line-height:1.3;text-align:center;}
.price-box__main{display:flex;align-items:baseline;gap:.5em;flex-wrap:wrap;position:relative;z-index:1;margin-top:auto;}
.price-box__regular{font-size:clamp(1.05rem,1.8vw,1.4rem);text-decoration:line-through;opacity:.4;}
.price-box__big{font-family:var(--ff-lat);font-weight:800;font-size:clamp(2.8rem,6.4vw,4.8rem);line-height:.95;letter-spacing:-.02em;}
.price-box__unit{font-size:.26em;font-weight:600;opacity:.7;margin-left:.4em;letter-spacing:0;}
.price-box__sub{display:block;margin-top:1em;color:var(--ink-2);font-size:.92rem;line-height:1.7;position:relative;z-index:1;}
.price-notes{margin-top:clamp(22px,3vw,30px);display:flex;flex-direction:column;gap:.55em;}
.price-notes li{position:relative;padding-left:1.5em;color:var(--ink-3);font-size:.86rem;line-height:1.75;}
.price-notes li::before{content:"※";position:absolute;left:0;top:0;color:var(--ink-3);}
.price-cta{margin-top:clamp(26px,3.4vw,40px);}

/* ============================================================
   17. ご利用の流れ（Process）
   ============================================================ */
.process{margin-top:clamp(28px,4vw,52px);border-top:1px solid var(--line);counter-reset:proc;}
.proc-step{display:grid;grid-template-columns:128px 1fr;gap:clamp(14px,3vw,48px);padding:clamp(24px,3vw,40px) 0;border-bottom:1px solid var(--line);align-items:start;}
.proc-step__no{font-family:var(--ff-lat);font-weight:800;font-size:clamp(2rem,4vw,3.4rem);line-height:1;color:var(--line-2);letter-spacing:-.02em;transition:color var(--t-fast);}
.proc-step:hover .proc-step__no{color:var(--accent);}
.proc-step__title{font-weight:700;font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.5;margin-bottom:.55em;}
.proc-step__desc{color:var(--ink-2);line-height:2;max-width:48em;}

/* ============================================================
   18. B2B Home（背景固定パララックス／ティッカー／理念／2カラム／追従CTA）
   ============================================================ */
/* 背景固定パララックス共通 */
.parallax{background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;}

/* ヒーロー（背景固定） */
.hero--parallax{justify-content:center;background-size:cover;background-position:center;background-attachment:fixed;}
.hero__scrim{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(10,12,20,.5),rgba(10,12,20,.4) 40%,rgba(10,12,20,.66));}
.hero--parallax .hero__inner,.hero--parallax .hero__top,.hero--parallax .hero__scroll{position:relative;z-index:1;}
.hero--parallax .hero__title{font-size:clamp(2.3rem,5.4vw,4.6rem);line-height:1.18;}
.hero--parallax .hero__sub{max-width:34em;}

/* ニュースティッカー */
.ticker{display:flex;align-items:center;gap:0;background:var(--paper-2);border-bottom:1px solid var(--line);overflow:hidden;}
.ticker__label{flex:none;align-self:stretch;display:flex;align-items:center;gap:.6em;padding:0 clamp(16px,2vw,26px);background:var(--ink);color:var(--paper);font-family:var(--ff-lat);font-weight:700;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;}
.ticker__view{flex:1;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 4%,#000 92%,transparent);}
.ticker__track{display:flex;width:max-content;animation:tickerMove 36s linear infinite;}
.ticker:hover .ticker__track{animation-play-state:paused;}
@keyframes tickerMove{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.ticker__item{display:inline-flex;align-items:center;gap:1em;padding:14px clamp(20px,3vw,40px);white-space:nowrap;border-right:1px solid var(--line);color:var(--ink);}
.ticker__date{font-family:var(--ff-lat);font-size:.78rem;font-weight:700;letter-spacing:.04em;color:var(--accent);}
.ticker__title{font-size:.9rem;color:var(--ink-2);}
.ticker__item:hover .ticker__title{color:var(--ink);}
.ticker__more{flex:none;padding:0 clamp(14px,2vw,22px);align-self:stretch;display:flex;align-items:center;gap:.5em;font-family:var(--ff-lat);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);border-left:1px solid var(--line);}
.ticker__more:hover{color:var(--accent);}

/* 理念・代表メッセージ（背景固定） */
.message{position:relative;color:var(--paper);overflow:hidden;}
.message__scrim{position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,rgba(10,12,20,.78),rgba(10,12,20,.62));}
.message__inner{position:relative;z-index:1;}
.sec-head--light{color:#fff;}
.message .eyebrow{color:rgba(255,255,255,.75);}
.message .eyebrow::before{background:var(--accent);}
.message .sec-no{color:rgba(255,255,255,.45);}
.concepts{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px);margin-top:clamp(34px,5vw,60px);}
.concept{border-top:2px solid rgba(255,255,255,.25);padding-top:1.4em;}
.concept__word{display:block;font-family:var(--ff-lat);font-weight:800;font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:.01em;}
.concept__read{display:block;margin-top:.2em;font-size:.86rem;letter-spacing:.1em;color:var(--accent);}
.concept .concept__read{color:color-mix(in srgb,var(--accent) 58%,#fff);}
.concept__text{margin-top:1em;color:rgba(255,255,255,.8);line-height:1.95;font-size:.95rem;}
.message__quote{margin-top:clamp(40px,6vw,72px);max-width:54em;}
.message__body{font-size:clamp(1.05rem,1.8vw,1.4rem);line-height:2.1;color:#fff;font-weight:500;}
.message__sign{margin-top:1.6em;display:flex;align-items:baseline;gap:1em;}
.message__name{font-weight:700;font-size:1.05rem;}
.message__role{font-family:var(--ff-lat);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.6);}

/* お知らせ＆コラム 2カラム */
.news-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,64px);margin-top:clamp(28px,4vw,48px);}
.news-col__head{display:flex;align-items:baseline;gap:.8em;padding-bottom:1em;border-bottom:2px solid var(--ink);margin-bottom:.4em;}
.news-col__en{font-family:var(--ff-lat);font-weight:800;font-size:1.1rem;letter-spacing:.02em;}
.news-col__ja{font-size:.86rem;color:var(--ink-2);}
.jrow{display:grid;grid-template-columns:auto auto 1fr;align-items:baseline;gap:1em;padding:1.05em 0;border-bottom:1px solid var(--line);color:inherit;}
.jrow__date{font-family:var(--ff-lat);font-size:.8rem;font-weight:700;color:var(--accent);letter-spacing:.04em;}
.jrow__cat{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);border:1px solid var(--line-2);border-radius:0;padding:.2em .8em;}
.jrow__title{font-size:.95rem;line-height:1.6;color:var(--ink);transition:color var(--t-fast);}
.jrow:hover .jrow__title{color:var(--accent);}
.news-col__empty{color:var(--ink-3);font-size:.9rem;padding:1.4em 0;}

/* 創業ストーリー（代表メッセージ） */
.section--founder{padding-top:0;}
.founder{max-width:44em;margin-top:clamp(26px,4vw,44px);}
.founder__body p{line-height:2.2;color:var(--ink-2);margin-bottom:1.5em;}
.founder__lead{font-size:clamp(1.12rem,1.9vw,1.45rem);color:var(--ink);font-weight:500;line-height:1.95;}
.founder__sign{margin-top:2em;display:flex;flex-direction:column;align-items:flex-start;}
.founder__sign-line{width:48px;height:2px;background:var(--accent);margin-bottom:1.1em;}
.founder__role{font-family:var(--ff-lat);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);}
.founder__name{font-weight:700;font-size:1.35rem;margin-top:.2em;}
/* 代表挨拶・メッセージ：文章＋写真（写真は小さめ） */
.founder-split{display:flex;flex-wrap:wrap;gap:clamp(22px,3vw,52px);align-items:center;}
.founder-split--rev{margin-bottom:clamp(40px,5vw,72px);}
.founder-split__media{flex:0 0 clamp(170px,28%,280px);aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:var(--line);}
.founder-split__media img{width:100%;height:100%;object-fit:cover;}
.founder-split__text{flex:1 1 340px;}
.founder-split--rev .founder-split__media{order:2;}
.founder-split__head{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.2rem,2vw,1.6rem);line-height:1.5;margin:.1em 0 .7em;}
.founder-split .founder__lead{font-size:clamp(1.1rem,1.5vw,1.28rem);line-height:1.85;color:var(--ink);font-weight:500;}
.founder-split .founder__body p{font-size:1.05rem;line-height:2;margin-bottom:1.1em;color:var(--ink-2);}
.gm-label{display:block;font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:1em;}
.gm-sign{margin-top:1.6em;display:flex;flex-direction:column;align-items:flex-start;}
.gm-sign__line{width:44px;height:2px;background:var(--accent);margin-bottom:.9em;}
.gm-sign__role{font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);}
.gm-sign__name{font-family:var(--ff-head);font-weight:700;font-size:1.2rem;margin-top:.2em;}
@media (max-width:760px){
  .founder-split__media{flex-basis:100%;aspect-ratio:3/2;}
  .founder-split--rev .founder-split__media{order:0;}
}
/* スマホで読みやすい文字サイズ */
@media (max-width:680px){
  .founder__lead{font-size:1.04rem;line-height:1.85;}
  .founder__body p{font-size:.96rem;line-height:1.95;margin-bottom:1.2em;}
}
/* メンバー紹介（サービス概要） */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,36px);}
.member{border:1px solid var(--line);background:var(--paper-2);overflow:hidden;}
.member__media{aspect-ratio:1/1;overflow:hidden;background:var(--line);}
.member__media img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow);}
.member:hover .member__media img{transform:scale(1.05);}
.member__body{padding:clamp(18px,2vw,26px);}
.member__role{font-family:var(--ff-lat);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);}
.member__name{font-family:var(--ff-head);font-weight:700;font-size:clamp(1.2rem,1.8vw,1.5rem);margin:.25em 0 .35em;}
.member__note{color:var(--ink-2);font-size:.9rem;line-height:1.7;}
@media (max-width:760px){.team-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.team-grid{grid-template-columns:1fr;}}

/* 選ばれる理由 */
.reasons{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,46px);margin-top:clamp(30px,4vw,54px);}
.reason{border-top:2px solid var(--ink);padding-top:1.3em;}
.reason__no{font-family:var(--ff-lat);font-weight:800;font-size:clamp(1.6rem,2.4vw,2.2rem);color:var(--accent);letter-spacing:.02em;}
.reason__title{font-weight:700;font-size:clamp(1.1rem,1.7vw,1.34rem);line-height:1.55;margin:.55em 0 .7em;}
.reason__desc{color:var(--ink-2);line-height:2;font-size:.95rem;}

/* ステートメント帯（キャッチコピー） */
.statement{border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.statement__head{font-size:clamp(1.55rem,3.6vw,2.9rem);font-weight:700;line-height:1.55;letter-spacing:.01em;max-width:22em;}
.statement__sub{margin-top:1.1em;color:var(--ink-2);font-size:clamp(1rem,1.5vw,1.2rem);line-height:1.95;max-width:40em;}

/* よくあるご質問（FAQ） */
.faq{margin-top:clamp(28px,4vw,48px);max-width:62em;border-top:1px solid var(--line);}
.faq__item{border-bottom:1px solid var(--line);}
.faq__q{display:flex;align-items:flex-start;gap:.9em;padding:1.35em 0;cursor:pointer;list-style:none;font-weight:700;font-size:clamp(1rem,1.6vw,1.18rem);line-height:1.6;}
.faq__q::-webkit-details-marker{display:none;}
.faq__mark{flex:none;font-family:var(--ff-lat);font-weight:800;color:var(--accent);font-size:1.15em;line-height:1.4;width:1.3em;}
.faq__qt{flex:1;}
.faq__ico{flex:none;width:1.1em;height:1.1em;position:relative;margin-top:.3em;}
.faq__ico::before,.faq__ico::after{content:"";position:absolute;background:var(--ink-3);}
.faq__ico::before{left:0;right:0;top:50%;height:2px;transform:translateY(-50%);}
.faq__ico::after{top:0;bottom:0;left:50%;width:2px;transform:translateX(-50%);transition:transform var(--t-fast);}
.faq__item[open] .faq__ico::after{transform:translateX(-50%) scaleY(0);}
.faq__a{display:flex;gap:.9em;padding:0 0 1.6em;}
.faq__mark--a{color:var(--ink-3);}
.faq__a p{flex:1;color:var(--ink-2);line-height:2.05;font-size:1.05rem;}
.news-col .arrow-link{margin-top:1.6em;}

/* 追従CTA（右下） */
.float-cta{position:fixed;right:clamp(14px,2vw,26px);bottom:clamp(14px,2vw,26px);z-index:90;
  display:inline-flex;align-items:center;gap:.7em;padding:1em 1.3em;border-radius:0;
  background:var(--accent);color:#fff;font-weight:700;font-size:.92rem;letter-spacing:.04em;
  box-shadow:0 18px 40px -16px color-mix(in srgb,var(--accent) 70%,transparent),0 4px 12px rgba(0,0,0,.18);
  transition:transform var(--t-fast),box-shadow var(--t-fast);}
.float-cta:hover{transform:translateY(-3px);box-shadow:0 26px 54px -18px color-mix(in srgb,var(--accent) 80%,transparent),0 6px 16px rgba(0,0,0,.2);}
.float-cta__ico{width:1.7em;height:1.7em;border-radius:50%;background:rgba(255,255,255,.22);display:grid;place-items:center;font-size:.9em;}

/* スマホでは背景固定をオフ（iOS等のガタつき回避） */
@media (max-width:860px){
  .parallax,.hero--parallax{background-attachment:scroll;}
  .concepts{grid-template-columns:1fr;gap:24px;}
  .news-cols{grid-template-columns:1fr;}
  .ticker__more{display:none;}
  .float-cta{padding:.85em 1.1em;font-size:.86rem;}
}

/* ============================================================
   14. Responsive
   ============================================================ */
@media (max-width:1180px){
  .demo-cols--3 .demo-col--c{display:none;}
  .demo-cols{justify-content:center;}
}
@media (max-width:980px){
  .hero__grid{grid-template-columns:minmax(0,1fr) 320px;gap:36px;}
}
@media (max-width:860px){
  .hero__grid{grid-template-columns:1fr;gap:34px;}
  .hero__col-demo{height:clamp(340px,46vh,430px);}
  .demo-col--b{display:none;}
}
@media (max-width:1100px){
  .svc{grid-template-columns:74px 1fr minmax(auto,22em) auto;gap:clamp(14px,2.4vw,32px);}
}
@media (max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;}
  .footer-brand{grid-column:1/-1;}
  .works-page-grid{grid-template-columns:repeat(2,1fr);}
  .svc{grid-template-columns:60px 1fr;gap:4px 20px;}
  .svc__desc{grid-column:2/-1;margin-top:.5em;}
  .svc__mark{display:none;}
  .about-split{gap:clamp(28px,5vw,56px);}
}
@media (max-width:860px){
  .nav__menu,.nav__cta{display:none;}
  .nav-toggle{display:block;}
  .about-split{grid-template-columns:1fr;}
  .about-split__media{aspect-ratio:16/10;max-height:56vh;order:-1;}
  .news-row{grid-template-columns:118px 1fr auto;}
  .news-row__cat{display:none;}
  .contact-grid{grid-template-columns:1fr;}
  .statement__big{max-width:none;}
  .hero__title{font-size:clamp(2.4rem,8vw,4.4rem);}
  .feature-svc{grid-template-columns:1fr;}
  .feature-svc__media{aspect-ratio:16/9;}
  .feature-svc__body{padding:clamp(22px,4vw,32px);}
  .svc-detail{grid-template-columns:1fr;}
  .svc-detail__side{position:static;}
}
@media (max-width:680px){
  :root{--gutter:22px;}
  .section{padding-block:clamp(56px,14vw,92px);}
  .section--tight{padding-block:clamp(44px,11vw,72px);}
  .hero{min-height:88svh;padding-bottom:46px;}
  .hero__top{display:none;}
  .hero__eyebrow--m{display:flex;margin-bottom:1.1em;}
  .hero__scroll{display:none;}
  .hero__sub{margin-top:1.4em;}
  .hero__actions{gap:12px;margin-top:2em;}
  .hero__actions .btn{flex:1 1 auto;justify-content:center;}
  .works-grid,.works-page-grid{grid-template-columns:1fr;gap:32px;}
  .footer-top{grid-template-columns:1fr;gap:34px;padding-block:56px;}
  .footer-brand .brand{font-size:1.4rem;}
  .statement__meta{grid-template-columns:1fr 1fr;}
  .news-row{grid-template-columns:1fr auto;row-gap:.15em;padding-block:18px;}
  .news-row__date{grid-column:1/-1;order:-1;}
  .news-row__ar{display:none;}
  .page-hero{padding-top:clamp(116px,28vw,150px);}
  .head-row{margin-bottom:34px;}
  .footer-bottom{justify-content:flex-start;gap:14px 22px;flex-wrap:wrap;}
  .entry h2{font-size:1.3rem;}
  .contact-info dl{grid-template-columns:1fr;gap:.4em 0;}
  .contact-info dt{padding-top:1em;}
  .contact-info dt:first-child{padding-top:0;}
  .svc-cards{grid-template-columns:1fr;}
  .other-svc{grid-template-columns:1fr;}
  .hero__rotator{font-size:clamp(1rem,5vw,1.3rem);}
  .price-cards{grid-template-columns:1fr;}
  .proc-step{grid-template-columns:1fr;gap:4px;}
  .proc-step__no{font-size:2rem;}
  .reasons{grid-template-columns:1fr;gap:0;}
  .reason{border-top:1px solid var(--line);padding:1.4em 0;}
  .reason:first-child{border-top:2px solid var(--ink);}
  .browser,.demo-col{width:264px;}
  .mini-scale{transform:scale(.264);}
  .browser__view{height:398px;}
}
@media (max-width:430px){
  .statement__meta{grid-template-columns:1fr;}
  .hero__actions .btn{width:100%;}
  .btn{padding:1em 1.4em;}
  .hero__title{font-size:clamp(1.9rem,9vw,2.4rem);line-height:1.16;}
  .cta__title{font-size:clamp(1.7rem,7.5vw,2.3rem);}
  .statement__big{font-size:clamp(1.4rem,5.6vw,1.8rem);line-height:1.7;}
  .work-card__body{flex-direction:column;align-items:flex-start;gap:4px;}
  .work-card__cat{white-space:normal;}
  .svc__title{font-size:1.25rem;}
  .page-hero__lead{font-size:.96rem;}
  .page-hero__en{font-size:clamp(2.3rem,12vw,3rem);}
}

/* スマホ：本文を読みやすく＋積み重なる項目を線でグループ化 */
@media (max-width:680px){
  .lead{font-size:1rem;line-height:1.95;}
  .gm-body,.member__note{font-size:.98rem;line-height:1.9;}
  .page-hero__lead{font-size:1rem;line-height:1.9;}
  .media-rows,.flow-steps{gap:clamp(48px,13vw,72px);}
  /* スマホ：制作の流れは余白とタイポでフラットに整理 */
  .flow-step{display:block;}
  .flow-step__body{background:transparent;border:0;box-shadow:none;border-radius:0;margin:22px 0 0;padding:0;}
  .flow-step__title{font-size:1.5rem;line-height:1.4;margin-bottom:.5em;}
  .flow-step__desc{font-size:.96rem;line-height:1.9;max-width:none;}
  .flow-step__body::before{margin-bottom:1.1em;}
  /* スマホ：選ばれる理由は「写真＋見出し＋小本文＋ボタン」を一体カードに */
  .media-row{display:block;border:1px solid var(--line);background:var(--paper-2);overflow:hidden;}
  .media-row__media{aspect-ratio:16/10;border:0;}
  .media-row__body{margin:0;padding:20px 18px 22px;}
  .media-row__title{font-size:1.3rem;line-height:1.45;margin-bottom:.5em;}
  .media-row__desc{font-size:.88rem;line-height:1.85;color:var(--ink-2);}
  .media-row__body::before{margin-bottom:1em;}
  .media-row__btn{margin-top:1.4em;width:100%;justify-content:center;}
  /* about 代表挨拶／メッセージ：小さな丸写真＋本文を吹き出しにしてまとめる */
  .founder-split{display:block;}
  .founder-split__media{width:92px;flex:none;aspect-ratio:1/1;border-radius:50%;margin-bottom:14px;}
  .founder-split--rev .founder-split__media{order:0;}
  .founder-split__text{position:relative;background:var(--paper-2);border:1px solid var(--line);border-radius:16px;padding:18px 18px 20px;}
  .founder-split__text::before{content:"";position:absolute;left:30px;top:-9px;width:16px;height:16px;background:var(--paper-2);border-left:1px solid var(--line);border-top:1px solid var(--line);transform:rotate(45deg);}
  .founder-split .founder__body p{font-size:.98rem;line-height:1.92;}
  .founder-split .founder__lead{font-size:1.06rem;}
}

/* 横スクロールのヒント */
.slide-hint{margin-top:clamp(18px,2.4vw,28px);text-align:center;font-family:var(--ff-lat);font-size:.74rem;letter-spacing:.16em;color:var(--ink-3);}

/* スマホ／PCの出し分けユーティリティ（改行・要素） */
.u-sp{display:none;}
br.u-pc{display:inline;}
br.u-sp{display:none;}
@media (max-width:680px){
  .u-pc{display:none;}
  .u-sp{display:inline;}
  br.u-pc{display:none;}
  br.u-sp{display:inline;}
}

/* タッチ端末では「ホバーで動く」演出を無効化（タップ後の固着を防ぐ） */
@media (hover:none){
  .svc:hover,.news-row:hover{padding-left:0;}
  .work-card:hover .work-card__media img{transform:none;filter:grayscale(.2);}
}


/* WordPress 必須クラス */
.hero.has-media .btn--ghost{color:#fff;border-color:rgba(255,255,255,.55);}
.hero.has-media .btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff;}

/* モバイルメニュー番号（CSSカウンター） */
.mobile-nav__menu{counter-reset:mnav;}
.mobile-nav__menu a::before{
  counter-increment:mnav;
  content:counter(mnav,decimal-leading-zero);
  font-family:var(--ff-lat);font-size:.8rem;color:var(--accent);letter-spacing:.16em;
  margin-right:.9em;font-weight:600;vertical-align:.4em;
}

.screen-reader-text{position:absolute!important;clip:rect(1px,1px,1px,1px);width:1px;height:1px;overflow:hidden;}
[id]{scroll-margin-top:96px;}
.aligncenter{margin-inline:auto;}.alignright{float:right;margin-left:1.5em;}.alignleft{float:left;margin-right:1.5em;}
.wp-caption-text{font-size:.82rem;color:var(--ink-3);text-align:center;margin-top:.6em;}
.sticky,.bypostauthor{}
