/* =====================================================
   ここから採用 — BtoB Matching Platform
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');

:root {
  --navy:    #0D1B2A;
  --navy2:   #1B2D42;
  --gold:    #C9A84C;
  --gold-lt: #F0C96A;
  --white:   #FFFFFF;
  --off:     #F7F6F3;
  --gray:    #888888;
  --border:  #E8E8E8;
  --text:    #1A1A1A;
  --green:   #1A7A5A;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  color: var(--text);
  font-size: 16px;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ===== HEADER ===== */
header {
  position: fixed; top:0; left:0; right:0;
  z-index: 1000;
  transition: background .3s, box-shadow .3s;
}
header.scrolled {
  background: rgba(13,27,42,.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 24px rgba(0,0,0,.25);
}
.header-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0 40px; height: 72px;
  display: flex; align-items: center; justify-content: space-between;
}
.logo { font-size:1.15rem; font-weight:900; color:#fff; letter-spacing:.04em; }
.logo span { color: var(--gold); }
nav ul { list-style:none; display:flex; align-items:center; gap:32px; }
nav a { color:rgba(255,255,255,.8); font-size:.85rem; font-weight:500; transition:color .2s; }
nav a:hover { color: var(--gold); }
.nav-register {
  background: var(--gold); color: var(--navy) !important;
  padding: 9px 22px; border-radius:3px; font-weight:700 !important;
  transition: background .2s !important;
}
.nav-register:hover { background: var(--gold-lt) !important; }

/* ===== BUTTONS ===== */
.btn-gold {
  display:inline-flex; align-items:center; gap:8px;
  background: var(--gold); color: var(--navy);
  padding:16px 36px; font-size:.95rem; font-weight:700;
  letter-spacing:.04em; border-radius:3px;
  transition: background .2s, transform .2s;
}
.btn-gold:hover { background: var(--gold-lt); transform:translateY(-2px); }
.btn-outline-w {
  display:inline-flex; align-items:center; gap:8px;
  background:transparent; color:#fff;
  padding:15px 36px; font-size:.95rem; font-weight:700;
  border:1.5px solid rgba(255,255,255,.5); border-radius:3px;
  transition: border-color .2s;
}
.btn-outline-w:hover { border-color:#fff; }
.btn-navy {
  display:inline-flex; align-items:center; gap:8px;
  background: var(--navy); color:#fff;
  padding:16px 36px; font-size:.95rem; font-weight:700;
  border-radius:3px; transition: background .2s, transform .2s;
}
.btn-navy:hover { background: var(--navy2); transform:translateY(-2px); }
.btn-green {
  display:inline-flex; align-items:center; gap:8px;
  background: var(--green); color:#fff;
  padding:16px 36px; font-size:.95rem; font-weight:700;
  border-radius:3px; transition: opacity .2s, transform .2s;
}
.btn-green:hover { opacity:.85; transform:translateY(-2px); }

/* ===== SECTION ===== */
section { padding: 96px 40px; }
.sec { max-width:1200px; margin:0 auto; }
.tag {
  font-size:.7rem; font-weight:700; letter-spacing:.22em;
  color: var(--gold); display:block; margin-bottom:12px;
}
.sec-title {
  font-size: clamp(1.6rem,3vw,2.4rem);
  font-weight:900; color: var(--navy); line-height:1.3;
  letter-spacing:-.01em; margin-bottom:16px;
}
.sec-lead { color: var(--gray); font-size:.95rem; line-height:1.9; max-width:520px; }

/* ===== HERO ===== */
.hero {
  min-height:100vh; background: var(--navy);
  display:flex; align-items:center;
  position:relative; overflow:hidden; padding:100px 0 60px;
}
.hero-glow {
  position:absolute; top:-150px; right:-100px;
  width:700px; height:700px; border-radius:50%;
  background: radial-gradient(circle, rgba(201,168,76,.1) 0%, transparent 65%);
  pointer-events:none;
}
.hero-glow2 {
  position:absolute; bottom:-200px; left:-150px;
  width:600px; height:600px; border-radius:50%;
  background: radial-gradient(circle, rgba(26,122,90,.08) 0%, transparent 65%);
  pointer-events:none;
}
.hero-inner {
  width:100%; position:relative;
  display:grid; grid-template-columns:1fr 1fr;
  align-items:center; gap:0;
}
.hero-left {
  padding:0 60px 0 80px;
}
.hero-right {
  padding:0 60px 0 40px;
  display:flex; flex-direction:column; gap:16px;
}
.hero-badge {
  display:inline-block; border:1px solid var(--gold);
  color: var(--gold); font-size:.72rem; font-weight:700;
  letter-spacing:.18em; padding:6px 16px; margin-bottom:28px;
}
.hero-title {
  font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight:900; color:#fff; line-height:1.15;
  margin-bottom:28px; letter-spacing:-.03em;
}
.hero-title em { font-style:normal; color: var(--gold); }
.hero-sub {
  font-size:1.05rem; color:rgba(255,255,255,.65);
  margin-bottom:44px; line-height:2; font-weight:300;
}

/* ヒーロー右側ビジュアルカード */
.hero-visual-card {
  background:var(--navy2);
  border:1px solid rgba(201,168,76,.25);
  border-radius:8px;
  padding:24px 28px;
  position:relative;
}
.hero-visual-card .hvc-label {
  font-size:.68rem; font-weight:700; letter-spacing:.12em;
  color:var(--gold); margin-bottom:10px;
}
.hero-visual-card .hvc-company {
  font-size:1rem; font-weight:700; color:#fff; margin-bottom:6px;
}
.hero-visual-card .hvc-area {
  font-size:.8rem; color:rgba(255,255,255,.4); margin-bottom:12px;
}
.hero-visual-card .hvc-tags {
  display:flex; flex-wrap:wrap; gap:6px; margin-bottom:14px;
}
.hero-visual-card .hvc-tag {
  font-size:.68rem; padding:3px 10px; border-radius:20px;
}
.hero-visual-card .hvc-tag.need { background:#1a3a2a; color:#4dbb87; border:1px solid #2a5a40; }
.hero-visual-card .hvc-tag.offer { background:#1a2a3a; color:#6699cc; border:1px solid #2a3a5a; }
.hero-visual-card .hvc-btn {
  display:inline-block; background:var(--gold); color:var(--navy);
  font-size:.75rem; font-weight:700; padding:7px 18px; border-radius:3px;
}
.hero-visual-badge {
  position:absolute; top:-10px; right:16px;
  background:var(--gold); color:var(--navy);
  font-size:.65rem; font-weight:700; padding:3px 10px; border-radius:20px;
}
.hero-stat-row {
  display:grid; grid-template-columns:1fr 1fr; gap:12px;
}
.hero-stat-box {
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:6px; padding:16px 20px;
  text-align:center;
}
.hero-stat-box .hsb-num {
  font-size:1.6rem; font-weight:900; color:var(--gold); line-height:1;
}
.hero-stat-box .hsb-label {
  font-size:.68rem; color:rgba(255,255,255,.4); margin-top:4px; letter-spacing:.06em;
}
/* 無料キャンペーンバナー */
.hero-free-banner {
  display:inline-block;
  background:rgba(201,168,76,.15);
  border:1px solid var(--gold);
  color:var(--gold);
  font-size:.82rem;
  padding:8px 20px;
  border-radius:40px;
  margin-bottom:24px;
  letter-spacing:.04em;
}
.hero-free-banner strong { color:#fff; }

/* 残り枠バー */
.hero-slots {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:48px;
  flex-wrap:wrap;
}
.slots-label { font-size:.75rem; color:rgba(255,255,255,.5); letter-spacing:.08em; white-space:nowrap; }
.slots-bar {
  flex:1; min-width:120px; max-width:200px;
  height:6px; background:rgba(255,255,255,.1); border-radius:3px; overflow:hidden;
}
.slots-fill { height:100%; background:var(--gold); border-radius:3px; }
.slots-count { font-size:.78rem; color:rgba(255,255,255,.6); white-space:nowrap; }
.slots-remain { color:var(--gold); font-weight:700; font-size:1rem; }

/* 料金プラン — 無料バッジ */
.plan-free-badge {
  display:inline-block;
  background:var(--green);
  color:#fff;
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.08em;
  padding:4px 12px;
  border-radius:3px;
  margin-bottom:8px;
}
.plan-price-free { color:var(--gold) !important; }

/* CTAセクション — 無料ラベル */
.cta-free-label {
  display:inline-block;
  background:var(--gold);
  color:var(--navy);
  font-size:.78rem;
  font-weight:700;
  padding:6px 20px;
  border-radius:40px;
  margin-bottom:20px;
  letter-spacing:.04em;
}

.hero-btns { display:flex; gap:16px; flex-wrap:wrap; margin-bottom:32px; }
.hero-kpi {
  display:flex; gap:56px; flex-wrap:wrap;
  padding-top:48px; border-top:1px solid rgba(255,255,255,.1);
}
.kpi-item {}
.kpi-num {
  font-size:2.4rem; font-weight:900; color:#fff;
  line-height:1; margin-bottom:4px;
}
.kpi-num span { color: var(--gold); font-size:1.1rem; }
.kpi-label { font-size:.72rem; color:rgba(255,255,255,.45); letter-spacing:.1em; }

/* ===== HOW IT WORKS ===== */
.how { background: var(--off); }
.steps {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:2px; background: var(--border);
  border:1px solid var(--border); margin-top:56px;
}
.step {
  background:#fff; padding:48px 36px; position:relative;
  transition: box-shadow .3s;
}
.step:hover { box-shadow:0 8px 32px rgba(0,0,0,.07); z-index:1; }
.step-num {
  font-size:3rem; font-weight:900; color:rgba(201,168,76,.15);
  line-height:1; margin-bottom:20px;
}
.step h3 { font-size:1.1rem; font-weight:700; color:var(--navy); margin-bottom:12px; }
.step p { font-size:.88rem; color:var(--gray); line-height:1.9; }
.step-arrow {
  position:absolute; top:50%; right:-20px;
  transform:translateY(-50%);
  width:40px; height:40px;
  background:#fff; border:1px solid var(--border);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:var(--gold); z-index:2;
}
.step:last-child .step-arrow { display:none; }

/* ===== FOR WHOM ===== */
.for-whom { padding:96px 40px; }
.for-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:32px; margin-top:56px;
}
.for-card {
  padding:56px 48px; border-radius:4px;
}
.for-card.seeker { background: var(--navy); }
.for-card.provider { background: var(--green); }
.for-card-label {
  font-size:.7rem; font-weight:700; letter-spacing:.2em;
  margin-bottom:16px; display:block;
}
.for-card.seeker .for-card-label { color: rgba(201,168,76,.8); }
.for-card.provider .for-card-label { color: rgba(255,255,255,.6); }
.for-card h3 { font-size:1.4rem; font-weight:900; color:#fff; margin-bottom:20px; line-height:1.4; }
.for-card p { font-size:.9rem; color:rgba(255,255,255,.65); line-height:1.9; margin-bottom:32px; }
.for-list { list-style:none; margin-bottom:40px; }
.for-list li {
  font-size:.88rem; color:rgba(255,255,255,.8);
  padding:10px 0; border-bottom:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; gap:12px;
}
.for-list li::before { content:'→'; color: var(--gold); font-weight:700; flex-shrink:0; }

/* ===== COMPANY CARDS ===== */
.companies-preview { background: var(--off); }
.card-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:56px;
}
.company-card {
  background:#fff; border:1px solid var(--border);
  border-radius:4px; overflow:hidden;
  transition: box-shadow .3s, transform .3s;
}
.company-card:hover { box-shadow:0 12px 40px rgba(0,0,0,.1); transform:translateY(-4px); }
.card-img {
  height:180px; background: var(--navy2);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.2); font-size:.8rem; letter-spacing:.08em;
  position:relative; overflow:hidden;
}
.card-badge {
  position:absolute; top:12px; left:12px;
  background: var(--gold); color: var(--navy);
  font-size:.65rem; font-weight:700; letter-spacing:.1em;
  padding:4px 10px; border-radius:2px;
}
.card-body { padding:24px; }
.card-category {
  font-size:.7rem; font-weight:700; letter-spacing:.12em;
  color: var(--gold); margin-bottom:8px; display:block;
}
.card-name { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:8px; }
.card-area { font-size:.8rem; color:var(--gray); margin-bottom:12px; }
.card-desc { font-size:.82rem; color:var(--gray); line-height:1.7; }
.card-footer {
  padding:16px 24px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
}
.card-plan {
  font-size:.72rem; font-weight:700; color:var(--gray);
  letter-spacing:.08em;
}
.card-plan.premium { color:var(--gold); }

/* ニーズタグ・業種タグ */
.card-tags {
  display:flex; flex-wrap:wrap; gap:6px;
  padding:10px 24px 0;
}
.tag-need {
  font-size:.68rem; font-weight:700;
  padding:3px 10px; border-radius:20px;
  background:#e8f4ef; color:var(--green);
  border:1px solid #b8dccb;
}
.tag-offer {
  font-size:.68rem; font-weight:700;
  padding:3px 10px; border-radius:20px;
  background:#eef3f8; color:var(--navy2);
  border:1px solid #c0cedb;
}
.tag-industry {
  font-size:.68rem; font-weight:700;
  padding:3px 10px; border-radius:20px;
  background:#fdf6e3; color:#8a6a00;
  border:1px solid #e8d48a;
}

/* 検索フィルター — ニーズタグ検索 */
.filter-need-bar {
  max-width:1200px; margin:0 auto;
  padding:0 40px 20px;
  display:flex; flex-wrap:wrap; gap:8px; align-items:center;
}
.filter-need-label {
  font-size:.72rem; font-weight:700; color:var(--gray);
  letter-spacing:.08em; margin-right:4px;
}
.filter-need-tag {
  font-size:.75rem; padding:5px 14px;
  border:1px solid var(--border); border-radius:20px;
  cursor:pointer; transition:.2s; color:var(--gray);
  background:#fff;
}
.filter-need-tag:hover,
.filter-need-tag.active { background:var(--green); color:#fff; border-color:var(--green); }
.filter-offer-tag:hover,
.filter-offer-tag.active { background:var(--navy2); color:#fff; border-color:var(--navy2); }

/* 登録フォーム — タグ選択 */
.tag-select-grid {
  display:flex; flex-wrap:wrap; gap:8px; margin-top:8px;
}
.tag-checkbox { display:none; }
.tag-checkbox + label {
  font-size:.78rem; padding:5px 14px;
  border:1px solid var(--border); border-radius:20px;
  cursor:pointer; transition:.2s; color:var(--gray);
  user-select:none;
}
.tag-checkbox:checked + label {
  background:var(--navy); color:#fff; border-color:var(--navy);
}
.card-link {
  font-size:.78rem; font-weight:700; color:var(--navy);
  display:flex; align-items:center; gap:4px;
  transition: color .2s;
}
.card-link:hover { color:var(--gold); }

/* ===== PRICING ===== */
.pricing { padding:96px 40px; background: var(--navy); }
.pricing .sec-title { color:#fff; }
.pricing .sec-lead { color:rgba(255,255,255,.5); }
.plan-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:2px; background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.06);
  margin-top:56px;
}
.plan {
  background: rgba(13,27,42,.8);
  padding:48px 36px; position:relative;
  transition: background .3s;
}
.plan:hover { background: rgba(27,45,66,.8); }
.plan.featured {
  background: rgba(201,168,76,.1);
  border:1px solid rgba(201,168,76,.3);
}
.plan-badge {
  display:inline-block; background:var(--gold); color:var(--navy);
  font-size:.65rem; font-weight:700; letter-spacing:.1em;
  padding:4px 12px; border-radius:2px; margin-bottom:20px;
}
.plan-name {
  font-size:.72rem; font-weight:700; letter-spacing:.2em;
  color:rgba(255,255,255,.45); margin-bottom:12px;
}
.plan-price {
  font-size:2.6rem; font-weight:900; color:#fff;
  line-height:1; margin-bottom:4px;
}
.plan-price span { font-size:1rem; font-weight:400; color:rgba(255,255,255,.45); }
.plan-cycle { font-size:.78rem; color:rgba(255,255,255,.4); margin-bottom:32px; }
.plan-divider { height:1px; background:rgba(255,255,255,.1); margin-bottom:28px; }
.plan-features { list-style:none; margin-bottom:40px; }
.plan-features li {
  font-size:.85rem; color:rgba(255,255,255,.7);
  padding:8px 0; display:flex; align-items:flex-start; gap:10px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.plan-features li::before { content:'✓'; color:var(--gold); font-weight:700; flex-shrink:0; margin-top:2px; }

/* ===== CTA ===== */
.cta-section {
  background: linear-gradient(135deg, var(--gold) 0%, #A87C2A 100%);
  padding:96px 40px; text-align:center;
}
.cta-section h2 {
  font-size: clamp(1.6rem,3vw,2.6rem);
  font-weight:900; color:var(--navy); margin-bottom:16px; line-height:1.3;
}
.cta-section p { color:rgba(13,27,42,.6); margin-bottom:48px; font-size:.95rem; }

/* ===== PAGE HERO ===== */
.page-hero {
  background: var(--navy); padding:148px 40px 72px;
  position:relative; overflow:hidden;
}
.page-hero::after {
  content:''; position:absolute; top:-100px; right:-100px;
  width:480px; height:480px; border-radius:50%;
  background: radial-gradient(circle, rgba(201,168,76,.08) 0%, transparent 65%);
}
.page-hero-inner { max-width:1200px; margin:0 auto; position:relative; }
.ph-tag { font-size:.7rem; font-weight:700; letter-spacing:.22em; color:var(--gold); display:block; margin-bottom:14px; }
.page-hero h1 { font-size: clamp(1.8rem,4vw,3rem); font-weight:900; color:#fff; line-height:1.3; }

/* ===== SEARCH BAR ===== */
.search-bar-wrap { background: var(--navy2); padding:32px 40px; }
.search-bar {
  max-width:1200px; margin:0 auto;
  display:flex; gap:12px; flex-wrap:wrap; align-items:center;
}
.search-bar select, .search-bar input {
  padding:12px 18px; border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.08); color:#fff;
  font-family:inherit; font-size:.9rem; border-radius:3px;
  flex:1; min-width:160px;
}
.search-bar select option { background: var(--navy2); color:#fff; }
.search-bar select:focus, .search-bar input:focus { outline:none; border-color:var(--gold); }
.search-bar input::placeholder { color:rgba(255,255,255,.35); }
.btn-search {
  background:var(--gold); color:var(--navy);
  padding:12px 28px; border:none; border-radius:3px;
  font-family:inherit; font-size:.9rem; font-weight:700;
  cursor:pointer; white-space:nowrap; transition:background .2s;
}
.btn-search:hover { background:var(--gold-lt); }

/* ===== COMPANIES LIST ===== */
.companies-section { padding:64px 40px; }
.companies-grid {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:24px; margin-top:40px;
}
.filter-bar {
  display:flex; gap:12px; align-items:center; flex-wrap:wrap; margin-bottom:32px;
}
.filter-tag {
  padding:6px 16px; border:1px solid var(--border);
  border-radius:20px; font-size:.78rem; font-weight:500;
  cursor:pointer; transition:all .2s; background:#fff;
}
.filter-tag.active, .filter-tag:hover {
  background: var(--navy); color:#fff; border-color:var(--navy);
}
.filter-count { font-size:.85rem; color:var(--gray); margin-left:auto; }

/* ===== DETAIL PAGE ===== */
.detail-layout {
  display:grid; grid-template-columns:1fr 340px;
  gap:40px; max-width:1200px; margin:0 auto;
  padding:64px 40px;
}
.detail-main {}
.detail-header { margin-bottom:32px; }
.detail-category { font-size:.72rem; font-weight:700; letter-spacing:.15em; color:var(--gold); margin-bottom:8px; display:block; }
.detail-name { font-size:1.8rem; font-weight:900; color:var(--navy); margin-bottom:12px; }
.detail-area { font-size:.88rem; color:var(--gray); }
.detail-img {
  height:320px; background:var(--navy2); border-radius:4px;
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.2); font-size:.85rem; letter-spacing:.1em;
  margin-bottom:40px;
}
.detail-section { margin-bottom:40px; }
.detail-section h3 {
  font-size:1rem; font-weight:700; color:var(--navy);
  padding-bottom:12px; border-bottom:2px solid var(--navy);
  margin-bottom:20px;
}
.detail-section p { font-size:.92rem; color:var(--gray); line-height:1.9; }
.detail-info-table { width:100%; border-collapse:collapse; }
.detail-info-table tr { border-bottom:1px solid var(--border); }
.detail-info-table th {
  width:120px; padding:14px 0; font-size:.8rem; font-weight:700;
  color:var(--gray); text-align:left; vertical-align:top;
}
.detail-info-table td { padding:14px 0; font-size:.88rem; color:var(--navy); }

/* サイドバー */
.detail-sidebar {}
.sidebar-card {
  background:var(--off); border:1px solid var(--border);
  border-radius:4px; padding:32px; margin-bottom:24px;
  position:sticky; top:96px;
}
.sidebar-plan {
  font-size:.65rem; font-weight:700; letter-spacing:.15em;
  color:var(--gold); margin-bottom:8px; display:block;
}
.sidebar-company { font-size:1.1rem; font-weight:900; color:var(--navy); margin-bottom:24px; }
.sidebar-divider { height:1px; background:var(--border); margin-bottom:24px; }
.sidebar-tel { font-size:1.3rem; font-weight:900; color:var(--navy); margin-bottom:4px; }
.sidebar-tel-label { font-size:.72rem; color:var(--gray); margin-bottom:24px; }
.contact-form-mini {}
.cf-group { margin-bottom:16px; }
.cf-group label { display:block; font-size:.75rem; font-weight:700; color:var(--navy); margin-bottom:6px; letter-spacing:.04em; }
.cf-group input, .cf-group select, .cf-group textarea {
  width:100%; padding:10px 14px; border:1.5px solid var(--border);
  border-radius:3px; font-family:inherit; font-size:.88rem;
  transition: border-color .2s;
}
.cf-group input:focus, .cf-group select:focus, .cf-group textarea:focus {
  outline:none; border-color:var(--gold);
}
.cf-group textarea { height:100px; resize:vertical; }

/* ===== REGISTER FORM ===== */
.register-section { padding:64px 40px; }
.register-wrap {
  display:grid; grid-template-columns:1fr 2fr;
  gap:80px; max-width:1200px; margin:0 auto; align-items:start;
}
.register-info h2 { font-size:1.6rem; font-weight:900; color:var(--navy); margin-bottom:20px; line-height:1.4; }
.register-info p { font-size:.9rem; color:var(--gray); line-height:1.9; margin-bottom:32px; }
.plan-summary {
  background:var(--navy); border-radius:4px; padding:28px;
  margin-bottom:24px;
}
.plan-summary-name { font-size:.7rem; letter-spacing:.15em; color:rgba(255,255,255,.5); margin-bottom:8px; font-weight:700; }
.plan-summary-price { font-size:1.6rem; font-weight:900; color:#fff; }
.plan-summary-price span { font-size:.85rem; font-weight:400; color:rgba(255,255,255,.4); }
.register-form-area { background:var(--off); padding:48px; border-radius:4px; }
.form-section-title {
  font-size:.72rem; font-weight:700; letter-spacing:.2em;
  color:var(--gold); margin-bottom:20px; padding-bottom:12px;
  border-bottom:1px solid var(--border);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:.8rem; font-weight:700; color:var(--navy); margin-bottom:7px; }
.req { color:var(--gold); font-size:.7rem; margin-left:4px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; padding:13px 17px; border:1.5px solid var(--border);
  background:#fff; border-radius:3px; font-family:inherit; font-size:.92rem;
  transition: border-color .2s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  outline:none; border-color:var(--gold);
}
.form-group textarea { height:120px; resize:vertical; }
.plan-select-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:4px; }
.plan-option { border:2px solid var(--border); border-radius:3px; padding:16px; cursor:pointer; transition:all .2s; }
.plan-option input[type=radio] { display:none; }
.plan-option:has(input:checked), .plan-option.selected {
  border-color:var(--gold); background:rgba(201,168,76,.05);
}
.plan-option-name { font-size:.75rem; font-weight:700; color:var(--gray); letter-spacing:.1em; margin-bottom:4px; }
.plan-option-price { font-size:1.1rem; font-weight:900; color:var(--navy); }
.plan-option-price span { font-size:.72rem; font-weight:400; }
.submit-area { text-align:center; margin-top:12px; }
.btn-submit {
  background:var(--gold); color:var(--navy); border:none;
  padding:18px 64px; font-family:inherit; font-size:1rem; font-weight:700;
  letter-spacing:.06em; border-radius:3px; cursor:pointer;
  transition: background .2s, transform .2s;
}
.btn-submit:hover { background:var(--gold-lt); transform:translateY(-2px); }
.submit-note { font-size:.75rem; color:var(--gray); margin-top:12px; }

/* ===== FOOTER ===== */
footer { background:var(--navy); color:#fff; padding:64px 40px 28px; }
.footer-inner { max-width:1200px; margin:0 auto; }
.footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px; padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:28px;
}
.footer-logo { font-size:1.1rem; font-weight:900; margin-bottom:14px; }
.footer-logo span { color:var(--gold); }
.footer-tagline { font-size:.8rem; color:rgba(255,255,255,.35); line-height:1.9; }
.footer-col h4 { font-size:.68rem; letter-spacing:.2em; color:var(--gold); font-weight:700; margin-bottom:18px; }
.footer-col ul { list-style:none; }
.footer-col li { margin-bottom:10px; }
.footer-col a { font-size:.83rem; color:rgba(255,255,255,.5); transition:color .2s; }
.footer-col a:hover { color:#fff; }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  font-size:.75rem; color:rgba(255,255,255,.28);
}

/* ===== MOBILE ===== */
@media (max-width:900px) {
  section { padding:64px 24px; }
  .header-inner { padding:0 24px; }
  nav ul { display:none; }
  .hero { padding:100px 0 60px; }
  .hero-inner { grid-template-columns:1fr; }
  .hero-left { padding:0 24px; }
  .hero-right { display:none; }
  .hero-kpi { gap:32px; }
  .steps, .for-grid, .card-grid, .plan-grid,
  .companies-grid, .register-wrap { grid-template-columns:1fr; }
  .detail-layout { grid-template-columns:1fr; padding:40px 24px; }
  .form-row { grid-template-columns:1fr; }
  .plan-select-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; gap:32px; }
  .footer-bottom { flex-direction:column; gap:12px; }
  .search-bar-wrap { padding:24px; }
  .register-form-area { padding:28px 20px; }
  .page-hero { padding:120px 24px 60px; }
}
