/* ==========================================================================
   Recruit LP — recruit.css
   All classes prefixed with r- to avoid conflicts with main theme styles.
   Shared classes (reveal, reveal-stagger, nav, wrap, sec-label) are NOT prefixed.
   ========================================================================== */

/* ─── LAYOUT ─── */
.r-wrap{max-width:1060px;margin:0 auto;padding:0 56px}

/* ─── HERO ─── */
.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%);
}

/* ─── STATS ─── */
.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}

/* ─── TRUST ─── */
.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;
}

/* ─── SECTION COMMON ─── */
.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}

/* ─── EMPATHY ─── */
.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;
}

/* ─── ABOUT ─── */
.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}

/* ─── POSITIONS ─── */
.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}

/* ─── MATCH ─── */
.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}

/* ─── REALITY ─── */
.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;
}

/* ─── MEMBERS ─── */
.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)}

/* ─── REQ ─── */
.r-req-block{margin-bottom:56px}
.r-req-block:last-of-type{margin-bottom:0}
.r-req-head{
  display:flex;align-items:center;gap:12px;margin-bottom:20px;
}
.r-req-badge{font-size:11px;font-weight:600;letter-spacing:.06em;padding:3px 10px;background:var(--light);color:var(--sub);border-radius:980px}
.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 th{
  width:110px;text-align:left;vertical-align:top;
  font-size:11px;font-weight:600;color:var(--sub);letter-spacing:.06em;padding:16px 16px 16px 0;
}
.r-req-table td{font-size:15px;color:var(--text);padding: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;
}

/* ─── PROCESS ─── */
.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}

/* ─── CTA ─── */
.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}

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */

/* Hero stagger */
.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}

/* Hero image reveal */
.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)}

/* Stats counter pop */
.r-stat-num{
  transition:opacity .5s,transform .5s cubic-bezier(.22,1,.36,1);
}

/* Card hover enhancements */
.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)}

/* CTA shimmer */
.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%}
}

/* Trust school pills stagger */
.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)}

/* Pivot box entrance */
.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)}

/* Process step stagger */
.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}

/* ─── CTA Form (Contact Form 7) ─── */
.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;
}

/* ==========================================================================
   RESPONSIVE — Tablet (≤ 900px)
   ========================================================================== */
@media (max-width:900px){
  /* Hero */
  .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}

  /* Stats */
  .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}

  /* About */
  .r-about-layout{grid-template-columns:1fr;gap:32px}
  .r-about-photo img{height:280px}

  /* Positions */
  .r-pos-grid{grid-template-columns:1fr;gap:40px}

  /* Match */
  .r-match-grid{grid-template-columns:1fr;gap:24px}

  /* Reality */
  .r-reality-grid{grid-template-columns:1fr;gap:24px}

  /* Members */
  .r-members-grid{grid-template-columns:1fr;gap:40px}

  /* Process */
  .r-process-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .r-process-grid::before{display:none}

  /* CTA */
  .r-cta{padding:80px 28px}

  /* Section */
  .r-section{padding:64px 0}
  .r-section--dark{padding:64px 0}
}

/* ==========================================================================
   RESPONSIVE — Mobile (≤ 600px)
   ========================================================================== */
@media (max-width:600px){
  /* Wrap padding */
  .wrap{padding-left:20px!important;padding-right:20px!important}

  /* Hero */
  .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}

  /* Stats */
  .r-stat-num{font-size:36px}
  .r-stat-text{font-size:14px;min-height:auto}

  /* Trust */
  .r-trust{padding:56px 0}
  .r-trust-title{font-size:20px}
  .r-trust-school{font-size:12px;padding:5px 12px}

  /* Empathy */
  .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}

  /* Section titles */
  .r-sec-title{font-size:24px}

  /* Positions */
  .r-pos-img img{height:180px}
  .r-pos-name{font-size:18px}
  .r-pos-desc{font-size:14px}

  /* Match */
  .r-match-item{padding:28px 24px}

  /* Reality */
  .r-reality-col{padding:24px 20px}
  .r-reality-item{font-size:13px}

  /* Members */
  .r-member-photo img{height:200px}
  .r-member-quote{font-size:14px}

  /* Requirements */
  .r-req-table th{width:80px;font-size:10px;padding:12px 8px 12px 0}
  .r-req-table td{font-size:14px;padding:12px 0}
  .r-req-name{font-size:16px}
  .r-req-tip{padding:16px 20px;font-size:14px}

  /* Process */
  .r-process-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .r-step-title{font-size:14px}
  .r-step-desc{font-size:13px}

  /* CTA */
  .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 in recruit */
  .footer-top{flex-direction:column;gap:28px}
  .footer-nav{gap:32px}
}
