:root {
--navy: #0d2240;
--navyD: #091a33;
--cyan: #00c2e0;
--cyan2: #00a8c4;
--cyanL: #ecfafd;
--cyanLL: #f4fcfe;
--text: #1c2a3a;
--sub: #5d6d7e;
--light: #f6f8fb;
--line: #e4e9ef;
} *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
font-family: 'Noto Sans JP', system-ui, sans-serif;
color: var(--text);
font-size: 16px;
line-height: 1.9;
background: #fff;
-webkit-font-smoothing: antialiased;
overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; } .nav {
position: fixed; top: 0; left: 0; width: 100%; z-index: 999;
height: 72px; display: flex; align-items: center; justify-content: space-between;
padding: 0 48px;
background: transparent;
transition: background .4s, box-shadow .4s, backdrop-filter .4s;
}
.nav.solid {
background: rgba(255,255,255,.96); backdrop-filter: blur(20px);
box-shadow: 0 1px 20px rgba(13,34,64,.05);
} .nav--page {
background: rgba(255,255,255,.96); backdrop-filter: blur(20px);
box-shadow: 0 1px 20px rgba(13,34,64,.05);
}
.nav-logo img { height: 24px; width: auto; transition: filter .3s; }
.nav:not(.solid):not(.nav--page) .nav-logo img { filter: brightness(0) invert(1); }
.nav-links { display: flex; align-items: center; gap: 32px; }
.nav-links a {
font-size: 13px; font-weight: 500;
letter-spacing: .03em; transition: color .2s, opacity .2s;
}
.nav:not(.solid):not(.nav--page) .nav-links a { color: rgba(255,255,255,.7); }
.nav:not(.solid):not(.nav--page) .nav-links a:hover { color: #fff; }
.nav.solid .nav-links a,
.nav--page .nav-links a { color: var(--sub); }
.nav.solid .nav-links a:hover,
.nav--page .nav-links a:hover { color: var(--navy); }
.nav-cta {
font-size: 13px; font-weight: 600; color: #fff !important;
background: var(--navy); padding: 9px 22px; border-radius: 980px;
transition: background .2s; letter-spacing: .03em;
}
.nav:not(.solid):not(.nav--page) .nav-cta {
background: rgba(255,255,255,.15); border: 1px solid rgba(255,255,255,.2);
}
.nav-cta:hover { background: var(--cyan) !important; } .nav-hamburger {
display: none;
width: 32px; height: 32px;
background: none; border: none; cursor: pointer;
position: relative; z-index: 1001;
}
.nav-hamburger span {
display: block; width: 20px; height: 2px;
background: var(--navy); margin: 4px auto;
transition: all .3s;
}
.nav:not(.solid):not(.nav--page) .nav-hamburger span {
background: #fff;
} .wrap { max-width: 1100px; margin: 0 auto; padding: 0 48px; }
.section { padding: 100px 0; }
.sec-label {
font-size: 11px; font-weight: 600; letter-spacing: .22em;
color: var(--cyan2); text-transform: uppercase; margin-bottom: 14px;
}
.sec-title {
font-size: clamp(24px, 2.8vw, 34px);
font-weight: 700; color: var(--navy); line-height: 1.5; margin-bottom: 14px;
}
.sec-lead { font-size: 15px; color: var(--sub); line-height: 2; max-width: 780px; } .page-hero {
padding: 140px 0 60px;
background: var(--light);
}
.page-hero .breadcrumb {
font-size: 12px; color: var(--sub); margin-bottom: 24px;
}
.page-hero .breadcrumb a { color: var(--cyan2); transition: color .2s; }
.page-hero .breadcrumb a:hover { color: var(--navy); }
.page-hero h1 {
font-size: clamp(26px, 3vw, 36px);
font-weight: 700; color: var(--navy); line-height: 1.5;
} .footer { background: var(--navyD); padding: 56px 0 32px; }
.footer-top {
display: flex; justify-content: space-between; align-items: flex-start;
padding-bottom: 36px; border-bottom: 1px solid rgba(255,255,255,.12);
}
.footer-logo img { height: 20px; width: auto; filter: brightness(0) invert(1); opacity: .85; }
.footer-logo-sub { font-size: 11px; color: rgba(255,255,255,.45); margin-top: 8px; }
.footer-nav { display: flex; gap: 36px; }
.footer-nav-col h4 {
font-size: 10px; font-weight: 600; letter-spacing: .14em;
color: rgba(255,255,255,.5); margin-bottom: 12px; text-transform: uppercase;
}
.footer-nav-col a {
display: block; font-size: 12px; color: rgba(255,255,255,.65);
margin-bottom: 8px; transition: color .2s;
}
.footer-nav-col a:hover { color: var(--cyan); }
.footer-bottom {
display: flex; justify-content: space-between; align-items: center; padding-top: 24px;
}
.footer-copy { font-size: 11px; color: rgba(255,255,255,.4); }
.footer-policy { font-size: 11px; }
.footer-policy a { color: rgba(255,255,255,.55); transition: color .2s; }
.footer-policy a:hover { color: var(--cyan); } .reveal {
opacity: 0; transform: translateY(32px);
transition: opacity .7s cubic-bezier(.25,.46,.45,.94), transform .7s cubic-bezier(.25,.46,.45,.94);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: .1s; }
.reveal-d2 { transition-delay: .2s; }
.reveal-d3 { transition-delay: .3s; }
.reveal-left {
opacity: 0; transform: translateX(-40px);
transition: opacity .8s ease, transform .8s ease;
}
.reveal-left.visible { opacity: 1; transform: translateX(0); }
@keyframes fade-in { to { opacity: 1; } }
@keyframes slide-up {
from { opacity: 0; transform: translateY(30px); }
to { opacity: 1; transform: translateY(0); }
} .news-list { display: flex; flex-direction: column; }
.news-item {
display: grid; grid-template-columns: 110px 100px 1fr; gap: 20px;
align-items: center;
padding: 20px 0; border-bottom: 1px solid var(--line);
transition: all .2s;
}
.news-item:first-child { border-top: 1px solid var(--line); }
.news-item:hover { background: var(--cyanLL); padding-left: 16px; padding-right: 16px; margin: 0 -16px; }
.news-date { font-size: 13px; font-weight: 400; color: var(--sub); font-variant-numeric: tabular-nums; }
.news-tag {
font-size: 11px; font-weight: 600; letter-spacing: .04em;
color: var(--cyan2); background: var(--cyanL);
padding: 2px 10px; border-radius: 980px; text-align: center; white-space: nowrap;
}
.news-tag--release { color: #2e7d32; background: #e8f5e9; }
.news-tag--media { color: #e65100; background: #fff3e0; }
.news-tag--event { color: #6a1b9a; background: #f3e5f5; }
.news-title { font-size: 14px; font-weight: 500; color: var(--text); line-height: 1.7; } .single-content { padding: 64px 0 100px; }
.single-inner { max-width: 780px; margin: 0 auto; }
.single-meta {
display: flex; align-items: center; gap: 12px;
margin-bottom: 32px; padding-bottom: 24px;
border-bottom: 1px solid var(--line);
}
.single-body { font-size: 15px; line-height: 2.2; color: var(--text); }
.single-body p { margin-bottom: 24px; }
.single-body h2 {
font-size: 20px; font-weight: 700; color: var(--navy);
margin: 48px 0 16px; padding-left: 12px;
border-left: 3px solid var(--cyan);
}
.single-body h3 {
font-size: 17px; font-weight: 700; color: var(--navy);
margin: 32px 0 12px;
}
.single-body img { border-radius: 8px; margin: 24px 0; }
.single-body a { color: var(--cyan2); border-bottom: 1px solid var(--cyan2); }
.single-body a:hover { color: var(--navy); border-color: var(--navy); }
.single-body ul, .single-body ol {
padding-left: 24px; margin-bottom: 24px;
}
.single-body li { margin-bottom: 8px; }
.single-nav {
display: flex; justify-content: space-between; align-items: center;
margin-top: 64px; padding-top: 32px;
border-top: 1px solid var(--line);
}
.single-nav a {
font-size: 13px; font-weight: 600; color: var(--cyan2);
transition: color .2s;
}
.single-nav a:hover { color: var(--navy); }
.single-nav-back a {
padding: 8px 20px; border: 1px solid var(--line);
border-radius: 980px; color: var(--sub);
}
.single-nav-back a:hover { border-color: var(--cyan); color: var(--cyan2); } .pagination {
display: flex; justify-content: center; gap: 8px;
margin-top: 48px;
}
.pagination a, .pagination span {
display: inline-flex; align-items: center; justify-content: center;
width: 40px; height: 40px; border-radius: 8px;
font-size: 14px; font-weight: 500; color: var(--sub);
border: 1px solid var(--line); transition: all .2s;
}
.pagination a:hover { border-color: var(--cyan); color: var(--cyan2); }
.pagination .current {
background: var(--navy); color: #fff; border-color: var(--navy);
} @media (max-width: 960px) {
.nav { padding: 0 24px; }
.wrap { padding: 0 24px; }
.footer-top { flex-direction: column; gap: 28px; }
.footer-nav { flex-wrap: wrap; gap: 20px; }
.news-item { grid-template-columns: 90px 80px 1fr; gap: 12px; }
}
@media (max-width: 640px) {
.nav-links { display: none; }
.nav-hamburger { display: block; }
.nav-links.open {
display: flex; flex-direction: column;
position: fixed; top: 0; left: 0; width: 100%; height: 100vh;
background: rgba(255,255,255,.98); backdrop-filter: blur(20px);
justify-content: center; align-items: center; gap: 24px;
z-index: 1000;
}
.nav-links.open a { color: var(--navy) !important; font-size: 18px; }
.section { padding: 64px 0; }
.news-item { grid-template-columns: 1fr; gap: 6px; }
.page-hero { padding: 120px 0 40px; }
}.r-wrap{max-width:1060px;margin:0 auto;padding:0 56px} .r-hero{
padding-top:64px;min-height:100vh;
display:grid;grid-template-columns:1fr 1fr;
background:#fff;overflow:hidden;
}
.r-hero-left{
display:flex;flex-direction:column;justify-content:center;
padding:80px 40px 80px 56px;
}
.r-hero-eyebrow{
font-size:13px;font-weight:500;color:var(--sub);letter-spacing:.12em;
margin-bottom:32px;display:flex;align-items:center;gap:12px;
}
.r-hero-eyebrow::before{content:'';width:24px;height:1.5px;background:var(--cyan)}
.r-hero-h1{
font-size:clamp(26px,3.6vw,42px);
font-weight:300;color:var(--navy);line-height:1.5;
margin-bottom:32px;letter-spacing:-.01em;
}
.r-hero-h1 strong{font-weight:700}
.r-hero-h1 em{font-style:normal;color:var(--cyan);font-weight:700}
.r-hero-sub{
font-size:16px;color:var(--sub);line-height:2;margin-bottom:20px;max-width:440px;
}
.r-hero-note{
font-size:14px;color:var(--sub);opacity:.7;margin-bottom:40px;
display:flex;align-items:center;gap:6px;
}
.r-hero-note::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--cyan);flex-shrink:0}
.r-hero-btns{display:flex;gap:12px}
.r-btn-primary{
display:inline-block;background:var(--navy);color:#fff;
padding:16px 40px;font-size:15px;font-weight:600;border-radius:980px;
text-decoration:none;letter-spacing:.04em;transition:background .2s;
}
.r-btn-primary:hover{background:var(--cyan)}
.r-btn-ghost{
display:inline-block;background:transparent;color:var(--text);
padding:16px 32px;font-size:15px;font-weight:500;border-radius:980px;
text-decoration:none;border:1px solid var(--line);transition:border-color .2s;
}
.r-btn-ghost:hover{border-color:var(--cyan)}
.r-hero-right{
position:relative;overflow:hidden;
}
.r-hero-right img{
width:100%;height:100%;object-fit:cover;display:block;object-position:calc(50% - 40px) center;
}
.r-hero-right::after{
content:'';position:absolute;inset:0;
background:linear-gradient(to right,#fff 0%,transparent 12%);
} .r-stats{
padding:64px 0;
border-bottom:1px solid var(--line);
}
.r-stats-grid{
display:grid;grid-template-columns:repeat(3,1fr);gap:0;
}
.r-stat{text-align:center;padding:0 20px;display:flex;flex-direction:column;align-items:center}
.r-stat+.r-stat{border-left:1px solid var(--line)}
.r-stat-num{font-size:44px;font-weight:200;color:var(--navy);line-height:1;margin-bottom:8px;letter-spacing:-.02em;height:48px;display:flex;align-items:baseline;justify-content:center}
.r-stat-num span{font-size:16px;font-weight:500}
.r-stat-text{font-size:15px;color:var(--sub);line-height:1.7;margin-bottom:4px;min-height:52px;display:flex;align-items:center;justify-content:center}
.r-stat-why{font-size:13px;color:var(--cyan2);font-weight:500} .r-trust{
padding:80px 0;
background:var(--navy);
color:#fff;
}
.r-trust-header{
text-align:center;margin-bottom:40px;
}
.r-trust-header .sec-label{color:var(--cyan);margin-bottom:12px}
.r-trust-title{
font-size:clamp(20px,2.8vw,28px);font-weight:300;color:#fff;line-height:1.4;
margin-bottom:8px;
}
.r-trust-title strong{font-weight:700}
.r-trust-award{
display:inline-flex;align-items:center;gap:10px;
background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
padding:10px 20px;font-size:13px;font-weight:600;color:#fff;
}
.r-trust-award-icon{font-size:18px}
.r-trust-award-sub{font-size:11px;font-weight:400;color:rgba(255,255,255,.5);display:block;margin-top:2px}
.r-trust-school-wrap{
display:flex;flex-wrap:wrap;gap:10px;
justify-content:center;
margin-top:40px;
}
.r-trust-school{
font-size:13px;color:rgba(255,255,255,.7);
padding:6px 16px;border-radius:980px;
white-space:nowrap;
background:rgba(255,255,255,.06);
border:1px solid rgba(255,255,255,.1);
transition:background .2s;
}
.r-trust-school:hover{background:rgba(255,255,255,.12)}
.r-trust-more{
font-size:13px;color:var(--cyan);font-weight:500;
padding:6px 16px;
} .r-section{padding:88px 0}
.r-section--alt{background:var(--light)}
.r-sec-title{
font-size:clamp(28px,3.6vw,42px);
font-weight:300;color:var(--navy);line-height:1.4;margin-bottom:20px;letter-spacing:-.01em;
}
.r-sec-title strong{font-weight:700}
.r-sec-lead{font-size:16px;color:var(--sub);line-height:2;max-width:680px} .r-empathy-grid{
margin-top:48px;
}
.r-pain-list{display:flex;flex-direction:column;gap:0}
.r-pain-item{
padding:28px 0;border-bottom:1px solid var(--line);
display:flex;align-items:flex-start;gap:20px;
font-size:16px;color:var(--text);line-height:1.9;
}
.r-pain-item:first-child{padding-top:0}
.r-pain-item:last-child{border-bottom:none}
.r-pain-num{
font-size:13px;font-weight:700;color:#fff;background:var(--cyan);
min-width:32px;height:32px;display:flex;align-items:center;justify-content:center;
border-radius:50%;flex-shrink:0;margin-top:2px;
}
.r-pain-item mark{
background:linear-gradient(transparent 60%,#fff8c5 60%);
font-weight:700;color:var(--navy);padding:0 2px;
}
.r-pivot-box{
margin-top:56px;padding:48px 56px;border-radius:16px;
background:var(--navy);text-align:center;
}
.r-pivot-box strong{
display:block;color:#fff;font-size:clamp(22px,2.8vw,30px);
font-weight:700;line-height:1.6;letter-spacing:.02em;
} .r-about-layout{
display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;
}
.r-about-photo{overflow:hidden}
.r-about-photo img{width:100%;height:440px;object-fit:cover;display:block}
.r-about-mission{
padding:20px 24px;background:var(--cyanL);
border-left:2px solid var(--cyan);
font-size:15px;color:var(--navy);line-height:1.85;margin-bottom:32px;
}
.r-about-mission strong{display:block;font-weight:600;margin-bottom:4px}
.r-about-facts{
display:grid;grid-template-columns:1fr 1fr;gap:16px 32px;margin-bottom:32px;
}
.r-about-fact{font-size:14px;color:var(--sub);line-height:1.7}
.r-about-fact strong{display:block;font-size:12px;font-weight:600;color:var(--navy);
letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px;opacity:.55;
}
.r-about-values{
padding:20px 24px;background:var(--navy);border-radius:12px;
font-size:15px;color:rgba(255,255,255,.85);line-height:1.85;
}
.r-about-values strong{display:block;font-weight:600;color:#fff;margin-bottom:4px;font-size:14px;letter-spacing:.04em}
.r-about-values span{font-weight:500;color:#fff} .r-pos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.r-pos-card{transition:transform .25s}
.r-pos-card:hover{transform:translateY(-6px)}
.r-pos-img{overflow:hidden;margin-bottom:20px;position:relative;border-radius:16px}
.r-pos-img img{width:100%;height:200px;object-fit:cover;display:block;transition:transform .4s}
.r-pos-card:hover .r-pos-img img{transform:scale(1.03)}
.r-pos-img-badge{
position:absolute;top:14px;left:14px;
font-size:11px;font-weight:600;color:#fff;background:rgba(0,0,0,.5);
padding:3px 10px;letter-spacing:.06em;backdrop-filter:blur(4px);border-radius:980px;
}
.r-pos-img-tag{
position:absolute;bottom:14px;right:14px;
font-size:11px;font-weight:700;color:var(--navy);background:var(--cyan);
padding:3px 10px;letter-spacing:.04em;border-radius:980px;
}
.r-pos-name{font-size:20px;font-weight:600;color:var(--navy);margin-bottom:10px}
.r-pos-desc{font-size:15px;color:var(--sub);line-height:1.9;margin-bottom:16px}
.r-pos-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.r-pos-tag{font-size:11px;color:var(--sub);border-bottom:1px solid var(--line);padding-bottom:1px}
.r-pos-more{
font-size:15px;font-weight:600;color:var(--navy);text-decoration:none;
display:inline-flex;align-items:center;gap:6px;transition:gap .2s;
}
.r-pos-more:hover{gap:10px;color:var(--cyan2)}
.r-pos-more::after{content:'\2192';font-size:15px} .r-match-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.r-match-item{
background:#fff;border-radius:16px;padding:40px 32px 36px;
text-align:center;position:relative;
box-shadow:0 1px 3px rgba(0,0,0,.04),0 8px 24px rgba(0,0,0,.06);
border-top:3px solid var(--cyan);
}
.r-match-icon{
width:56px;height:56px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;
background:var(--cyanL);border-radius:14px;font-size:22px;font-weight:700;color:var(--cyan);
}
.r-match-title{font-size:16px;font-weight:600;color:var(--navy);margin-bottom:14px;line-height:1.5}
.r-match-desc{font-size:14px;color:var(--sub);line-height:1.9;text-align:left}
.r-match-divider{display:none} .r-section--dark{background:var(--navy);padding:88px 0}
.r-section--dark .sec-label{color:var(--cyan)}
.r-section--dark .r-sec-title{color:#fff}
.r-section--dark .r-sec-title strong{color:#fff}
.r-section--dark .r-sec-lead{color:rgba(255,255,255,.5)}
.r-reality-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:48px}
.r-reality-col{
background:rgba(255,255,255,.06);border-radius:16px;padding:32px 28px;
border:1px solid rgba(255,255,255,.1);
}
.r-reality-col.r-good{border-top:3px solid var(--cyan)}
.r-reality-col.r-hard{border-top:3px solid #e03030}
.r-reality-head{
font-size:15px;font-weight:700;color:#fff;margin-bottom:20px;
display:flex;align-items:center;gap:10px;
}
.r-reality-head-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.r-reality-head-dot.r-g{background:var(--cyan)}
.r-reality-head-dot.r-h{background:#e03030}
.r-reality-items{display:flex;flex-direction:column;gap:0}
.r-reality-item{
padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1);
font-size:14px;color:rgba(255,255,255,.75);line-height:1.85;
padding-left:20px;position:relative;
}
.r-reality-item::before{
content:'';position:absolute;left:0;top:22px;
width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.2);
}
.r-reality-item:last-child{border-bottom:none}
.r-reality-item mark{
background:linear-gradient(transparent 60%,rgba(0,194,224,.25) 60%);
font-weight:700;color:#fff;padding:0 2px;
} .r-members-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:48px}
.r-member{display:grid;grid-template-columns:1fr;gap:0}
.r-member-photo{overflow:hidden;border-radius:16px}
.r-member-photo img{width:100%;height:260px;object-fit:cover;display:block}
.r-member-info{padding:28px 0}
.r-member-name{font-size:17px;font-weight:600;color:var(--navy);margin-bottom:4px}
.r-member-role{font-size:13px;color:var(--cyan2);font-weight:500;margin-bottom:12px}
.r-member-path{
display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:16px;
}
.r-member-step{font-size:12px;font-weight:500;color:var(--text);background:var(--light);padding:3px 10px;border-radius:980px}
.r-member-arr{font-size:11px;color:var(--sub)}
.r-member-quote{font-size:15px;color:var(--sub);line-height:1.95;padding-left:16px;border-left:2px solid var(--cyan)} .r-req-block{
margin-bottom:40px;
background:#fff;
border-radius:16px;
border:1px solid var(--line);
overflow:hidden;
transition:transform .35s cubic-bezier(.25,.46,.45,.94),box-shadow .35s;
}
.r-req-block:hover{
transform:translateY(-10px);
box-shadow:0 24px 64px rgba(13,34,64,.1);
}
.r-req-block:last-of-type{margin-bottom:0}
.r-req-head{
display:flex;align-items:center;gap:12px;
padding:20px 28px;
border-bottom:1px solid var(--line);
}
.r-req-badge{
font-size:11px;font-weight:600;letter-spacing:.04em;
padding:3px 10px;border-radius:980px;
}
.r-req-badge--kknavi{background:var(--cyanL);color:var(--cyan2)}
.r-req-badge--rt{background:#ecfafd;color:var(--navy)}
.r-req-name{font-size:18px;font-weight:600;color:var(--navy)}
.r-req-table{width:100%;border-collapse:collapse}
.r-req-table tr{border-bottom:1px solid var(--line)}
.r-req-table tr:last-child{border-bottom:none}
.r-req-table tr:nth-child(even){background:var(--light)}
.r-req-table th{
width:110px;text-align:left;vertical-align:top;
font-size:12px;font-weight:600;color:var(--navy);letter-spacing:.06em;
padding:16px 16px 16px 28px;
}
.r-req-table td{font-size:14px;color:var(--text);padding:16px 28px 16px 0;line-height:1.85}
.r-req-tip{
margin-top:40px;padding:20px 28px;background:var(--cyanL);
font-size:15px;color:var(--navy);line-height:1.8;
border-radius:16px;
border:1px solid var(--line);
} .r-process-grid{
display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:48px;
position:relative;
}
.r-process-grid::before{
content:'';position:absolute;top:18px;
left:calc(12.5% + 6px);right:calc(12.5% + 6px);
height:1px;background:var(--line);
}
.r-step{text-align:center;position:relative;z-index:1}
.r-step-num{
width:36px;height:36px;border-radius:50%;border:1.5px solid var(--cyan);
background:#fff;display:flex;align-items:center;justify-content:center;
margin:0 auto 20px;font-size:13px;font-weight:600;color:var(--cyan2);
}
.r-step-title{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:8px}
.r-step-desc{font-size:14px;color:var(--sub);line-height:1.75} .r-cta{
padding:120px 56px;background:var(--navy);text-align:center;
position:relative;overflow:hidden;
}
.r-cta::before{
content:'';position:absolute;
bottom:-100px;left:50%;transform:translateX(-50%);
width:500px;height:500px;border-radius:50%;
background:rgba(0,194,224,.04);
}
.r-cta-inner{max-width:640px;margin:0 auto;position:relative;z-index:1}
.r-cta-label{font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--cyan);margin-bottom:24px;text-transform:uppercase}
.r-cta-h2{
font-size:clamp(24px,3.2vw,36px);font-weight:300;color:#fff;line-height:1.5;margin-bottom:20px;
}
.r-cta-h2 strong{font-weight:700}
.r-cta-desc{font-size:15px;color:rgba(255,255,255,.65);line-height:1.9;margin-bottom:32px;max-width:520px;margin-left:auto;margin-right:auto}
.r-cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:28px}
.r-cta-btn-a{
display:inline-block;background:var(--cyan);color:var(--navy);
padding:16px 44px;font-size:15px;font-weight:700;text-decoration:none;border-radius:980px;
transition:background .2s,transform .15s;
}
.r-cta-btn-a:hover{background:#fff;transform:translateY(-2px)}
.r-cta-btn-b{
display:inline-block;background:transparent;color:rgba(255,255,255,.7);
padding:16px 28px;font-size:15px;font-weight:500;text-decoration:none;border-radius:980px;
border:1px solid rgba(255,255,255,.2);transition:border-color .2s;
}
.r-cta-btn-b:hover{border-color:var(--cyan);color:#fff}
.r-cta-note{font-size:13px;color:rgba(255,255,255,.8);line-height:1.8;margin-bottom:36px}  .r-hero-left .r-hero-anim{
opacity:0;transform:translateY(20px);
transition:opacity .8s cubic-bezier(.22,1,.36,1),transform .8s cubic-bezier(.22,1,.36,1);
}
.r-hero-left.loaded .r-hero-anim:nth-child(1){opacity:1;transform:translateY(0);transition-delay:.15s}
.r-hero-left.loaded .r-hero-anim:nth-child(2){opacity:1;transform:translateY(0);transition-delay:.35s}
.r-hero-left.loaded .r-hero-anim:nth-child(3){opacity:1;transform:translateY(0);transition-delay:.5s}
.r-hero-left.loaded .r-hero-anim:nth-child(4){opacity:1;transform:translateY(0);transition-delay:.6s}
.r-hero-left.loaded .r-hero-anim:nth-child(5){opacity:1;transform:translateY(0);transition-delay:.75s} .r-hero-right img{
opacity:0;transform:scale(1.06);
transition:opacity 1.2s .3s cubic-bezier(.22,1,.36,1),transform 1.8s .3s cubic-bezier(.22,1,.36,1);
}
.r-hero-right.loaded img{opacity:1;transform:scale(1)} .r-stat-num{
transition:opacity .5s,transform .5s cubic-bezier(.22,1,.36,1);
} .r-match-item{transition:transform .3s cubic-bezier(.22,1,.36,1),box-shadow .3s}
.r-match-item:hover{transform:translateY(-6px);box-shadow:0 4px 8px rgba(0,0,0,.06),0 16px 40px rgba(0,0,0,.1)}
.r-reality-col{transition:transform .3s cubic-bezier(.22,1,.36,1),background .3s,border-color .3s}
.r-reality-col:hover{transform:translateY(-4px);background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.18)}
.r-member{transition:transform .3s cubic-bezier(.22,1,.36,1)}
.r-member:hover{transform:translateY(-4px)} .r-cta-btn-a{position:relative;overflow:hidden}
.r-cta-btn-a::after{
content:'';position:absolute;top:0;left:-100%;
width:60%;height:100%;
background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
animation:r-shimmer 3s infinite 2s;
}
@keyframes r-shimmer{
0%{left:-100%}
30%{left:150%}
100%{left:150%}
} .r-trust-school{
opacity:0;transform:translateY(8px);
transition:opacity .4s,transform .4s cubic-bezier(.22,1,.36,1);
}
.r-trust-school-wrap.visible .r-trust-school{opacity:1;transform:translateY(0)} .r-pivot-box{
opacity:0;transform:scale(.96);
transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1);
}
.r-pivot-box.visible{opacity:1;transform:scale(1)} .r-step{
opacity:0;transform:translateY(20px);
transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1);
}
.r-process-grid.visible .r-step{opacity:1;transform:translateY(0)}
.r-process-grid.visible .r-step:nth-child(1){transition-delay:.1s}
.r-process-grid.visible .r-step:nth-child(2){transition-delay:.25s}
.r-process-grid.visible .r-step:nth-child(3){transition-delay:.4s}
.r-process-grid.visible .r-step:nth-child(4){transition-delay:.55s} .r-cta-form {
max-width: 520px;
margin: 0 auto;
text-align: left;
}
.r-cta-form .r-form-group {
margin-bottom: 20px;
}
.r-cta-form label {
display: block;
font-size: 13px;
font-weight: 600;
color: rgba(255,255,255,.8);
margin-bottom: 6px;
letter-spacing: .03em;
}
.r-cta-form .r-required {
font-size: 10px;
color: var(--cyan);
margin-left: 4px;
}
.r-cta-form input[type="text"],
.r-cta-form input[type="email"],
.r-cta-form input[type="tel"],
.r-cta-form select,
.r-cta-form textarea {
width: 100%;
padding: 12px 16px;
font-size: 15px;
font-family: 'Noto Sans JP', sans-serif;
color: #fff;
background: rgba(255,255,255,.1);
border: 1px solid rgba(255,255,255,.2);
border-radius: 8px;
outline: none;
transition: border-color .2s, background .2s;
}
.r-cta-form input::placeholder,
.r-cta-form textarea::placeholder {
color: rgba(255,255,255,.3);
}
.r-cta-form input:focus,
.r-cta-form select:focus,
.r-cta-form textarea:focus {
border-color: var(--cyan);
background: rgba(255,255,255,.15);
}
.r-cta-form select {
-webkit-appearance: none;
appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='rgba(255,255,255,0.5)' d='M1.4 0L6 4.6 10.6 0 12 1.4l-6 6-6-6z'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 14px center;
padding-right: 36px;
}
.r-cta-form select option {
background: var(--navy);
color: #fff;
}
.r-cta-form textarea {
min-height: 120px;
resize: vertical;
}
.r-cta-form .wpcf7-list-item {
display: inline-block;
margin-right: 20px;
}
.r-cta-form .wpcf7-radio {
display: flex;
align-items: center;
gap: 24px;
flex-wrap: wrap;
}
.r-cta-form .wpcf7-radio .wpcf7-list-item {
display: inline-flex;
align-items: center;
gap: 8px;
margin: 0;
cursor: pointer;
}
.r-cta-form .wpcf7-radio .wpcf7-list-item input[type="radio"] {
margin: 0;
width: 18px;
height: 18px;
accent-color: var(--cyan);
flex-shrink: 0;
}
.r-cta-form .wpcf7-radio .wpcf7-list-item-label {
color: #fff !important;
font-size: 15px !important;
line-height: 1;
}
.r-cta-form .r-form-submit {
text-align: center;
margin-top: 28px;
}
.r-cta-form input[type="submit"] {
display: inline-block;
background: var(--cyan);
color: var(--navy);
padding: 16px 56px;
font-size: 15px;
font-weight: 700;
font-family: 'Noto Sans JP', sans-serif;
border: none;
border-radius: 980px;
cursor: pointer;
transition: background .2s, transform .15s;
letter-spacing: .04em;
}
.r-cta-form input[type="submit"]:hover {
background: #fff;
transform: translateY(-2px);
}
.r-cta-form .wpcf7-response-output {
color: rgba(255,255,255,.8);
border-color: var(--cyan) !important;
font-size: 14px;
margin-top: 16px;
}
.r-cta-form .wpcf7-not-valid-tip {
color: #ff6b6b;
font-size: 12px;
} @media (max-width:900px){ .r-hero{grid-template-columns:1fr;min-height:auto}
.r-hero-left{padding:100px 28px 48px;text-align:center;align-items:center}
.r-hero-sub{max-width:100%}
.r-hero-btns{justify-content:center;flex-wrap:wrap}
.r-hero-right{height:320px} .r-stats-grid{grid-template-columns:1fr;gap:32px}
.r-stat+.r-stat{border-left:none;border-top:1px solid var(--line);padding-top:32px} .r-about-layout{grid-template-columns:1fr;gap:32px}
.r-about-photo img{height:280px} .r-pos-grid{grid-template-columns:1fr;gap:40px} .r-match-grid{grid-template-columns:1fr;gap:24px} .r-reality-grid{grid-template-columns:1fr;gap:24px} .r-members-grid{grid-template-columns:1fr;gap:40px} .r-process-grid{grid-template-columns:repeat(2,1fr);gap:32px}
.r-process-grid::before{display:none} .r-cta{padding:80px 28px} .r-section{padding:64px 0}
.r-section--dark{padding:64px 0}
} @media (max-width:600px){ .wrap{padding-left:20px!important;padding-right:20px!important} .r-hero-left{padding:88px 20px 36px}
.r-hero-h1{font-size:24px}
.r-hero-sub{font-size:14px}
.r-hero-note{font-size:12px}
.r-hero-right{height:240px}
.r-btn-primary{padding:14px 28px;font-size:14px}
.r-btn-ghost{padding:14px 24px;font-size:14px} .r-stat-num{font-size:36px}
.r-stat-text{font-size:14px;min-height:auto} .r-trust{padding:56px 0}
.r-trust-title{font-size:20px}
.r-trust-school{font-size:12px;padding:5px 12px} .r-pain-item{font-size:14px;gap:14px;padding:20px 0}
.r-pain-num{min-width:28px;height:28px;font-size:11px}
.r-pivot-box{padding:32px 24px}
.r-pivot-box strong{font-size:20px} .r-sec-title{font-size:24px} .r-pos-img img{height:180px}
.r-pos-name{font-size:18px}
.r-pos-desc{font-size:14px} .r-match-item{padding:28px 24px} .r-reality-col{padding:24px 20px}
.r-reality-item{font-size:13px} .r-member-photo img{height:200px}
.r-member-quote{font-size:14px} .r-req-head{padding:16px 20px}
.r-req-table th{width:80px;font-size:10px;padding:12px 12px 12px 20px}
.r-req-table td{font-size:14px;padding:12px 20px 12px 0}
.r-req-name{font-size:16px}
.r-req-tip{padding:16px 20px;font-size:14px} .r-process-grid{grid-template-columns:repeat(2,1fr);gap:24px}
.r-step-title{font-size:14px}
.r-step-desc{font-size:13px} .r-cta{padding:64px 20px}
.r-cta-h2{font-size:22px}
.r-cta-desc{font-size:14px}
.r-cta-note{font-size:12px}
.r-cta-form input[type="submit"]{padding:14px 40px;font-size:14px} .footer-top{flex-direction:column;gap:28px}
.footer-nav{gap:32px}
}