/* ============================================================
   ZEN コーポレートサイト v2（アセットパック版トップページ）
   ベース: zen_top_complete_asset_pack/05_tokens/design_tokens.css
   v2: 5視点監査（忠実度/デザイン/モーション/コード/データ整合）反映
   ============================================================ */
:root{
  --bg:#050506;
  --bg2:#0b0b0d;
  --card:rgba(18,18,20,.82);
  --card-solid:#121214;
  --border:rgba(255,255,255,.14);
  --border-soft:rgba(255,255,255,.08);
  --txt:#ffffff;
  --muted:rgba(255,255,255,.68);
  --muted2:rgba(255,255,255,.58);
  --orange:#ff6a00;
  --pink:#ff1768;
  --magenta:#d92eff;
  --purple:#6f31ff;
  --blue:#21a8ff;
  --grad:linear-gradient(90deg,var(--orange),var(--pink) 48%,var(--purple));
  --r-sm:10px;--r-md:16px;--r-lg:24px;
  --shadow:0 24px 80px rgba(0,0,0,.55);
  --container:1400px;
  --font-ja:"Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --font-en:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:76px}
body{background:var(--bg);color:var(--txt);font-family:var(--font-ja);-webkit-font-smoothing:antialiased;font-feature-settings:"palt";overflow-x:hidden}
/* フィルムグレイン（参照モックの質感。pointer-events無効・ごく薄く） */
body::after{content:"";position:fixed;inset:0;background:url(../assets/ui/noise_overlay.svg);opacity:.32;pointer-events:none;z-index:900}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer}
.en{font-family:var(--font-en)}
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
::selection{background:rgba(255,23,104,.5)}
:focus-visible{outline:2px solid var(--pink);outline-offset:3px;border-radius:4px}

/* ---------- 共通: ボタン ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;border-radius:999px;font-weight:700;font-size:14px;letter-spacing:.04em;padding:14px 26px;border:0;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,background-color .35s,border-color .35s,background-position .5s cubic-bezier(.2,.8,.2,1);white-space:nowrap}
.btn .ar{display:inline-block;transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.btn:hover .ar{transform:translateX(5px)}
.btn-grad{position:relative;color:#fff;background:linear-gradient(90deg,var(--orange),var(--pink) 55%,var(--magenta));background-size:170% 100%;background-position:0% 0;box-shadow:0 8px 30px rgba(255,23,104,.35)}
.btn-grad:hover{background-position:90% 0;transform:translateY(-2px);box-shadow:0 14px 40px rgba(255,23,104,.5)}
.btn-ghost{color:#fff;background:rgba(0,0,0,.25);border:1px solid var(--border)}
.btn-ghost:hover{border-color:rgba(255,255,255,.45);background:rgba(255,255,255,.06);transform:translateY(-2px)}
.btn-sm{padding:10px 20px;font-size:12.5px}

/* ---------- 共通: セクションラベル ---------- */
.sec{position:relative;padding:20px 0}
.sec-label{display:flex;align-items:center;gap:12px;font-size:14.5px;font-weight:900;letter-spacing:.08em;margin-bottom:14px}
.sec-label::before{content:"";width:4px;height:18px;border-radius:2px;background:var(--grad);flex-shrink:0}
.sec-label h2{font-size:inherit;font-weight:inherit;letter-spacing:inherit}
.sec-label .more{margin-left:auto;font-size:12.5px;font-weight:700;color:var(--muted);display:inline-flex;align-items:center;gap:7px;transition:color .3s}
.sec-label .more:hover{color:#fff}
.sec-label .more .ar{transition:transform .3s}
.sec-label .more:hover .ar{transform:translateX(4px)}

/* ---------- リビール（JS有効時のみ隠す） ---------- */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.js .reveal.is-in{opacity:1;transform:none}
.js .reveal[data-d="1"]{transition-delay:.08s}.js .reveal[data-d="2"]{transition-delay:.16s}.js .reveal[data-d="3"]{transition-delay:.24s}.js .reveal[data-d="4"]{transition-delay:.32s}.js .reveal[data-d="5"]{transition-delay:.4s}
/* リストは行単位の自動ステガー */
.js .news-list li.reveal:nth-child(2),.js .tips-list li.reveal:nth-child(2){transition-delay:.1s}
.js .news-list li.reveal:nth-child(3),.js .tips-list li.reveal:nth-child(3){transition-delay:.2s}

/* ============================================================
   HEADER
   ============================================================ */
.header{position:fixed;inset:0 0 auto 0;z-index:100;transition:background-color .4s,border-color .4s;border-bottom:1px solid transparent}
.header.is-scrolled{background:rgba(5,5,6,.8);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom-color:var(--border-soft)}
.header-in{max-width:var(--container);margin:0 auto;padding:10px 32px;display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
.brand .zen{font-family:var(--font-en);font-weight:900;font-size:26px;letter-spacing:-.04em;line-height:1}
.brand .sub{display:flex;flex-direction:column;gap:2px}
.brand .sub b{font-size:11px;font-weight:700;letter-spacing:.13em}
.brand .sub span{font-size:10px;color:var(--muted2);letter-spacing:.08em}
.gnav{display:flex;align-items:center;gap:2px;margin-left:auto}
.gnav a{position:relative;font-size:13px;font-weight:700;letter-spacing:.06em;padding:9px 12px;color:rgba(255,255,255,.85);transition:color .3s;white-space:nowrap}
.gnav a[aria-current="page"]{color:#fff}
.gnav a[aria-current="page"]::after{transform:scaleX(1)}
.gnav a::after{content:"";position:absolute;left:12px;right:12px;bottom:3px;height:2px;border-radius:2px;background:var(--grad);transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.gnav a:hover{color:#fff}
.gnav a:hover::after{transform:scaleX(1);transform-origin:left}
.header-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}
.menu-btn{display:none}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:560px;padding:124px 0 20px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-collage{position:absolute;top:0;right:0;width:78%;height:100%;display:grid;grid-template-columns:1.5fr 1fr;grid-template-rows:1.25fr 1fr;gap:3px;opacity:1}
.hero-collage .cell{position:relative;overflow:hidden}
.hero-collage .cell img{width:100%;height:100%;object-fit:cover;filter:saturate(1.15) brightness(1.06);animation:kenburns 26s ease-in-out infinite alternate}
.hero-collage .cell:nth-child(2) img{animation-delay:-9s;object-position:50% 22%}
.hero-collage .cell:nth-child(3) img{animation-delay:-17s;object-position:50% 60%}
.hero-collage .cell.tall{grid-row:1/3;grid-column:2}
@keyframes kenburns{0%{transform:scale(1) translate(0,0)}100%{transform:scale(1.1) translate(-1.6%,1.2%)}}
/* スクロール連動の控えめパララックス（対応ブラウザのみ） */
@supports(animation-timeline:scroll()){
  .hero-collage{animation:heroPar linear both;animation-timeline:scroll();animation-range:0 100vh}
  @keyframes heroPar{to{transform:translateY(48px)}}
}
.hero-scrim{position:absolute;inset:0;background:
  linear-gradient(90deg,var(--bg) 14%,rgba(5,5,6,.9) 32%,rgba(5,5,6,.34) 56%,rgba(5,5,6,.04) 78%,rgba(5,5,6,0) 100%);
}
.hero-scrim::after{content:"";position:absolute;inset:auto 0 0 0;height:70px;background:linear-gradient(180deg,transparent,var(--bg))}
.hero-scrim::before{content:"";position:absolute;inset:0 0 auto 0;height:64px;background:linear-gradient(0deg,transparent,rgba(5,5,6,.5))}
/* ネオンストリーク（テキスト外・右上空間に1本のみ、ごく控えめ） */
.streak{position:absolute;width:300px;height:1.5px;background:linear-gradient(90deg,transparent,rgba(255,106,0,.7),rgba(255,23,104,.7),transparent);filter:blur(.5px);opacity:0;transform:rotate(-22deg);animation:streak 11s ease-in-out infinite;pointer-events:none}
@keyframes streak{0%,80%{opacity:0;translate:-8vw 6vh}88%{opacity:.35}100%{opacity:0;translate:16vw -8vh}}
.hero-in{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1fr) 430px;align-items:center;gap:28px}
.hero-copy h1{font-size:clamp(30px,3.6vw,50px);font-weight:900;line-height:1.34;letter-spacing:.015em;word-break:keep-all;text-shadow:0 2px 18px rgba(0,0,0,.55)}
.hero-copy h1 .grad{background:linear-gradient(100deg,var(--orange),var(--pink) 85%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-copy h1 .hl2 .grad{background-image:linear-gradient(100deg,var(--pink),var(--magenta) 85%)}
.hero-copy .lead{margin-top:18px;font-size:15px;line-height:1.95;color:var(--muted);max-width:30em;text-shadow:0 1px 10px rgba(0,0,0,.6)}
.hero-copy .hero-btns{margin-top:26px;display:flex;gap:14px;flex-wrap:wrap}
/* ロード時ステージング */
.hl{opacity:0;transform:translateY(30px);animation:hin 1s cubic-bezier(.2,.7,.2,1) forwards}
.hl2{animation-delay:.15s}.hl3{animation-delay:.3s}
@keyframes hin{to{opacity:1;transform:none}}
/* スマホモック */
.hero-phone{position:relative;justify-self:center;perspective:1100px;animation:phonein 1.2s cubic-bezier(.2,.7,.2,1) .25s both}
@keyframes phonein{from{opacity:0;transform:translateY(46px)}to{opacity:1;transform:translateY(0)}}
.phone-tilt{transform:rotate(-3deg);transition:transform .25s ease-out;will-change:transform;animation:phonefloat 7s ease-in-out infinite}
@keyframes phonefloat{0%,100%{translate:0 0}50%{translate:0 -11px}}
.phone{position:relative;width:262px;height:534px;border-radius:42px;background:#070707;border:3px solid #3c3c42;box-shadow:0 36px 80px rgba(0,0,0,.65),0 0 0 1px rgba(255,255,255,.06);padding:10px}
.phone::before{content:"";position:absolute;top:10px;left:calc(50% - 44px);width:88px;height:23px;background:#070707;border-radius:0 0 13px 13px;z-index:3}
.phone-screen{position:relative;width:100%;height:100%;border-radius:33px;overflow:hidden;background:#111}
.phone-screen::after{content:"";position:absolute;inset:0;z-index:1;background:rgba(5,5,6,.14);pointer-events:none}
.phone-screen video{width:100%;height:100%;object-fit:cover}
.phone-ui{position:absolute;inset:0;z-index:2;pointer-events:none}
.phone-ui .pu-top{position:absolute;top:0;left:0;right:0;padding:13px 15px 24px;background:linear-gradient(180deg,rgba(0,0,0,.55),transparent);display:flex;align-items:center;gap:9px}
.phone-ui .pu-top img{width:28px;height:28px;border-radius:50%;border:1.5px solid rgba(255,255,255,.7);object-fit:cover}
.phone-ui .pu-top b{font-size:11.5px;letter-spacing:.04em}
.phone-ui .pu-side{position:absolute;right:9px;bottom:66px;display:flex;flex-direction:column;gap:15px;align-items:center}
.phone-ui .pu-side svg{width:23px;height:23px;filter:drop-shadow(0 1px 4px rgba(0,0,0,.6))}
.phone-ui .pu-bottom{position:absolute;left:0;right:0;bottom:0;padding:22px 15px 13px;background:linear-gradient(0deg,rgba(0,0,0,.6),transparent);font-size:10.5px;color:rgba(255,255,255,.92);line-height:1.6}
/* 浮遊チップ（実測データ。存在感は控えめに） */
.float-chip{position:absolute;z-index:3;background:rgba(12,12,16,.88);border:1px solid var(--border);border-radius:13px;padding:10px 15px;box-shadow:0 14px 40px rgba(0,0,0,.5);animation:chipfloat 6s ease-in-out infinite}
.float-chip .t{font-size:9px;color:var(--muted2);letter-spacing:.05em;font-weight:700}
.float-chip .n{font-family:var(--font-en);font-size:19px;font-weight:800;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.float-chip .n small{font-family:var(--font-ja);font-size:10.5px;font-weight:700;color:var(--muted);margin-left:2px}
.float-chip.fc1{top:72px;right:-22px;animation-delay:-2s}
.float-chip.fc2{bottom:104px;left:-30px;animation-delay:-4s}
@keyframes chipfloat{0%,100%{translate:0 0}50%{translate:0 -8px}}
/* 画面外では演出を停止（省電力） */
.is-off .cell img,.is-off .streak,.is-off .phone-tilt,.is-off .float-chip{animation-play-state:paused}

/* ============================================================
   メディアデータバー
   ============================================================ */
.media-data{margin-top:-26px}
.media-data .container{position:relative}
.media-data .container::before{content:"";position:absolute;inset:-20px 0 auto;height:300px;background:radial-gradient(820px 320px at 90% -20%,rgba(111,49,255,.05),transparent 70%);pointer-events:none}
.md-head{display:flex;align-items:baseline;gap:12px;margin-bottom:12px;flex-wrap:wrap;row-gap:2px}
.md-head h2{font-size:15px;font-weight:900;letter-spacing:.06em;display:flex;align-items:center;gap:12px;white-space:nowrap}
.md-head h2::before{content:"";width:4px;height:17px;border-radius:2px;background:var(--grad)}
.md-head .asof{font-size:11px;color:var(--muted2);letter-spacing:.06em}
.md-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}
.md-card{display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--border-soft);border-radius:var(--r-md);padding:14px 18px;backdrop-filter:blur(8px);transition:transform .4s cubic-bezier(.2,.8,.2,1),border-color .4s,box-shadow .4s;position:relative;overflow:hidden}
.md-card::after{content:"";position:absolute;inset:auto 0 0 0;height:2px;background:var(--grad);opacity:0;transition:opacity .4s}
.md-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2);box-shadow:0 16px 44px rgba(0,0,0,.45)}
.md-card:hover::after{opacity:1}
.md-ic{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:
  linear-gradient(var(--card-solid),var(--card-solid)) padding-box,
  conic-gradient(from 210deg,var(--orange),var(--pink),var(--magenta),var(--purple),var(--orange)) border-box;
  border:2px solid transparent}
.md-ic svg{width:19px;height:19px}
.md-card .lab{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.05em}
.md-card .val{font-family:var(--font-en);font-size:23px;font-weight:800;letter-spacing:-.01em;line-height:1.3;font-variant-numeric:tabular-nums}
.md-card .val small{font-family:var(--font-ja);font-size:12px;font-weight:700;margin-left:1px}
.md-card .val .approx{font-family:var(--font-ja);font-size:13px;font-weight:700;margin-right:2px}
.md-card .note{font-size:10.5px;color:var(--muted2);letter-spacing:.04em;opacity:.85}

/* ============================================================
   主なサービス
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.svc-card{position:relative;display:flex;flex-direction:column;min-height:186px;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border-soft);background:var(--card-solid);transition:transform .45s cubic-bezier(.2,.8,.2,1),border-color .45s,box-shadow .45s}
.svc-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.22);box-shadow:var(--shadow)}
.svc-card .ph{position:absolute;inset:0}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;object-position:72% 50%;opacity:.85;transition:transform .8s cubic-bezier(.2,.7,.2,1),opacity .5s}
.svc-card:hover .ph img{transform:scale(1.06);opacity:.95}
.svc-card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,7,9,.97) 24%,rgba(7,7,9,.78) 48%,rgba(7,7,9,.28) 74%,rgba(7,7,9,.12)),linear-gradient(0deg,rgba(7,7,9,.45),transparent 40%)}
.svc-card .body{position:relative;z-index:1;display:flex;flex-direction:column;height:100%;padding:19px 21px;gap:8px}
.svc-chip{display:inline-flex;align-items:center;gap:9px;font-size:16px;font-weight:900;letter-spacing:.05em}
.svc-chip .ic{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff}
.svc-chip .ic svg{width:16px;height:16px}
.svc-card.gourmet .svc-chip .ic{background:linear-gradient(135deg,#ff8a00,#ff4d00)}
.svc-card.works .svc-chip .ic{background:linear-gradient(135deg,#8a4bff,#5f2bd9)}
.svc-card.sns .svc-chip .ic{background:linear-gradient(135deg,#ff2d78,#d92eff)}
.svc-card p{font-size:12.5px;color:var(--muted);line-height:1.85;max-width:24em;text-shadow:0 1px 8px rgba(0,0,0,.6)}
.svc-card .cta{margin-top:auto}
.svc-card .cta .btn{padding:8px 18px;font-size:12px;background:rgba(0,0,0,.35)}

/* ============================================================
   目的から探す
   ============================================================ */
.purpose-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}
.pp-card{position:relative;display:flex;align-items:center;gap:15px;min-height:102px;padding:18px 52px 18px 20px;border-radius:var(--r-md);overflow:hidden;isolation:isolate;transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .45s}
.pp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.pp-card .ph{position:absolute;inset:0;z-index:-2}
.pp-card .ph img{width:100%;height:100%;object-fit:cover;object-position:78% 50%;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.pp-card:hover .ph img{transform:scale(1.07)}
.pp-card .tint{position:absolute;inset:0;z-index:-1;opacity:.74;transition:opacity .45s}
.pp-card:hover .tint{opacity:.64}
.pp-card.p1 .tint{background:linear-gradient(95deg,#c63d00 0%,#e8480a 38%,rgba(255,77,0,.58) 60%,rgba(180,30,40,.15) 100%)}
.pp-card.p1 .ph img{object-position:92% 50%}
.pp-card.p2 .tint{background:linear-gradient(95deg,#b3104f 0%,rgba(217,32,120,.72) 42%,rgba(140,20,120,.18) 100%)}
.pp-card.p3 .tint{background:linear-gradient(95deg,#4a1ed6 0%,rgba(111,49,255,.72) 42%,rgba(60,30,160,.22) 100%)}
.pp-ic{flex-shrink:0;width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.35);display:grid;place-items:center}
.pp-ic svg{width:22px;height:22px}
.pp-card h3{font-size:18px;font-weight:900;letter-spacing:.04em;text-shadow:0 1px 10px rgba(0,0,0,.45)}
.pp-card p{margin-top:5px;font-size:12px;line-height:1.75;color:rgba(255,255,255,.92);text-shadow:0 1px 8px rgba(0,0,0,.5)}
.pp-card .ar{position:absolute;right:17px;top:50%;translate:0 -50%;width:29px;height:29px;border-radius:50%;border:1px solid rgba(255,255,255,.5);display:grid;place-items:center;transition:transform .4s cubic-bezier(.2,.8,.2,1),background-color .4s}
.pp-card .ar svg{width:14px;height:14px}
.pp-card:hover .ar{transform:translateX(5px);background:rgba(255,255,255,.18)}

/* ============================================================
   事例インタビュー
   ============================================================ */
.case-grid{display:grid;grid-template-columns:230px repeat(4,1fr);gap:13px;align-items:stretch}
.case-intro{display:flex;flex-direction:column;gap:11px;padding:20px;border-radius:var(--r-md);background:var(--card);border:1px solid var(--border-soft)}
.case-intro h2{font-size:17px;font-weight:900;letter-spacing:.05em;display:flex;align-items:center;gap:11px}
.case-intro h2::before{content:"";width:4px;height:17px;border-radius:2px;background:var(--grad)}
.case-intro p{font-size:12.5px;color:var(--muted);line-height:1.9}
.case-intro .btn{margin-top:auto;align-self:flex-start}
.case-card{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border-soft);background:var(--card-solid);display:flex;flex-direction:column;transition:transform .45s cubic-bezier(.2,.8,.2,1),border-color .45s,box-shadow .45s}
.case-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.22);box-shadow:var(--shadow)}
.case-thumb{position:relative;aspect-ratio:16/10.2;overflow:hidden}
.case-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.case-card:hover .case-thumb img{transform:scale(1.07)}
.case-thumb::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.3))}
.case-cat{position:absolute;top:10px;left:10px;z-index:2;font-size:10px;font-weight:800;letter-spacing:.06em;padding:4px 11px;border-radius:999px;background:rgba(8,8,10,.74);border:1px solid rgba(255,255,255,.35)}
.case-play{position:absolute;inset:0;z-index:2;display:grid;place-items:center}
.case-play .pbtn{width:42px;height:42px;border-radius:50%;background:rgba(10,10,12,.55);border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(4px);display:grid;place-items:center;transition:transform .4s cubic-bezier(.2,.8,.2,1),background .4s,border-color .4s}
.case-card:hover .case-play .pbtn{transform:scale(1.1);background:linear-gradient(135deg,var(--pink),var(--magenta));border-color:transparent}
.case-play svg{width:15px;height:15px;fill:#fff;margin-left:2px}
/* 動画尺バッジ（対談動画URL確定後に値を設定して表示） */
.case-dur{position:absolute;right:9px;bottom:9px;z-index:2;font-family:var(--font-en);font-size:10px;font-weight:700;padding:3px 7px;border-radius:5px;background:rgba(8,8,10,.72)}
.case-card .cap{padding:11px 14px 13px;display:flex;flex-direction:column;gap:4px}
.case-card .cap b{font-size:13px;font-weight:800;line-height:1.6}
.case-card .cap span{font-size:11px;color:var(--muted2);letter-spacing:.04em}

/* ============================================================
   お知らせ / お役立ち情報
   ============================================================ */
.info-grid{display:grid;grid-template-columns:1.06fr 1fr;gap:38px}
.news-list li{border-bottom:1px solid var(--border-soft)}
.news-list li:first-child{border-top:1px solid var(--border-soft)}
.news-list .row{display:grid;grid-template-columns:44px 86px 1fr;gap:0 14px;align-items:center;padding:13px 6px;transition:background-color .3s}
.news-list .new{grid-column:1;justify-self:start}
.news-list time{grid-column:2}
.news-list .tt{grid-column:3}
.news-list .row:hover{background:rgba(255,255,255,.035)}
.news-list .new{flex-shrink:0;font-family:var(--font-en);font-size:9px;font-weight:800;letter-spacing:.1em;padding:3px 8px;border-radius:5px;background:var(--pink);color:#fff}
.news-list time{flex-shrink:0;font-family:var(--font-en);font-size:12px;color:var(--muted2);letter-spacing:.04em}
.news-list .tt{font-size:13px;font-weight:500;color:rgba(255,255,255,.88);line-height:1.7;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical}
.tips-list li{border-bottom:1px solid var(--border-soft)}
.tips-list li:first-child{border-top:1px solid var(--border-soft)}
.tips-row{display:flex;align-items:center;gap:13px;padding:10px 6px}
.tips-row .th{flex-shrink:0;width:60px;height:42px;border-radius:8px;overflow:hidden}
.tips-row .th img{width:100%;height:100%;object-fit:cover}
.tips-row .tt{font-size:13px;font-weight:500;color:rgba(255,255,255,.88);line-height:1.7}
.tips-row .soon{flex-shrink:0;margin-left:auto;font-size:10px;font-weight:700;color:var(--muted2);border:1px solid var(--border-soft);border-radius:999px;padding:4px 11px;letter-spacing:.08em}

/* ============================================================
   ボトムCTA
   ============================================================ */
.cta-band{position:relative;margin-top:28px;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--grad);background-size:220% 100%;animation:gradflow 5s linear infinite;z-index:2}
@keyframes gradflow{0%{background-position:0% 0}100%{background-position:220% 0}}
.cta-band.is-off::before{animation-play-state:paused}
.cta-bg{position:absolute;inset:0}
.cta-bg img{position:absolute;top:0;height:100%;object-fit:cover}
.cta-bg .bg-l{left:0;width:53%;object-position:50% 40%}
.cta-bg .bg-r{right:0;width:47%;object-position:50% 30%}
.cta-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,5,6,.82) 0%,rgba(5,5,6,.5) 45%,rgba(5,5,6,.55) 100%)}
.cta-btns .btn-ghost{border-color:rgba(255,255,255,.55);background:rgba(5,5,6,.55)}
.cta-in{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-start;gap:30px;padding:38px 32px;max-width:var(--container);margin:0 auto;flex-wrap:wrap}
.cta-in h2{font-size:clamp(19px,2.2vw,25px);font-weight:900;letter-spacing:.06em;text-shadow:0 1px 12px rgba(0,0,0,.5)}
.cta-in p{margin-top:8px;font-size:12.5px;color:rgba(255,255,255,.85);letter-spacing:.04em;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.cta-in .cta-btns{margin-left:46px;display:flex;gap:14px;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--border-soft);background:#040405}
.footer-in{max-width:var(--container);margin:0 auto;padding:24px 32px 26px;display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.footer .brand .zen{font-size:24px}
.fnav{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.fnav a{font-size:12.5px;font-weight:500;color:var(--muted);padding:12px 11px;transition:color .3s}
.fnav a:hover{color:#fff}
.f-right{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.socials{display:flex;flex-direction:column;gap:9px;align-items:flex-end}
.socials .sns-row{display:flex;align-items:center;gap:9px}
.socials .sns-lab{font-size:10.5px;font-weight:700;letter-spacing:.04em;color:var(--muted);white-space:nowrap;margin-right:1px}
.socials a{color:rgba(255,255,255,.78);transition:transform .35s,color .35s;display:grid;place-items:center}
.socials a:hover{transform:translateY(-3px);color:#fff}
.socials svg{width:18px;height:18px}
.copyright{font-family:var(--font-en);font-size:11px;color:var(--muted2);letter-spacing:.06em}
.f-company{font-size:10.5px;color:var(--muted2);line-height:1.8;text-align:right}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media(max-width:1240px) and (min-width:1101px){
  .hero-in{grid-template-columns:minmax(0,1fr) 400px}
  .hero-copy h1{font-size:clamp(30px,3.3vw,42px)}
}
@media(max-width:1360px){
  .gnav{display:none}
  .menu-btn{display:grid;place-items:center;width:42px;height:42px;margin-left:auto;background:none;border:1px solid var(--border);border-radius:10px;color:#fff}
  .menu-btn svg{width:20px;height:20px}
  .header-cta .btn-ghost{display:none}
}
@media(max-width:1100px){
  .hero-in{grid-template-columns:1fr;gap:44px}
  .hero-phone{justify-self:center}
  .md-grid{grid-template-columns:repeat(2,1fr)}
  .svc-grid,.purpose-grid{grid-template-columns:1fr;gap:13px}
  .case-grid{grid-template-columns:repeat(2,1fr)}
  .case-intro{grid-column:1/-1;flex-direction:row;align-items:center}
  .case-intro .btn{margin-top:0;margin-left:auto}
  .info-grid{grid-template-columns:1fr;gap:28px}
  .cta-in .cta-btns{margin-left:0}
  .f-right{margin-left:0;align-items:flex-start}
  .f-right .socials{align-items:flex-start}
  .f-company{text-align:left}
}
@media(max-width:640px){
  html{scroll-padding-top:68px}
  .cta-bg::after{background:linear-gradient(90deg,rgba(5,5,6,.9) 0%,rgba(5,5,6,.74) 55%,rgba(5,5,6,.58) 100%)}
  .cta-bg .bg-r{object-position:50% 14%}
  .cta-in .btn{width:100%;max-width:340px;justify-content:center}
  .hero-btns{flex-direction:column;align-items:stretch}
  .hero-btns .btn{justify-content:center}
  .container{padding:0 22px}
  .header-in{padding:10px 18px;gap:12px}
  .header-cta .btn{padding:10px 16px;font-size:11.5px}
  .brand .sub{display:none}
  .hero{padding:108px 0 46px;min-height:0}
  .hero-collage{width:100%;opacity:.5}
  .hero-scrim{background:linear-gradient(180deg,rgba(5,5,6,.82) 0%,rgba(5,5,6,.55) 55%,var(--bg) 100%)}
  .hero-copy h1{font-size:clamp(24px,7.4vw,30px)}
  .hero-copy .lead{font-size:13.5px}
  .phone{width:236px;height:482px}
  .float-chip.fc1{right:-6px}
  .float-chip.fc2{left:-8px}
  .md-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .md-card{flex-direction:column;align-items:flex-start;gap:8px;padding:15px 16px}
  .md-card .val{font-size:21px}
  .md-head .asof{width:100%;padding-left:16px}
  .case-grid{grid-template-columns:1fr}
  .case-intro{flex-direction:column;align-items:flex-start}
  .news-list .row{flex-wrap:wrap;row-gap:4px}
  .news-list .tt{width:100%;-webkit-line-clamp:2}
  .cta-in{padding:34px 22px}
  .footer-in{padding:22px 22px}
}
/* モバイルメニュー */
.m-nav{position:fixed;inset:0;z-index:200;background:rgba(5,5,6,.96);backdrop-filter:blur(16px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s,visibility .35s}
.m-nav.is-open{opacity:1;visibility:visible;pointer-events:auto}
.m-nav a{font-size:19px;font-weight:800;padding:13px 30px;letter-spacing:.08em}
.m-nav .close{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:none;color:#fff;font-size:20px}

/* ---------- use参照アイコンの共通描画 ---------- */
.icn{fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ---------- ?snap スクリーンショットモード ---------- */
.snap .reveal{opacity:1 !important;transform:none !important;filter:none !important;transition:none !important}
.snap .hl,.snap .hero-phone{animation:none;opacity:1;transform:none}

/* ---------- reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
  .js .reveal{opacity:1;transform:none}
}

/* ============================================================
   下層ページ共通コンポーネント（gourmet / works / agency / company / recruit）
   ============================================================ */
/* 金アクセント（徳島グルメ） */
.gold{background:linear-gradient(100deg,#f6d56a,#e8b53a 60%,#c9952a);-webkit-background-clip:text;background-clip:text;color:transparent}
/* ページヒーロー（1枚写真背景） */
.page-hero{position:relative;min-height:520px;padding:120px 0 56px;overflow:hidden}
.page-hero .ph-bg{position:absolute;inset:0}
.page-hero .ph-bg img{width:100%;height:100%;object-fit:cover;animation:kenburns 30s ease-in-out infinite alternate}
.page-hero .ph-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,5,6,.92) 22%,rgba(5,5,6,.66) 48%,rgba(5,5,6,.28) 75%,rgba(5,5,6,.18));}
.page-hero .ph-bg::before{content:"";position:absolute;inset:auto 0 0 0;height:110px;background:linear-gradient(180deg,transparent,var(--bg));z-index:1}
.page-hero .hero-in{align-items:center}
.page-hero h1{font-size:clamp(28px,3.4vw,46px);font-weight:900;line-height:1.42;letter-spacing:.02em;word-break:keep-all;text-shadow:0 2px 18px rgba(0,0,0,.55)}
/* 月桂樹バッジ */
.laurel-badge{display:inline-flex;align-items:center;gap:12px;margin-top:20px;padding:10px 18px;border:1px solid rgba(246,213,106,.35);border-radius:12px;background:rgba(20,16,8,.55)}
.laurel-badge svg{width:30px;height:30px;color:#e8b53a}
.laurel-badge .lb-t{font-size:11px;color:var(--muted);letter-spacing:.06em;font-weight:700}
.laurel-badge .lb-n{font-size:15px;font-weight:900;letter-spacing:.04em}
.laurel-badge .lb-n .en{font-size:17px}
.laurel-badge .lb-sub{font-size:10.5px;color:var(--muted2)}
/* IGプロフィール風フォン */
.profile-ui{position:absolute;inset:0;z-index:2;background:#0b0b0d;display:flex;flex-direction:column;pointer-events:none}
.profile-ui .pr-head{display:flex;align-items:center;gap:8px;padding:12px 13px 6px;font-size:11.5px;font-weight:700}
.profile-ui .pr-main{display:flex;align-items:center;gap:14px;padding:8px 14px}
.profile-ui .pr-main img{width:56px;height:56px;border-radius:50%;border:2px solid rgba(255,255,255,.25);object-fit:cover}
.profile-ui .pr-stats{display:flex;gap:14px}
.profile-ui .pr-stats div{text-align:center}
.profile-ui .pr-stats b{display:block;font-family:var(--font-en);font-size:13.5px;line-height:1.2}
.profile-ui .pr-stats span{font-size:8.5px;color:var(--muted2);white-space:nowrap}
.profile-ui .pr-bio{padding:2px 14px 8px;font-size:9.5px;line-height:1.65;color:rgba(255,255,255,.85)}
.profile-ui .pr-bio b{font-size:10.5px;display:block}
.profile-ui .pr-chips{display:flex;gap:5px;padding:0 14px 9px;flex-wrap:wrap}
.profile-ui .pr-chips span{font-size:8.5px;padding:3px 9px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}
.profile-ui .pr-grid{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:2px;overflow:hidden;align-content:start}
.profile-ui .pr-grid img{width:100%;aspect-ratio:1;object-fit:cover}
/* 浮遊ポストカード */
.post-card{position:absolute;z-index:3;width:148px;border-radius:13px;overflow:hidden;background:#101014;border:1px solid var(--border);box-shadow:0 18px 50px rgba(0,0,0,.55);animation:chipfloat 7s ease-in-out infinite}
.post-card img{width:100%;aspect-ratio:1/1.05;object-fit:cover}
.post-card .pc-cap{padding:8px 11px 10px}
.post-card .pc-cap b{display:block;font-size:11px;letter-spacing:.04em}
.post-card .pc-cap span{display:block;margin-top:2px;font-size:9px;color:var(--muted2);line-height:1.5}
/* お悩み */
.worry-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.worry{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:20px 10px 18px;background:var(--card);border:1px solid var(--border-soft);border-radius:var(--r-md)}
.worry .w-ic{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;background:
  linear-gradient(var(--card-solid),var(--card-solid)) padding-box,
  conic-gradient(from 210deg,var(--orange),var(--pink),var(--magenta),var(--purple),var(--orange)) border-box;
  border:2px solid transparent}
.worry .w-ic svg{width:22px;height:22px}
.worry p{font-size:11.5px;line-height:1.75;color:rgba(255,255,255,.85);font-weight:500}
/* ライトカードセクション（とは？/流れ/声） */
.light-card{background:#f7f4ec;color:#1c1a16;border-radius:var(--r-lg);padding:30px 34px}
.light-card .sec-label,.light-card h2{color:#1c1a16}
.light-card .muted{color:#6b665c}
/* フロー図（飲食店→徳島グルメ→見つけたい人） */
.flow-3{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap;margin-top:8px}
.flow-3 .fl-node{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;min-width:130px}
.flow-3 .fl-circle{width:92px;height:92px;border-radius:50%;display:grid;place-items:center;border:2px solid #d8d2c2;background:#fff}
.flow-3 .fl-circle svg{width:34px;height:34px;color:#7a6a45}
.flow-3 .fl-circle.brand{border-color:#ff1768}
.flow-3 .fl-circle.brand .fl-brand{font-size:13px;font-weight:900;background:linear-gradient(100deg,var(--orange),var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1.4}
.flow-3 .fl-node b{font-size:13.5px;letter-spacing:.04em}
.flow-3 .fl-node span{font-size:10.5px;color:#6b665c;line-height:1.6}
.flow-3 .fl-ar{font-size:20px;color:#2da44e;font-weight:900}
/* できること4カード */
.cando-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cando{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border-soft);background:var(--card-solid);min-height:208px;display:flex;flex-direction:column}
.cando .cd-ph{height:108px;overflow:hidden;flex-shrink:0}
.cando .cd-ph img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.cando:hover .cd-ph img{transform:scale(1.06)}
.cando .cd-body{padding:13px 15px 15px;display:flex;flex-direction:column;gap:6px}
.cando .cd-body b{font-size:13.5px;letter-spacing:.04em}
.cando .cd-body p{font-size:11px;color:var(--muted);line-height:1.8}
/* ステップ（流れ・ライト） */
.step-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:11px}
.step{background:#f7f4ec;color:#1c1a16;border-radius:14px;padding:16px 14px 15px;display:flex;flex-direction:column;gap:8px;position:relative}
.step .st-no{font-family:var(--font-en);font-size:10.5px;font-weight:800;letter-spacing:.14em;color:#73694b}
.step b{font-size:13px;letter-spacing:.03em}
.step p{font-size:10.5px;color:#6b665c;line-height:1.7}
.step::after{content:"▶";position:absolute;right:-11px;top:50%;translate:0 -50%;font-size:9px;color:#5b564a;z-index:2}
.step:last-child::after{content:none}
/* お客様の声 */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.voice{background:#f7f4ec;color:#1c1a16;border-radius:14px;padding:20px 22px;display:flex;flex-direction:column;gap:10px}
.voice .v-q{font-size:14.5px;font-weight:800;line-height:1.8}
.voice .v-q::before{content:"“";color:#c9952a;font-size:22px;margin-right:2px}
.voice .v-src{font-size:10.5px;color:#6b665c;margin-top:auto}
/* FAQ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 36px}
.faq-item{border-bottom:1px solid var(--border-soft)}
.faq-item summary{display:flex;align-items:center;gap:12px;padding:15px 4px;font-size:13.5px;font-weight:700;cursor:pointer;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .q{color:var(--pink);font-family:var(--font-en);font-weight:800;flex-shrink:0}
.faq-item summary .pm{margin-left:auto;flex-shrink:0;color:var(--muted2);transition:transform .3s}
.faq-item[open] summary .pm{transform:rotate(45deg)}
.faq-item .a{padding:0 4px 16px 30px;font-size:12.5px;color:var(--muted);line-height:1.95}
/* 4カラム変種（インラインstyle禁止。メディアクエリで正しく畳む） */
.case-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.step-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.step-grid.cols-4 .step:nth-child(3)::after{content:"▶"}
.step-grid.cols-4 .step:nth-child(4)::after{content:none}
.hero-in.solo{grid-template-columns:minmax(0,1fr)}
/* 下層レスポンシブ */
@media(max-width:1100px){
  .case-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .step-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .step-grid.cols-4 .step:nth-child(2n)::after{content:none}
  .worry-grid{grid-template-columns:repeat(3,1fr)}
  .cando-grid{grid-template-columns:repeat(2,1fr)}
  .step-grid{grid-template-columns:repeat(3,1fr)}
  .step:nth-child(3)::after{content:none}
  .voice-grid{grid-template-columns:1fr}
  .faq-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .page-hero{min-height:0;padding:104px 0 44px}
  .page-hero .lead br{display:none}
  .case-grid.cols-4{grid-template-columns:1fr}
  .step-grid.cols-4{grid-template-columns:1fr 1fr}
  .worry-grid .worry:last-child:nth-child(odd){grid-column:1/-1}
  .sec-label{flex-wrap:wrap}
  .post-card{display:none}
  .post-card.keep{display:block;top:20px;right:2px;left:auto;width:112px}
  .profile-ui .pr-stats{gap:9px}
  .profile-ui .pr-main{gap:10px}
  .worry-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .cando-grid{grid-template-columns:1fr}
  .step-grid{grid-template-columns:1fr 1fr}
  .step:nth-child(2n)::after{content:none}
  .step:nth-child(3)::after{content:"▶"}
  .light-card{padding:22px 20px}
  .post-card{width:118px}
  .flow-3 .fl-ar{transform:rotate(90deg)}
  .flow-3{flex-direction:column}
}

/* ============================================================
   v3追加: リールマーキー / 配色テーマ / お問い合わせフォーム
   ============================================================ */
/* ---- リールマーキー（実投稿動画が横に流れ続ける） ---- */
.reel-section{padding:24px 0 8px}
.reel-marquee{overflow-x:auto;overflow-y:hidden;margin-top:18px;width:100vw;margin-left:calc(50% - 50vw);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  scrollbar-width:none;cursor:grab;-webkit-overflow-scrolling:touch}
.reel-marquee::-webkit-scrollbar{display:none}
.reel-marquee.dragging{cursor:grabbing}
.reel-marquee.dragging .reel-item{pointer-events:none}
.reel-track{display:flex;gap:14px;width:max-content;padding:18px 0 20px;user-select:none;-webkit-user-select:none}
.reel-item{width:176px;aspect-ratio:9/16;border-radius:12px;overflow:hidden;border:1px solid var(--border-soft);flex-shrink:0;position:relative;background:#0b0b0d;box-shadow:0 14px 36px rgba(0,0,0,.4)}
.reel-item:nth-child(even){transform:translateY(16px)}
.reel-item img,.reel-item video{width:100%;height:100%;object-fit:cover;display:block}
.reel-item .rl-badge{position:absolute;left:8px;bottom:8px;z-index:2;display:flex;align-items:center;gap:5px;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.7)}
.reel-item .rl-badge svg{width:12px;height:12px;fill:#fff}
.reel-item::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.35),transparent 40%);pointer-events:none}
@media(max-width:600px){.reel-item{width:132px}}

/* ---- 配色テーマ: 徳島ワークス = 黒ベース×青アクセント ---- */
body.theme-works{--orange:#1f6bff;--pink:#2b8fff;--magenta:#36c5ff;--purple:#1746b8;
  --grad:linear-gradient(90deg,#1f6bff,#2b8fff 48%,#36c5ff)}
body.theme-works .btn-grad{background:linear-gradient(90deg,#1f6bff,#2b8fff 55%,#36c5ff);box-shadow:0 8px 30px rgba(43,143,255,.35)}
body.theme-works .btn-grad:hover{box-shadow:0 14px 40px rgba(43,143,255,.5)}
body.theme-works .page-hero .ph-bg::after{background:linear-gradient(90deg,rgba(4,8,16,.94) 20%,rgba(6,12,24,.62) 48%,rgba(6,12,24,.22) 76%,rgba(6,12,24,.1)),linear-gradient(0deg,rgba(4,8,16,.5),transparent 42%)}
body.theme-works{background:#04060c}
body.theme-works .footer,body.theme-works .cta-bg::after{background-color:#04060c}
body.theme-works .msg-body .msg-eyebrow{color:#2b8fff}

/* ---- 配色テーマ: 徳島グルメ = 赤アクセント（ホットペッパーグルメ風）＋白寄りライト ---- */
body.theme-gourmet{--orange:#e60023;--pink:#ff2d2d;--magenta:#ff5a3c;--purple:#c20a1f;
  --grad:linear-gradient(90deg,#e60023,#ff2d2d 48%,#ff5a3c)}
body.theme-gourmet .btn-grad{background:linear-gradient(90deg,#e60023,#ff2d2d 55%,#ff5a3c);box-shadow:0 8px 30px rgba(230,0,35,.32)}
body.theme-gourmet .btn-grad:hover{box-shadow:0 14px 40px rgba(230,0,35,.5)}
body.theme-gourmet .light-card{background:#fbfbfa;border:1px solid #ececea}
body.theme-gourmet .step,body.theme-gourmet .voice{background:#fbfbfa;border:1px solid #ececea}
body.theme-gourmet .flow-3 .fl-circle{background:#fff;border-color:#f0c9cd}
body.theme-gourmet .flow-3 .fl-circle.brand{border-color:#e60023}

/* ---- お問い合わせフォーム ---- */
.cform-wrap{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.cform-lead h2,.cform-lead h3{font-size:clamp(20px,2.4vw,28px);font-weight:900;letter-spacing:.04em;line-height:1.5}
.cform-lead p{margin-top:14px;font-size:13.5px;color:var(--muted);line-height:2}
.cform-lead .cf-mail{margin-top:20px;display:inline-flex;align-items:center;gap:9px;font-family:var(--font-en);font-size:14px;color:#fff;border:1px solid var(--border);border-radius:10px;padding:11px 16px}
.cform-lead .cf-mail svg{width:17px;height:17px}
.cform{background:var(--card);border:1px solid var(--border-soft);border-radius:var(--r-lg);padding:26px 26px 24px;backdrop-filter:blur(8px)}
.cform label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin:0 0 6px;letter-spacing:.03em}
.cform label .req{color:var(--pink);margin-left:4px}
.cform .field{margin-bottom:15px}
.cform input,.cform textarea,.cform select{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.32);border-radius:10px;padding:12px 14px;color:#fff;font-family:inherit;font-size:14px;transition:border-color .25s,background-color .25s}
.cform input:focus,.cform textarea:focus,.cform select:focus{outline:none;border-color:var(--pink);background:rgba(0,0,0,.45)}
.cform textarea{resize:vertical;min-height:104px;line-height:1.7}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.cform .agree{display:flex;align-items:flex-start;gap:9px;margin:4px 0 16px;font-size:11.5px;color:var(--muted);line-height:1.7}
.cform .agree input{width:auto;margin-top:2px}
.cform .agree a{color:#fff;text-decoration:underline}
.cform .submit{width:100%;justify-content:center}
.cform .cf-note{margin-top:12px;font-size:10.5px;color:var(--muted2);line-height:1.7}
@media(max-width:900px){.cform-wrap{grid-template-columns:1fr;gap:24px}}
@media(max-width:600px){.cform .row2{grid-template-columns:1fr}}

/* ============================================================
   v6追加: YouTube事例（facade方式）/ コラム枠（撮影の裏側）
   動画ID一元管理: 各カードの href と data-yt と img src の ID を揃える。
   チャンネル移行時は ID 3箇所＋assets/yt/ID.jpg を差し替えるだけ。
   ============================================================ */
.yt-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.yt-card{position:relative;display:flex;flex-direction:column;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border-soft);background:var(--card-solid);transition:transform .45s cubic-bezier(.2,.8,.2,1),border-color .45s,box-shadow .45s}
.yt-card:hover{transform:translateY(-5px);border-color:rgba(255,255,255,.22);box-shadow:var(--shadow)}
.yt-thumb{position:relative;aspect-ratio:16/9;overflow:hidden;background:#000}
.yt-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.yt-card:hover .yt-thumb img{transform:scale(1.05)}
.yt-thumb iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.yt-play{position:absolute;inset:0;z-index:2;display:grid;place-items:center;cursor:pointer;background:linear-gradient(0deg,rgba(0,0,0,.28),rgba(0,0,0,.08))}
.yt-play .ytb{width:62px;height:44px;border-radius:11px;background:#ff0000;display:grid;place-items:center;box-shadow:0 8px 26px rgba(0,0,0,.5);transition:transform .35s cubic-bezier(.2,.8,.2,1),background-color .3s}
.yt-card:hover .yt-play .ytb{transform:scale(1.08);background:#ff2323}
.yt-play .ytb svg{width:22px;height:22px;fill:#fff;margin-left:2px}
.yt-cat{position:absolute;top:10px;left:10px;z-index:3;font-size:10px;font-weight:800;letter-spacing:.05em;padding:4px 10px;border-radius:999px;background:rgba(8,8,10,.78);border:1px solid rgba(255,255,255,.28)}
.yt-card .yt-cap{padding:13px 15px 15px;display:flex;flex-direction:column;gap:6px}
.yt-card .yt-cap b{font-size:13px;font-weight:800;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.yt-card .yt-cap .yt-store{font-size:11px;color:var(--muted2);letter-spacing:.03em}
.yt-card .yt-cap .yt-result{margin-top:2px;font-size:12px;font-weight:800}
.yt-card .yt-cap .yt-result .grad-t{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
@media(max-width:1100px){.yt-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.yt-grid{grid-template-columns:1fr}}

/* コラム枠（撮影の裏側 / 取材ノート） */
.column-head{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.column-head .ch-sub{font-size:12px;color:var(--muted);letter-spacing:.04em;margin-bottom:2px}
.column-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.col-card{display:grid;grid-template-columns:300px minmax(0,1fr);gap:0;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border-soft);background:var(--card-solid);transition:transform .45s cubic-bezier(.2,.8,.2,1),border-color .45s,box-shadow .45s}
.col-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.2);box-shadow:var(--shadow)}
.col-card .yt-thumb{aspect-ratio:auto;height:100%;min-height:170px}
.col-card .col-body{padding:18px 20px;display:flex;flex-direction:column;gap:8px;justify-content:center}
.col-card .col-tag{font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--orange)}
.col-card .col-body b{font-size:14px;font-weight:800;line-height:1.6}
.col-card .col-body p{font-size:12px;color:var(--muted);line-height:1.85}
.col-card .col-more{margin-top:2px;font-size:11.5px;font-weight:700;color:var(--muted);display:inline-flex;align-items:center;gap:6px}
.col-card .col-more svg{width:13px;height:13px;fill:#fff}
@media(max-width:900px){.column-grid{grid-template-columns:1fr}}
@media(max-width:600px){.col-card{grid-template-columns:1fr}.col-card .yt-thumb{aspect-ratio:16/9;min-height:0}}

/* 総フォロワーチップの「約」 */
.float-chip .n .approx{font-family:var(--font-ja);font-size:13px;font-weight:700;margin-right:1px}

/* ============================================================
   v10: モーション強化パッケージ（最先端感・お！となる動き）
   ============================================================ */
/* スクロール進捗バー（最上部） */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:300;background:var(--grad);box-shadow:0 0 14px rgba(255,90,60,.6);will-change:width}

/* リビールを上質に：ブラーが晴れながら浮き上がる */
.js .reveal{opacity:0;transform:translateY(34px) scale(.985);filter:blur(8px);
  transition:opacity .85s cubic-bezier(.2,.75,.2,1),transform .85s cubic-bezier(.2,.75,.2,1),filter .8s ease}
.js .reveal.is-in{opacity:1;transform:none;filter:blur(0)}

/* ボタン：ホバーで光沢が走る */
.btn-grad{position:relative;overflow:hidden;isolation:isolate}
.btn-grad::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,transparent 20%,rgba(255,255,255,.4) 50%,transparent 80%);transform:translateX(-130%) skewX(-18deg)}
.btn-grad:hover::after{animation:sheen .85s ease}
@keyframes sheen{to{transform:translateX(130%) skewX(-18deg)}}

/* オーロラ（背景に漂う色光・最先端SaaS感） */
.aurora{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.aurora b{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45;mix-blend-mode:screen;animation:auroraDrift 20s ease-in-out infinite}
.aurora .a1{width:44vw;height:44vw;left:-10%;top:-14%;background:radial-gradient(circle,rgba(255,106,0,.5),transparent 64%)}
.aurora .a2{width:40vw;height:40vw;right:-8%;top:2%;background:radial-gradient(circle,rgba(217,46,255,.42),transparent 64%);animation-delay:-7s}
.aurora .a3{width:36vw;height:36vw;left:34%;bottom:-22%;background:radial-gradient(circle,rgba(33,168,255,.38),transparent 64%);animation-delay:-13s}
@keyframes auroraDrift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(7%,5%) scale(1.14)}66%{transform:translate(-6%,-4%) scale(.92)}}
.is-off .aurora b{animation-play-state:paused}

/* カード：ホバーで持ち上がり＋色付きの影 */
.svc-card,.pp-card,.md-card,.case-card,.yt-card,.cando,.worry{transition:transform .5s cubic-bezier(.2,.8,.2,1),box-shadow .5s,border-color .4s}
.md-card:hover,.worry:hover{transform:translateY(-5px)}
.svc-card:hover,.case-card:hover,.yt-card:hover,.cando:hover{box-shadow:0 26px 60px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.06)}

/* ヒーロー: スマホ群の3D視差土台 */
.hero-phone,.page-hero .hero-phone{perspective:1200px}
.dual-phones{transform-style:preserve-3d;transition:transform .25s cubic-bezier(.2,.8,.2,1)}
.dual-phones .dp{transition:transform .35s cubic-bezier(.2,.8,.2,1)}

/* セクション見出しバー：軽い発光のパルス */
.sec-label::before,.md-head h2::before{box-shadow:0 0 12px rgba(255,90,60,.4)}

@media(prefers-reduced-motion:reduce){
  .aurora b{animation:none}
  .js .reveal{filter:none;transform:none}
  .scroll-progress{display:none}
}

/* ヒーロー用オーロラは控えめ（左の暗部だけ色を載せる） */
.hero-aurora{z-index:1}
.hero-aurora b{opacity:.28}
.hero-aurora .a1{left:-12%;top:-10%}
.hero-aurora .a3{left:6%;bottom:-20%;background:radial-gradient(circle,rgba(217,46,255,.4),transparent 64%)}

/* ============================================================
   v13: カーソル追従ライン（光の線が尾を引く）＋ クリック波紋
   ============================================================ */
.cursor-canvas{position:fixed;inset:0;width:100vw;height:100vh;pointer-events:none;z-index:6;mix-blend-mode:screen}
/* クリック波紋（水面のように広がるリング） */
.ripple{position:fixed;border-radius:50%;pointer-events:none;z-index:5;border:2px solid var(--rc,#ff5a3c);
  transform:translate(-50%,-50%) scale(0);opacity:.6;mix-blend-mode:screen;animation:rippleExpand .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rippleExpand{to{transform:translate(-50%,-50%) scale(1);opacity:0}}
@media(prefers-reduced-motion:reduce){.cursor-canvas{display:none}}
@media(hover:none){.cursor-canvas{display:none}}

.skip-link{position:absolute;left:-9999px;top:0;z-index:2000;background:var(--orange);color:#fff;padding:11px 20px;border-radius:0 0 10px 0;font-size:13px;font-weight:800;text-decoration:none}
.skip-link:focus{left:0}
