/* ============================================================
   CodeClimb リッチ刷新v2 / 写真主役デザイン（2026-06-13）
   - 承認モック(mock-top.html v4)をテーマへ移植したスタイル
   - すべて .cc-page-home 配下にスコープ（他ページに影響しない／task#8で展開）
   - 色は #208CBA / #33657A + 白・濃淡のみ
   - corporate.css の後に読み込み、同一詳細度で上書き
   - モーションは prefers-reduced-motion で停止
   ============================================================ */
:root{
  --main:#208CBA; --sub:#33657A; --ink:#13262F; --ink2:#0C2530;
  --ctext:#27353B; --cmuted:#5C6E76; --ccloud:#F4F8FA; --cline:#E1E9ED;
  --m06:rgba(32,140,186,.06); --m10:rgba(32,140,186,.10); --m14:rgba(32,140,186,.14); --m30:rgba(32,140,186,.30);
  --cshadow:0 16px 40px -22px rgba(51,101,122,.40);
  --cshadow-lg:0 34px 70px -30px rgba(51,101,122,.50);
  --fhead:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  --fbody:"Noto Sans JP",sans-serif;
  --fnum:"Fraunces",serif;
  --dots:radial-gradient(rgba(32,140,186,.16) 1.2px,transparent 1.3px);
}
@keyframes ccLnUp{to{transform:translateY(0)}}
@keyframes ccMark{to{transform:scaleX(1)}}
@keyframes ccFadeUp{to{opacity:1;transform:none}}
@keyframes ccKen{from{transform:scale(1)}to{transform:scale(1.09)}}
@keyframes ccFloaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes ccSd{to{top:34px}}
@keyframes ccMq{to{transform:translateX(-50%)}}
@keyframes ccRise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

.cc-page-home{font-family:var(--fbody);color:var(--ctext);line-height:1.95;overflow-x:hidden}
.cc-page-home h1,.cc-page-home h2,.cc-page-home h3{font-family:var(--fhead);color:var(--ink);letter-spacing:.012em;font-weight:700}
.cc-page-home .wrap{max-width:1180px;margin:0 auto;padding:0 28px;position:relative;z-index:1}

/* eyebrow */
.cc-page-home .eyebrow{font-family:var(--fnum);font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--main);font-weight:500;display:inline-flex;align-items:center;gap:10px}
.cc-page-home .eyebrow::before{content:"";width:26px;height:1px;background:var(--main)}
.cc-page-home .eyebrow::after{content:"";width:5px;height:5px;border-radius:50%;background:var(--main);box-shadow:0 0 0 3px var(--m14)}
.cc-page-home .eyebrow.center{justify-content:center}

/* placeholder */
.cc-page-home .ph{position:relative;background:linear-gradient(135deg,#EAEFF2,#E2E9ED);border-radius:14px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cc-page-home .ph::after{content:attr(data-l);font-family:var(--fnum);font-size:12px;letter-spacing:.12em;color:#9DAAB1;position:relative;z-index:1}
.cc-page-home .ph::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(32,140,186,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(32,140,186,.05) 1px,transparent 1px);background-size:22px 22px}
.cc-page-home .ph.r43{aspect-ratio:4/3}.cc-page-home .ph.r45{aspect-ratio:4/5}.cc-page-home .ph.r169{aspect-ratio:16/9}

/* buttons */
.cc-page-home .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--fbody);font-weight:700;font-size:15px;padding:15px 28px;border-radius:11px;transition:.25s;cursor:pointer;border:1.5px solid transparent}
.cc-page-home .btn-primary{background:var(--main);color:#fff;box-shadow:0 14px 30px -12px rgba(32,140,186,.75)}
.cc-page-home .btn-primary:hover{background:#1a789f;transform:translateY(-2px);color:#fff}
.cc-page-home .btn-ghost{border-color:var(--cline);color:var(--ink);background:#fff}
.cc-page-home .btn-ghost:hover{border-color:var(--main);color:var(--main)}
.cc-page-home .btn-lg{padding:17px 34px;font-size:16px}
.cc-page-home .btn-block{width:100%}

/* ============ HERO ============ */
.cc-page-home .hero{position:relative;min-height:calc(100svh - 72px);display:flex;align-items:center;padding:36px 0;overflow:hidden;background:radial-gradient(120% 90% at 95% 10%,var(--m06),transparent 55%),#fff}
.cc-page-home .hero-wm{position:absolute;left:-1%;bottom:-4%;font-family:var(--fnum);font-weight:600;font-size:clamp(130px,21vw,300px);color:var(--m06);line-height:.8;letter-spacing:-.02em;z-index:0;pointer-events:none;user-select:none}
.cc-page-home .side-label{position:absolute;left:14px;top:42%;transform:rotate(180deg);writing-mode:vertical-rl;font-family:var(--fnum);font-size:11px;letter-spacing:.4em;color:var(--m30);z-index:2}
@media(max-width:1040px){.cc-page-home .side-label,.cc-page-home .hero-wm{display:none}}
.cc-page-home .hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:54px;align-items:center;width:100%}
.cc-page-home .hero-copy{position:relative;z-index:3}
.cc-page-home .hero-copy .eyebrow{margin-bottom:20px}
.cc-page-home .hero h1{font-size:clamp(32px,4.7vw,58px);font-weight:900;line-height:1.3;margin:0 0 26px}
.cc-page-home .hero h1 .ln{display:block;overflow:hidden}
.cc-page-home .hero h1 .ln>span{display:inline-block;transform:translateY(110%);animation:ccLnUp .9s cubic-bezier(.2,.7,.2,1) forwards}
.cc-page-home .hero h1 .ln:nth-child(1)>span{animation-delay:.05s}.cc-page-home .hero h1 .ln:nth-child(2)>span{animation-delay:.16s}.cc-page-home .hero h1 .ln:nth-child(3)>span{animation-delay:.27s}
.cc-page-home .hero h1 em{font-style:normal;color:var(--main)}
.cc-page-home .hero h1 .mark{position:relative;white-space:nowrap}
.cc-page-home .hero h1 .mark::after{content:"";position:absolute;left:-2px;right:-2px;bottom:.06em;height:.34em;background:var(--m30);z-index:-1;transform:scaleX(0);transform-origin:left;animation:ccMark .7s ease .95s forwards}
.cc-page-home .hero .fade{opacity:0;transform:translateY(14px);animation:ccFadeUp .8s ease forwards}
.cc-page-home .hero .lead{animation-delay:.5s}.cc-page-home .hero .hero-tags{animation-delay:.62s}.cc-page-home .hero .hero-cta{animation-delay:.72s}.cc-page-home .hero .assurance{animation-delay:.82s}
.cc-page-home .lead{font-size:17px;color:var(--ctext);line-height:2;max-width:33em}
.cc-page-home .hero-tags{display:flex;flex-wrap:wrap;gap:9px;margin:26px 0 30px}
.cc-page-home .hero-tags span{font-size:13px;font-weight:500;color:var(--sub);background:rgba(255,255,255,.7);border:1px solid var(--m14);padding:7px 14px;border-radius:999px;backdrop-filter:blur(4px)}
.cc-page-home .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.cc-page-home .assurance{display:flex;gap:22px;margin-top:26px;flex-wrap:wrap}
.cc-page-home .assurance span{font-size:12.5px;color:var(--cmuted);display:flex;align-items:center;gap:7px}
.cc-page-home .assurance span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--main);box-shadow:0 0 0 3px var(--m14)}

/* hero visual : 写真コンポジション */
.cc-page-home .hero-visual{position:relative;align-self:stretch;min-height:clamp(440px,72vh,650px);display:flex;align-items:center;justify-content:center;opacity:0;animation:ccFadeUp 1s ease .35s forwards}
.cc-page-home .hv-outline{position:absolute;width:48%;aspect-ratio:1;border:2px solid var(--m30);border-radius:50%;top:3%;right:0;z-index:0}
.cc-page-home .hv-dots{position:absolute;width:130px;height:130px;background:var(--dots);background-size:16px 16px;bottom:2%;left:2%;z-index:0;opacity:.7;-webkit-mask:radial-gradient(closest-side,#000,transparent);mask:radial-gradient(closest-side,#000,transparent)}
.cc-page-home .hv-line{position:absolute;width:2px;height:118%;top:-9%;left:28%;transform:rotate(19deg);background:linear-gradient(transparent,var(--m30),transparent);z-index:0}
.cc-page-home .hv-main{position:relative;width:73%;aspect-ratio:4/5;border-radius:22px;overflow:hidden;box-shadow:var(--cshadow-lg);z-index:2;background:#E2E9ED}
.cc-page-home .hv-slide{position:absolute;inset:0;opacity:0;border-radius:0;transition:opacity 1.6s ease}
.cc-page-home .hv-slide::before{opacity:.32}
.cc-page-home .hv-slide.is-active{opacity:1;animation:ccKen 9s ease-in-out infinite alternate}
.cc-page-home .hv-slide:nth-child(1){background:linear-gradient(135deg,#E7EDF0,#DAE3E8)}
.cc-page-home .hv-slide:nth-child(2){background:linear-gradient(135deg,#E1E9ED,#D3DDE3)}
.cc-page-home .hv-slide:nth-child(3){background:linear-gradient(135deg,#EAF0F2,#DEE7EB)}
.cc-page-home .hv-circle{position:absolute;border-radius:50%!important;overflow:hidden;box-shadow:var(--cshadow-lg);z-index:3;border:5px solid #fff}
.cc-page-home .hv-circle::after{font-size:10px}
.cc-page-home .hv-c1{width:33%;aspect-ratio:1;top:-2%;left:-5%;animation:ccFloaty 6s ease-in-out infinite}
.cc-page-home .hv-c2{width:23%;aspect-ratio:1;bottom:4%;right:-6%;animation:ccFloaty 7s ease-in-out infinite .9s}
.cc-page-home .hero-visual .badge{position:absolute;left:-3%;bottom:11%;z-index:4;background:rgba(255,255,255,.97);border:1px solid #fff;border-radius:14px;padding:14px 18px;box-shadow:var(--cshadow-lg);display:flex;align-items:center;gap:12px;animation:ccFloaty 5.5s ease-in-out infinite}
.cc-page-home .hero-visual .badge .nm{font-family:var(--fnum);font-size:28px;color:var(--main);font-weight:600;line-height:1}
.cc-page-home .hero-visual .badge .nm small{font-family:var(--fbody);font-size:12px;color:var(--cmuted)}
.cc-page-home .hero-visual .badge b{color:var(--ink);font-size:13px;display:block}.cc-page-home .hero-visual .badge small{display:block;font-size:10.5px;color:var(--cmuted)}
.cc-page-home .hero-visual .chip{position:absolute;right:-3%;top:6%;z-index:4;background:var(--ink2);color:#fff;border-radius:13px;padding:13px 17px;box-shadow:var(--cshadow-lg);animation:ccFloaty 6.5s ease-in-out infinite .6s}
.cc-page-home .hero-visual .chip .v{font-family:var(--fnum);font-size:24px;color:#7FCBE8;font-weight:600;line-height:1}
.cc-page-home .hero-visual .chip small{font-size:10.5px;color:rgba(255,255,255,.72);display:block;margin-top:3px}
.cc-page-home .scrolldown{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);z-index:5;font-family:var(--fnum);font-size:10px;letter-spacing:.3em;color:var(--cmuted);display:flex;flex-direction:column;align-items:center;gap:7px}
.cc-page-home .scrolldown i{width:1px;height:34px;background:linear-gradient(var(--main),transparent);position:relative;overflow:hidden}
.cc-page-home .scrolldown i::after{content:"";position:absolute;top:-34px;left:0;width:1px;height:34px;background:var(--main);animation:ccSd 1.8s ease-in-out infinite}
@media(max-width:880px){
  .cc-page-home .hero{min-height:auto;padding:30px 0 50px}.cc-page-home .hero-grid{grid-template-columns:1fr;gap:36px}
  .cc-page-home .hero-visual{order:-1;min-height:380px}
  .cc-page-home .hero h1 .ln>span,.cc-page-home .hero .fade,.cc-page-home .hero-visual{animation:none;opacity:1;transform:none}
  .cc-page-home .hero h1 .mark::after{animation:none;transform:scaleX(1)}.cc-page-home .scrolldown{display:none}
}

/* marquee */
.cc-page-home .marquee{border-top:1px solid var(--cline);border-bottom:1px solid var(--cline);background:var(--ccloud);overflow:hidden;white-space:nowrap;position:relative;z-index:2}
.cc-page-home .mq-track{display:inline-flex;padding:14px 0;animation:ccMq 26s linear infinite;will-change:transform}
.cc-page-home .mq-track span{font-family:var(--fnum);font-size:14px;letter-spacing:.06em;color:var(--sub);padding:0 26px;display:inline-flex;align-items:center}
.cc-page-home .mq-track span::before{content:"✦";color:var(--main);margin-right:26px;font-size:9px}

/* STATS */
.cc-page-home .stats{border-bottom:1px solid var(--cline);background:#fff;padding:0}
.cc-page-home .stats .wrap{display:grid;grid-template-columns:repeat(4,1fr)}
.cc-page-home .stat{padding:36px 24px;text-align:center;border-right:1px solid var(--cline)}
.cc-page-home .stat:last-child{border-right:0}
.cc-page-home .stat .n{font-family:var(--fnum);font-size:42px;font-weight:600;color:var(--ink);line-height:1}
.cc-page-home .stat .n small{font-family:var(--fbody);font-size:14px;font-weight:700;color:var(--main);margin-left:3px}
.cc-page-home .stat .l{font-size:12.5px;color:var(--cmuted);margin-top:10px;line-height:1.7}
@media(max-width:680px){.cc-page-home .stats .wrap{grid-template-columns:repeat(2,1fr)}.cc-page-home .stat:nth-child(2){border-right:0}.cc-page-home .stat:nth-child(1),.cc-page-home .stat:nth-child(2){border-bottom:1px solid var(--cline)}}

/* SECTION + あしらい */
.cc-page-home .s{padding:clamp(66px,8vw,112px) 0;position:relative;overflow:hidden}
.cc-page-home .s-cloud{background:var(--ccloud)}
.cc-page-home .s-dark{background:linear-gradient(150deg,var(--ink2),#0A3346);color:#fff}
.cc-page-home .deco-dots{position:absolute;width:160px;height:160px;background:var(--dots);background-size:18px 18px;opacity:.6;pointer-events:none;z-index:0}
.cc-page-home .deco-dots.tr{top:34px;right:24px;-webkit-mask:radial-gradient(closest-side,#000,transparent);mask:radial-gradient(closest-side,#000,transparent)}
.cc-page-home .deco-dots.bl{bottom:34px;left:24px;-webkit-mask:radial-gradient(closest-side,#000,transparent);mask:radial-gradient(closest-side,#000,transparent)}
.cc-page-home .s-index{position:absolute;font-family:var(--fnum);font-weight:600;font-size:clamp(90px,13vw,168px);color:var(--m06);line-height:.8;top:18px;right:4%;z-index:0;pointer-events:none}
.cc-page-home .s-dark .s-index{color:rgba(127,203,232,.07)}
.cc-page-home .s-head{max-width:720px;margin-bottom:48px}
.cc-page-home .s-head.center{margin:0 auto 52px;text-align:center}
.cc-page-home .s-head h2{font-size:clamp(25px,3.4vw,39px);margin:16px 0 14px;font-weight:900}
.cc-page-home .s-head p{color:var(--cmuted);font-size:15.5px}
.cc-page-home .s-dark .s-head h2{color:#fff}.cc-page-home .s-dark .s-head p{color:rgba(255,255,255,.78)}
.cc-page-home .g3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:880px){.cc-page-home .g3{grid-template-columns:1fr}}
.cc-page-home .card{background:#fff;border:1px solid var(--cline);border-radius:16px;padding:34px 28px 32px;box-shadow:var(--cshadow);transition:.28s;position:relative;overflow:hidden}
.cc-page-home .card::before{content:"";position:absolute;left:0;top:0;width:0;height:3px;background:var(--main);transition:.4s}
.cc-page-home .card:hover{transform:translateY(-6px);box-shadow:var(--cshadow-lg);border-color:var(--m30)}.cc-page-home .card:hover::before{width:100%}
.cc-page-home .card .num{font-family:var(--fnum);font-size:30px;font-weight:600;color:var(--m30);display:block;line-height:1;margin-bottom:6px}
.cc-page-home .card h3{font-size:18px;margin:0 0 10px}.cc-page-home .card p{font-size:14px;color:var(--cmuted);line-height:1.95}

/* services photo cards */
.cc-page-home .svc{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:880px){.cc-page-home .svc{grid-template-columns:1fr}}
.cc-page-home .svc-card{background:#fff;border:1px solid var(--cline);border-radius:18px;overflow:hidden;box-shadow:var(--cshadow);transition:.28s;display:flex;flex-direction:column}
.cc-page-home .svc-card:hover{transform:translateY(-7px);box-shadow:var(--cshadow-lg)}
.cc-page-home .svc-card .ph{border-radius:0;aspect-ratio:4/3}
.cc-page-home .svc-card .thumb{aspect-ratio:4/3;overflow:hidden}
.cc-page-home .svc-card .thumb img{width:100%;height:100%;object-fit:cover}
.cc-page-home .svc-card .bd{padding:26px 24px 28px;display:flex;flex-direction:column;flex:1}
.cc-page-home .svc-card .tag{font-family:var(--fnum);font-size:12px;letter-spacing:.14em;color:var(--sub);text-transform:uppercase}
.cc-page-home .svc-card h3{font-size:20px;margin:9px 0 10px}.cc-page-home .svc-card p{font-size:13.5px;color:var(--cmuted);flex:1}
.cc-page-home .svc-card .price{font-family:var(--fnum);font-size:30px;color:var(--ink);font-weight:600;margin:16px 0 4px}
.cc-page-home .svc-card .price small{font-family:var(--fbody);font-size:13px;font-weight:700;color:var(--cmuted)}
.cc-page-home .svc-card .link{margin-top:16px;color:var(--main);font-weight:700;font-size:14px;display:inline-flex;gap:6px}
.cc-page-home .svc-card .link::after{content:"→";transition:.25s}.cc-page-home .svc-card:hover .link::after{transform:translateX(4px)}

/* results */
.cc-page-home .res{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:880px){.cc-page-home .res{grid-template-columns:1fr}}
.cc-page-home .res-card{background:#fff;border:1px solid var(--cline);border-radius:16px;padding:34px 28px;box-shadow:var(--cshadow);position:relative;overflow:hidden}
.cc-page-home .res-card::before{content:"";position:absolute;left:0;top:0;width:4px;height:100%;background:linear-gradient(var(--main),var(--sub))}
.cc-page-home .res-card .big{font-family:var(--fnum);font-size:42px;color:var(--main);font-weight:600;line-height:1.05}
.cc-page-home .res-card .big small{font-family:var(--fbody);font-size:14px;font-weight:700;color:var(--sub);display:block;margin-top:4px}
.cc-page-home .res-card p{font-size:13.5px;color:var(--cmuted);margin-top:14px;line-height:1.95}

/* steps */
.cc-page-home .steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:st}
@media(max-width:880px){.cc-page-home .steps{grid-template-columns:1fr}}
.cc-page-home .step{padding:32px 26px;border:1px solid var(--cline);border-radius:16px;background:#fff;position:relative;box-shadow:var(--cshadow)}
.cc-page-home .step::before{counter-increment:st;content:"0" counter(st);font-family:var(--fnum);font-size:38px;color:var(--m30);font-weight:600;display:block;margin-bottom:8px}
.cc-page-home .step::after{content:"↗";position:absolute;right:-17px;top:50%;transform:translateY(-50%);color:var(--m30);font-size:20px}
.cc-page-home .step:last-child::after{display:none}@media(max-width:880px){.cc-page-home .step::after{display:none}}
.cc-page-home .step h3{font-size:17px;margin-bottom:8px}.cc-page-home .step p{font-size:13.5px;color:var(--cmuted)}

/* representative */
.cc-page-home .rep{display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
@media(max-width:880px){.cc-page-home .rep{grid-template-columns:1fr;gap:30px}}
.cc-page-home .rep-media{position:relative}.cc-page-home .rep-media .ph,.cc-page-home .rep-media img{box-shadow:var(--cshadow-lg);border-radius:18px;width:100%}
.cc-page-home .rep-media::before{content:"";position:absolute;inset:auto auto -16px -16px;width:60%;height:60%;border:2px solid var(--m30);border-radius:16px;z-index:-1}
.cc-page-home .rep h3{font-size:24px;margin-bottom:4px}
.cc-page-home .rep .role{font-family:var(--fnum);font-size:13px;color:var(--main);letter-spacing:.06em;margin-bottom:18px}
.cc-page-home .rep p{font-size:14.5px;color:var(--ctext);margin-bottom:14px}

/* AI org dark */
.cc-page-home .aiorg-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
@media(max-width:880px){.cc-page-home .aiorg-grid{grid-template-columns:1fr;gap:34px}}
.cc-page-home .s-dark .eyebrow{color:#7FCBE8}.cc-page-home .s-dark .eyebrow::before{background:#7FCBE8}.cc-page-home .s-dark .eyebrow::after{background:#7FCBE8;box-shadow:0 0 0 3px rgba(127,203,232,.2)}
.cc-page-home .aiorg p.ld{color:rgba(255,255,255,.8);font-size:15px;margin:16px 0 22px}
.cc-page-home .pills{display:flex;flex-wrap:wrap;gap:8px}
.cc-page-home .pills span{font-size:12.5px;color:#cfe8f3;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.05);padding:6px 13px;border-radius:999px}
.cc-page-home .nodes{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
.cc-page-home .node{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:14px;padding:15px;transition:.25s}
.cc-page-home .node:hover{background:var(--m14);border-color:var(--m30);transform:translateY(-3px)}
.cc-page-home .node.hub{grid-column:span 3;background:var(--m14);border-color:var(--m30)}
.cc-page-home .node .r{font-family:var(--fnum);font-size:12px;color:#7FCBE8;letter-spacing:.08em}
.cc-page-home .node h4{font-size:14px;color:#fff;margin:3px 0;font-family:var(--fhead);font-weight:700}
.cc-page-home .node p{font-size:11.5px;color:rgba(255,255,255,.66);line-height:1.6}
@media(max-width:560px){.cc-page-home .nodes{grid-template-columns:repeat(2,1fr)}.cc-page-home .node.hub{grid-column:span 2}}

/* pricing */
.cc-page-home .plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:880px){.cc-page-home .plans{grid-template-columns:1fr}}
.cc-page-home .plan{border:1px solid var(--cline);border-radius:18px;padding:34px 28px;background:#fff;box-shadow:var(--cshadow);text-align:center;transition:.28s}
.cc-page-home .plan:hover{transform:translateY(-6px);box-shadow:var(--cshadow-lg)}
.cc-page-home .plan.featured{border-color:var(--main);box-shadow:0 30px 60px -28px rgba(32,140,186,.5);position:relative}
.cc-page-home .plan.featured::before{content:"おすすめ";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--main);color:#fff;font-size:12px;font-weight:700;padding:5px 16px;border-radius:999px}
.cc-page-home .plan .name{font-family:var(--fnum);font-size:13px;letter-spacing:.16em;color:var(--sub);text-transform:uppercase}
.cc-page-home .plan h3{font-size:19px;margin:6px 0 14px}
.cc-page-home .plan .price{font-family:var(--fnum);font-size:36px;color:var(--ink);font-weight:600}
.cc-page-home .plan .price small{font-family:var(--fbody);font-size:13px;font-weight:700;color:var(--cmuted)}
.cc-page-home .plan .period{font-size:12.5px;color:var(--cmuted);margin:6px 0 18px}
.cc-page-home .plan ul{list-style:none;text-align:left;margin-bottom:22px;padding:0}
.cc-page-home .plan li{font-size:13.5px;color:var(--ctext);padding:8px 0 8px 24px;position:relative;border-bottom:1px dashed var(--cline)}
.cc-page-home .plan li::before{content:"";position:absolute;left:2px;top:15px;width:11px;height:6px;border-left:2px solid var(--main);border-bottom:2px solid var(--main);transform:rotate(-45deg)}

/* dynamic card (works/blog) reuse svc-card; voice */
.cc-page-home .voice-card{background:#fff;border:1px solid var(--cline);border-radius:16px;padding:28px 26px;box-shadow:var(--cshadow)}
.cc-page-home .voice-card h3{font-size:16px;margin:10px 0 8px}
.cc-page-home .voice-card p{font-size:13.5px;color:var(--cmuted)}
.cc-page-home .voice-card__score{font-family:var(--fnum);color:var(--main);font-weight:600}
.cc-page-home .voice-card__stars{color:var(--main)}
.cc-page-home .voice-card__meta{font-family:var(--fnum);font-size:11px;letter-spacing:.1em;color:var(--sub);margin-top:10px}
.cc-page-home .section-action{text-align:center;margin-top:36px;gap:1rem;}

/* final CTA */
.cc-page-home .fcta{position:relative;background:linear-gradient(150deg,var(--ink2),#0A3346);color:#fff;text-align:center;padding:clamp(66px,8vw,104px) 0;overflow:hidden}
.cc-page-home .fcta .deco-dots{opacity:.18}
.cc-page-home .fcta h2{color:#fff;font-size:clamp(25px,3.4vw,38px);margin-bottom:16px}
.cc-page-home .fcta p{color:rgba(255,255,255,.8);max-width:640px;margin:0 auto 30px;font-size:15px}
.cc-page-home .fcta .meta{font-size:12.5px;color:rgba(255,255,255,.55);margin-top:22px}

/* reveal */
.cc-page-home .rv{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
.cc-page-home .rv.in{opacity:1;transform:none}

/* ============ スクロール連動 背景あしらい ============ */
.cc-page-home{--sp:0;position:relative;z-index:0}
.cc-page-home>*{position:relative;z-index:1}
.cc-page-home .hero{background:transparent}                 /* 固定背景を透けさせる */
.cc-page-home .s-cloud{background:rgba(244,248,250,.80)}     /* 半透過で背景を覗かせる */
.cc-page-home .cc-bg{position:absolute;inset:0;z-index:-1;pointer-events:none;overflow:hidden;background:#fff}
.cc-page-home .cc-bg .orb{position:absolute;border-radius:50%;filter:blur(64px);will-change:transform}
.cc-page-home .cc-bg .orb1{width:48vmax;height:48vmax;left:-12vmax;top:-8vmax;background:radial-gradient(closest-side,var(--m14),transparent 70%);transform:translate3d(calc(var(--sp)*24vw),calc(var(--sp)*42vh),0)}
.cc-page-home .cc-bg .orb2{width:42vmax;height:42vmax;right:-14vmax;top:28vh;background:radial-gradient(closest-side,rgba(51,101,122,.12),transparent 70%);transform:translate3d(calc(var(--sp)*-28vw),calc(var(--sp)*-32vh),0)}
.cc-page-home .cc-bg .orb3{width:36vmax;height:36vmax;left:32vw;bottom:-16vmax;background:radial-gradient(closest-side,var(--m10),transparent 70%);transform:translate3d(calc(var(--sp)*18vw),calc(var(--sp)*-54vh),0)}
.cc-page-home .cc-bg .bgdots{position:absolute;inset:0;background:var(--dots);background-size:28px 28px;opacity:.45;-webkit-mask:radial-gradient(120% 70% at 78% calc(var(--sp)*100%),#000,transparent 66%);mask:radial-gradient(120% 70% at 78% calc(var(--sp)*100%),#000,transparent 66%)}
/* 登る プログレスライン（スクロールで伸びる） */
.cc-page-home .cc-progress{position:fixed;top:0;right:26px;width:2px;height:100vh;z-index:3;pointer-events:none}
.cc-page-home .cc-progress::before{content:"";position:absolute;inset:0;background:var(--cline);opacity:.6}
.cc-page-home .cc-progress::after{content:"";position:absolute;left:0;top:0;width:100%;height:100%;background:linear-gradient(var(--main),var(--sub));transform-origin:top;transform:scaleY(var(--sp));box-shadow:0 0 10px var(--m30)}
.cc-page-home .cc-progress .dot{position:absolute;left:50%;top:calc(var(--sp)*100%);transform:translate(-50%,-50%);width:9px;height:9px;border-radius:50%;background:var(--main);box-shadow:0 0 0 4px var(--m14),0 0 14px var(--main)}
@media(max-width:880px){.cc-page-home .cc-progress{right:10px}}

@media(prefers-reduced-motion:reduce){
  .cc-page-home .rv{opacity:1!important;transform:none!important;transition:none!important}
  .cc-page-home .hero h1 .ln>span,.cc-page-home .hero .fade,.cc-page-home .hero-visual{animation:none!important;opacity:1!important;transform:none!important}
  .cc-page-home .hero h1 .mark::after{animation:none!important;transform:scaleX(1)!important}
  .cc-page-home .mq-track,.cc-page-home .hero-visual .badge,.cc-page-home .hero-visual .chip,.cc-page-home .hv-circle,.cc-page-home .hv-slide.is-active,.cc-page-home .scrolldown i::after{animation:none!important}
  .cc-page-home .cc-bg .orb{transform:none!important}            /* 動きを止める（位置は固定） */
}
