:root {
  --green: #06C755;
  --green-dark: #00A040;
  --green-light: #E8FAF0;
  --green-mid: #04A844;
  --green-pale: #F0FBF4;
  --black: #0D1117;
  --gray-dark: #2D3748;
  --gray: #64748B;
  --gray-light: #F8FAFC;
  --gray-mid: #EDF2F7;
  --white: #FFFFFF;
  --border: #E2E8F0;
  --font: "Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.08), 0 2px 6px rgba(0,0,0,0.05);
  --shadow-lg: 0 20px 50px rgba(0,0,0,0.10), 0 8px 20px rgba(0,0,0,0.06);
  --shadow-green: 0 8px 30px rgba(6,199,85,0.25);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;color-scheme:light;}
body{font-family:var(--font);color:var(--black);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased;color-scheme:light;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

/* ===== HEADER ===== */
header {
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(255,255,255,0.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:0 40px;
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
  transition:box-shadow 0.3s;
}
.logo {
  font-size:22px;font-weight:900;
  color:var(--green);letter-spacing:-0.5px;
  display:flex;align-items:center;gap:6px;
}
.logo-icon {
  width:32px;height:32px;background:var(--green);border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:white;font-size:16px;font-weight:900;
}
.logo span{color:var(--black);}
nav{display:flex;align-items:center;gap:28px;}
nav a{font-size:14px;color:var(--gray);font-weight:500;transition:color 0.2s;}
nav a:hover{color:var(--green);}
.nav-login{font-size:14px;color:var(--gray-dark);font-weight:600;}
.nav-cta{
  background:var(--green);color:var(--white)!important;
  padding:9px 22px;border-radius:7px;font-weight:700;font-size:14px;
  transition:all 0.2s;white-space:nowrap;
  box-shadow:0 2px 8px rgba(6,199,85,0.3);
}
.nav-cta:hover{background:var(--green-mid);transform:translateY(-1px);box-shadow:var(--shadow-green);}

/* ===== 固定ページ（特商法・利用規約など） ===== */
.lp-public-page {
  background:linear-gradient(180deg, var(--green-pale) 0%, var(--gray-light) 220px, var(--gray-light) 100%);
  min-height:100vh;
}
.lp-page-shell {
  max-width:920px;
  margin:0 auto;
  padding:0 20px;
}
.lp-page-main {
  padding:96px 0 72px;
}
.lp-page-hero {
  margin-bottom:24px;
}
.lp-page-eyebrow {
  font-size:12px;
  font-weight:800;
  letter-spacing:0.12em;
  color:var(--green);
  margin-bottom:10px;
}
.lp-page-title {
  font-size:32px;
  font-weight:900;
  color:var(--black);
  letter-spacing:-0.8px;
  line-height:1.25;
}
.lp-page-lead {
  margin-top:12px;
  font-size:15px;
  line-height:1.8;
  color:var(--gray);
}
.lp-page-card {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:16px;
  box-shadow:var(--shadow-md);
  padding:28px 28px 32px;
}
.lp-page-content {
  font-size:15px;
  line-height:1.85;
  color:var(--gray-dark);
}
.lp-page-content > * + * {margin-top:16px;}
.lp-page-link {
  color:var(--green);
  text-decoration:underline;
  font-weight:700;
}
.lp-page-link:hover {color:var(--green-dark);}
.lp-page-note {
  margin-top:20px;
  padding:14px 16px;
  border-radius:10px;
  background:var(--green-pale);
  border:1px solid rgba(6,199,85,0.18);
  font-size:13px;
  color:var(--gray);
}
.lp-alert {
  margin-bottom:20px;
  padding:14px 16px;
  border-radius:10px;
  font-size:14px;
  line-height:1.6;
}
.lp-alert-success {
  background:#ecfdf3;
  border:1px solid #86efac;
  color:#166534;
}
.lp-alert-error {
  background:#fef2f2;
  border:1px solid #fecaca;
  color:#991b1b;
}
.lp-alert-warning {
  background:#fffbeb;
  border:1px solid #fde68a;
  color:#92400e;
}
.lp-alert-title {font-weight:700;margin-bottom:6px;}
.lp-alert-list {
  margin:0;
  padding-left:18px;
}
.lp-faq-list {display:grid;gap:16px;}
.lp-faq-item {
  padding:18px 20px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--gray-light);
}
.lp-faq-question {
  font-size:16px;
  font-weight:800;
  color:var(--black);
  margin-bottom:8px;
}
.lp-faq-answer {color:var(--gray-dark);}
.lp-info-list {
  margin:0;
}
.lp-info-item {
  padding:18px 0;
  border-bottom:1px solid var(--border);
}
.lp-info-item:first-child {padding-top:0;}
.lp-info-item:last-child {
  border-bottom:none;
  padding-bottom:0;
}
.lp-info-label {
  font-size:12px;
  font-weight:800;
  letter-spacing:0.06em;
  color:var(--gray);
  margin:0 0 8px;
}
.lp-info-value {
  margin:0;
  font-size:15px;
  font-weight:700;
  color:var(--black);
  line-height:1.7;
}
.lp-info-sub {
  font-size:13px;
  font-weight:600;
  color:var(--gray);
}
.lp-contact-aside {
  margin-bottom:24px;
  padding:16px 18px;
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--gray-light);
  font-size:15px;
  font-weight:700;
  line-height:1.8;
}
.lp-legal-table {
  width:100%;
  border-collapse:collapse;
}
.lp-legal-table th {
  text-align:left;
  padding:14px 20px 14px 0;
  width:32%;
  vertical-align:top;
  font-weight:800;
  color:var(--black);
  font-size:14px;
}
.lp-legal-table td {
  padding:14px 0;
  vertical-align:top;
  font-size:15px;
}
.lp-legal-table tr + tr th,
.lp-legal-table tr + tr td {
  border-top:1px solid var(--border);
}
.las-reg-doc-body {
  font-size:15px;
  line-height:1.85;
  color:var(--gray-dark);
}
.las-reg-doc-heading {
  margin:24px 0 10px;
  padding-bottom:8px;
  border-bottom:2px solid var(--green-light);
  font-size:17px;
  font-weight:800;
  color:var(--black);
}
.las-reg-doc-heading:first-child {margin-top:0;}
.las-reg-doc-bullet,
.las-reg-doc-paragraph {
  margin:0 0 10px;
}
.lp-contact-form {display:grid;gap:18px;}
.lp-form-grid {
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}
.lp-form-field {display:grid;gap:8px;}
.lp-form-label {
  font-size:14px;
  font-weight:700;
  color:var(--black);
}
.lp-form-required {
  margin-left:6px;
  font-size:11px;
  font-weight:800;
  color:var(--green-dark);
}
.lp-form-input,
.lp-form-textarea {
  width:100%;
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px 14px;
  font:inherit;
  color:var(--black);
  background:var(--white);
  transition:border-color 0.2s, box-shadow 0.2s;
}
.lp-form-input:focus,
.lp-form-textarea:focus {
  outline:none;
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(6,199,85,0.15);
}
.lp-form-textarea {resize:vertical; min-height:180px;}
.lp-form-actions {display:grid;gap:10px;}
.lp-form-submit {
  border:none;
  border-radius:10px;
  background:var(--green);
  color:var(--white);
  font-size:16px;
  font-weight:800;
  padding:14px 20px;
  cursor:pointer;
  box-shadow:var(--shadow-green);
  transition:transform 0.2s, opacity 0.2s;
}
.lp-form-submit:hover:not(:disabled) {
  transform:translateY(-1px);
  background:var(--green-mid);
}
.lp-form-submit:disabled {
  opacity:0.55;
  cursor:not-allowed;
  box-shadow:none;
}
.lp-form-note {
  font-size:13px;
  color:var(--gray);
}
.lp-form-honeypot {
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

/* ===== HERO ===== */
.hero {
  min-height:100vh;
  background:linear-gradient(145deg, #F0FBF4 0%, #FFFFFF 55%, #EBF8F1 100%);
  display:flex;align-items:center;
  padding:100px 40px 60px;
  position:relative;overflow:hidden;
}
.hero-blob1 {
  position:absolute;width:700px;height:700px;
  background:radial-gradient(circle, rgba(6,199,85,0.07) 0%, transparent 65%);
  top:-200px;right:-100px;pointer-events:none;
}
.hero-blob2 {
  position:absolute;width:400px;height:400px;
  background:radial-gradient(circle, rgba(6,199,85,0.05) 0%, transparent 65%);
  bottom:-100px;left:100px;pointer-events:none;
}
.hero-inner {
  max-width:1160px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
  position:relative;z-index:1;
}
.hero-badge {
  display:inline-flex;align-items:center;gap:8px;
  background:var(--white);border:1px solid rgba(6,199,85,0.35);
  padding:7px 18px;border-radius:100px;
  font-size:13px;font-weight:700;color:var(--green-dark);
  margin-bottom:24px;box-shadow:var(--shadow-sm);
}
.hero-badge-dot {
  width:7px;height:7px;background:var(--green);border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse {
  0%,100%{opacity:1;transform:scale(1);}
  50%{opacity:0.6;transform:scale(0.85);}
}
h1 {
  font-size:48px;font-weight:900;line-height:1.2;
  letter-spacing:-1.5px;margin-bottom:22px;
  color:var(--black);
}
h1 .accent{color:var(--green);}
.hero-sub {
  font-size:17px;color:var(--gray);line-height:1.85;margin-bottom:36px;
}
.hero-tags {
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px;
}
.hero-tag {
  background:var(--green-pale);color:var(--green-dark);
  font-size:12px;font-weight:600;padding:5px 12px;border-radius:100px;
  border:1px solid rgba(6,199,85,0.2);
}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;align-items:center;}
.btn-primary {
  background:var(--green);color:var(--white);
  padding:15px 34px;border-radius:9px;font-weight:700;font-size:16px;
  transition:all 0.2s;display:inline-block;
  box-shadow:var(--shadow-green);
}
.btn-primary:hover{background:var(--green-mid);transform:translateY(-2px);box-shadow:0 12px 36px rgba(6,199,85,0.35);}
.btn-outline {
  border:2px solid var(--border);color:var(--gray-dark);
  padding:13px 28px;border-radius:9px;font-weight:600;font-size:15px;
  transition:all 0.2s;display:inline-block;background:var(--white);
}
.btn-outline:hover{border-color:var(--green);color:var(--green);background:var(--green-pale);}
.hero-note{font-size:12px;color:var(--gray);margin-top:14px;}

/* Hero Visual */
.hero-visual-wrap {
  position:relative;
}
.hero-custom-image {
  width:100%;
  max-width:520px;
  border-radius:16px;
  box-shadow:0 20px 60px rgba(0,0,0,0.12);
  object-fit:cover;
}
.hero-visual {
  background:var(--white);border-radius:18px;
  box-shadow:var(--shadow-lg);
  overflow:hidden;border:1px solid var(--border);
  position:relative;z-index:2;
}
.hero-float-card {
  position:absolute;z-index:3;
  background:var(--white);border-radius:12px;
  box-shadow:var(--shadow-md);
  border:1px solid var(--border);
  padding:12px 16px;
  animation:float 4s ease-in-out infinite;
}
.hero-float-card.card1 {
  bottom:-20px;left:-30px;
  animation-delay:0s;
}
.hero-float-card.card2 {
  top:30px;right:-30px;
  animation-delay:1.5s;
}
@keyframes float {
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-8px);}
}
.float-label{font-size:11px;color:var(--gray);font-weight:600;margin-bottom:4px;}
.float-val{font-size:20px;font-weight:900;color:var(--green);}
.float-val2{font-size:13px;font-weight:700;color:var(--gray-dark);}

.mock-header{
  background:var(--green);padding:14px 20px;
  display:flex;align-items:center;gap:10px;
}
.mock-header-dot {width:8px;height:8px;background:rgba(255,255,255,0.4);border-radius:50%;}
.mock-header-title {color:var(--white);font-weight:700;font-size:13px;margin-left:4px;}
.mock-body{padding:18px;background:#F9FBF9;}
.mock-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;}
.mock-stat{
  background:var(--white);border-radius:10px;padding:14px 10px;
  border:1px solid var(--border);text-align:center;
}
.mock-stat-num{font-size:21px;font-weight:900;color:var(--green);}
.mock-stat-label{font-size:10px;color:var(--gray);margin-top:3px;}
.mock-chart{
  background:var(--white);border-radius:10px;padding:14px;
  border:1px solid var(--border);margin-bottom:12px;
}
.mock-chart-title{font-size:11px;font-weight:700;margin-bottom:10px;color:var(--gray-dark);}
.mock-bars{display:flex;align-items:flex-end;gap:6px;height:52px;}
.mock-bar{flex:1;background:linear-gradient(to top,var(--green-dark),var(--green));border-radius:3px 3px 0 0;opacity:0.85;}
.mock-chips{display:flex;gap:8px;flex-wrap:wrap;}
.mock-chip{
  background:var(--green-light);color:var(--green-dark);
  font-size:10px;font-weight:700;padding:4px 10px;border-radius:100px;
}

/* ===== MARQUEE STRIP ===== */
.marquee-strip {
  background:var(--black);padding:14px 0;overflow:hidden;
  border-top:3px solid var(--green);
}
.marquee-track {
  display:flex;gap:0;
  animation:marquee 28s linear infinite;
  width:max-content;
}
.marquee-item {
  display:flex;align-items:center;gap:12px;
  padding:0 36px;font-size:13px;font-weight:600;color:rgba(255,255,255,0.75);
  white-space:nowrap;border-right:1px solid rgba(255,255,255,0.12);
}
.marquee-item .mi{font-size:16px;}
@keyframes marquee {
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* ===== NUMBERS ===== */
.numbers {
  background:var(--green);padding:56px 40px;
}
.numbers-inner {
  max-width:1000px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.number-item {
  text-align:center;padding:20px;
  border-right:1px solid rgba(255,255,255,0.2);
}
.number-item:last-child{border-right:none;}
.number-num{font-size:44px;font-weight:900;color:var(--white);line-height:1;}
.number-unit{font-size:18px;font-weight:700;}
.number-label{font-size:13px;color:rgba(255,255,255,0.8);margin-top:8px;font-weight:500;}

/* ===== SECTION COMMON ===== */
.section-label {
  font-size:12px;font-weight:800;color:var(--green);
  letter-spacing:3px;text-transform:uppercase;margin-bottom:10px;
}
.section-title {
  font-size:36px;font-weight:900;letter-spacing:-0.8px;margin-bottom:14px;
  color:var(--black);
}
.section-sub{font-size:16px;color:var(--gray);line-height:1.8;}

/* ===== FEATURE CATEGORIES ===== */
.feat-cats {
  padding:100px 40px;background:var(--white);
}
.feat-cats-inner{max-width:1160px;margin:0 auto;}
.feat-cats-header{margin-bottom:64px;}
.feat-cats-grid {
  display:grid;grid-template-columns:repeat(2,1fr);gap:28px;
}
.feat-cat-card {
  border-radius:20px;padding:40px;
  border:1px solid var(--border);
  background:var(--white);
  transition:all 0.25s;
  position:relative;overflow:hidden;
}
.feat-cat-card::before {
  content:'';position:absolute;
  top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--green),var(--green-dark));
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s;
}
.feat-cat-card:hover::before{transform:scaleX(1);}
.feat-cat-card:hover {
  box-shadow:var(--shadow-lg);
  transform:translateY(-4px);
  border-color:rgba(6,199,85,0.2);
}
.feat-cat-head {
  display:flex;align-items:center;gap:16px;margin-bottom:24px;
}
.feat-cat-icon {
  width:52px;height:52px;border-radius:14px;
  background:var(--green-light);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;flex-shrink:0;
}
.feat-cat-title{font-size:20px;font-weight:800;color:var(--black);}
.feat-cat-desc{font-size:14px;color:var(--gray);line-height:1.8;margin-bottom:24px;}
.feat-cat-items {
  display:flex;flex-wrap:wrap;gap:8px;
}
.feat-cat-item {
  font-size:12px;font-weight:600;color:var(--gray-dark);
  background:var(--gray-light);
  padding:5px 12px;border-radius:100px;
  border:1px solid var(--border);
}

/* ===== ALL FEATURES GRID ===== */
.all-features {
  padding:100px 40px;background:var(--gray-light);
}
.all-features-inner{max-width:1160px;margin:0 auto;}
.all-features-header{text-align:center;margin-bottom:60px;}
.features-grid {
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.feature-card {
  background:var(--white);border-radius:14px;padding:26px;
  border:1px solid var(--border);
  transition:all 0.22s;
  position:relative;
}
.feature-card:hover {
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:rgba(6,199,85,0.3);
}
.feature-icon {
  width:44px;height:44px;border-radius:11px;
  background:var(--green-light);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:16px;
}
.feature-card h3{font-size:15px;font-weight:800;margin-bottom:8px;color:var(--black);}
.feature-card p{font-size:13px;color:var(--gray);line-height:1.75;}
.feature-plan {
  margin-top:14px;
  font-size:11px;font-weight:700;color:var(--green-dark);
  background:var(--green-light);padding:3px 10px;border-radius:100px;
  display:inline-block;
  line-height:1.5;
  max-width:100%;
  word-break:break-word;
}

/* ===== TARGET SECTION ===== */
.targets {
  padding:100px 40px;background:var(--white);
}
.targets-inner{max-width:1160px;margin:0 auto;}
.targets-header{margin-bottom:60px;}
.targets-grid {
  display:grid;grid-template-columns:repeat(5,1fr);gap:20px;
}
.target-card {
  border-radius:16px;padding:28px 20px;
  background:var(--gray-light);
  border:1px solid var(--border);
  text-align:center;
  transition:all 0.22s;cursor:default;
}
.target-card:hover {
  background:var(--green-pale);
  border-color:rgba(6,199,85,0.35);
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(6,199,85,0.12);
}
.target-emoji{font-size:36px;margin-bottom:14px;}
.target-name{font-size:14px;font-weight:800;color:var(--black);margin-bottom:6px;}
.target-desc{font-size:12px;color:var(--gray);line-height:1.6;}

/* ===== FLOW SECTION ===== */
.flow {
  padding:100px 40px;background:var(--black);
}
.flow-inner{max-width:1000px;margin:0 auto;text-align:center;}
.flow-title{
  font-size:34px;font-weight:900;color:var(--white);
  letter-spacing:-0.8px;margin-bottom:12px;
}
.flow-sub{font-size:16px;color:rgba(255,255,255,0.6);margin-bottom:60px;}
.flow-steps {
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;
}
.flow-steps::before {
  content:'';position:absolute;
  top:36px;left:12%;right:12%;height:2px;
  background:linear-gradient(90deg,var(--green),var(--green-dark));
  z-index:0;
}
.flow-step {
  position:relative;z-index:1;
  display:flex;flex-direction:column;align-items:center;
  padding:0 16px;
}
.flow-num {
  width:72px;height:72px;border-radius:50%;
  background:var(--green);
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:900;color:var(--white);
  margin-bottom:20px;
  box-shadow:0 0 0 6px rgba(6,199,85,0.15);
  border:3px solid rgba(255,255,255,0.1);
}
.flow-step-title{font-size:15px;font-weight:800;color:var(--white);margin-bottom:8px;}
.flow-step-desc{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.7;}

/* ===== PRICING ===== */
.pricing{padding:100px 40px;background:var(--gray-light);}
.pricing-inner{max-width:1100px;margin:0 auto;text-align:center;}
.pricing-note{
  display:inline-block;
  background:var(--green-pale);color:var(--green-dark);
  font-size:13px;font-weight:700;padding:8px 20px;border-radius:100px;
  border:1px solid rgba(6,199,85,0.25);margin-bottom:48px;
}
.plans-scroll-wrap {
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  margin-top:48px;
  padding-bottom:8px;
  scrollbar-width:thin;
}
.plans-scroll-wrap::-webkit-scrollbar{height:6px;}
.plans-scroll-wrap::-webkit-scrollbar-thumb{
  background:rgba(6,199,85,0.35);
  border-radius:999px;
}
.plans-grid {
  display:flex;
  gap:24px;
  margin-top:0;
  width:max-content;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  padding:4px 2px 8px;
}
.plan-card {
  background:var(--white);border-radius:20px;padding:38px 32px;
  border:1px solid var(--border);position:relative;
  transition:all 0.22s;text-align:left;
  flex:0 0 340px;
  width:340px;
  display:flex;
  flex-direction:column;
}
.plan-card:hover{box-shadow:var(--shadow-lg);}
.plan-card.featured {
  border-color:var(--border);
  box-shadow:var(--shadow-md);
  background:var(--white);
}
.plan-card--display-only {
  pointer-events:none;
  user-select:none;
}
.plans-scroll-wrap--auto {
  overflow:hidden;
  margin-top:48px;
  padding-bottom:8px;
  -webkit-mask-image:linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
  mask-image:linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
}
.plans-grid--marquee {
  width:max-content;
  animation:lp-plans-marquee 50s linear infinite;
}
.plans-scroll-wrap--auto:hover .plans-grid--marquee {
  animation-play-state:paused;
}
@keyframes lp-plans-marquee {
  0% { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}
.plans-display-note {
  margin-top:20px;
  font-size:13px;
  color:var(--gray);
  line-height:1.6;
}
.plan-badge {
  position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  background:var(--green);color:var(--white);
  font-size:11px;font-weight:800;padding:5px 18px;border-radius:100px;
  white-space:nowrap;letter-spacing:0.5px;
}
.plan-name{font-size:22px;font-weight:900;margin-bottom:6px;}
.plan-price {
  font-size:42px;font-weight:900;color:var(--green);
  margin:18px 0 4px;letter-spacing:-1px;
}
.plan-price span{font-size:15px;font-weight:500;color:var(--gray);}
.plan-trial{
  margin-top:8px;
  font-size:12px;font-weight:700;color:var(--green-dark);
}
.plan-desc{font-size:13px;color:var(--gray);margin-bottom:26px;line-height:1.6;}
.plan-limit{
  display:inline-block;
  margin:12px 0 0;
  padding:6px 14px;
  border-radius:100px;
  background:var(--green-pale);
  border:1px solid rgba(6,199,85,0.25);
  font-size:13px;font-weight:700;color:var(--green-dark);
}
.plan-divider{border:none;border-top:1px solid var(--border);margin:20px 0;}
.plan-features{
  list-style:none;
  margin-bottom:32px;
  flex:1;
}
.plan-features li {
  font-size:13px;padding:7px 0;
  border-bottom:1px solid var(--border);
  display:flex;align-items:flex-start;gap:9px;color:var(--gray-dark);
  line-height:1.5;
}
.plan-features li:last-child{border-bottom:none;}
.pf-check{color:var(--green);font-weight:900;font-size:14px;flex-shrink:0;margin-top:2px;}
.plan-btn {
  display:block;width:100%;padding:14px;border-radius:9px;
  font-weight:700;font-size:15px;text-align:center;transition:all 0.2s;
  margin-top:auto;
}
.plan-btn-primary{background:var(--green);color:var(--white);box-shadow:0 4px 14px rgba(6,199,85,0.3);}
.plan-btn-primary:hover{background:var(--green-mid);}
.plan-btn-outline{border:2px solid var(--border);color:var(--gray-dark);}
.plan-btn-outline:hover{border-color:var(--green);color:var(--green);}

/* ===== CTA ===== */
.cta {
  padding:100px 40px;
  background:linear-gradient(135deg,#0D1117 0%,#1a2e1e 100%);
  text-align:center;position:relative;overflow:hidden;
}
.cta-blob {
  position:absolute;width:500px;height:500px;
  background:radial-gradient(circle,rgba(6,199,85,0.12) 0%,transparent 65%);
  top:-100px;left:50%;transform:translateX(-50%);
  pointer-events:none;
}
.cta-inner{position:relative;z-index:1;}
.cta h2{
  font-size:40px;font-weight:900;color:var(--white);
  letter-spacing:-1px;margin-bottom:16px;
}
.cta p{font-size:17px;color:rgba(255,255,255,0.65);margin-bottom:40px;line-height:1.8;}
.btn-white {
  background:var(--white);color:var(--green);
  padding:18px 48px;border-radius:10px;font-weight:800;font-size:17px;
  display:inline-block;transition:all 0.2s;
  box-shadow:0 8px 30px rgba(255,255,255,0.15);
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 14px 40px rgba(255,255,255,0.2);}
.cta-note{font-size:13px;color:rgba(255,255,255,0.4);margin-top:18px;}

/* ===== FOOTER ===== */
footer{background:var(--black);padding:60px 40px 30px;}
.footer-inner{
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,0.08);
}
.footer-logo{
  font-size:22px;font-weight:900;color:var(--green);
  letter-spacing:-0.5px;margin-bottom:14px;
}
.footer-desc{font-size:14px;color:rgba(255,255,255,0.45);line-height:1.8;}
.footer-col h4{font-size:13px;font-weight:800;color:rgba(255,255,255,0.85);margin-bottom:18px;letter-spacing:0.5px;}
.footer-col a{
  display:block;font-size:13px;color:rgba(255,255,255,0.45);
  margin-bottom:10px;transition:color 0.2s;
}
.footer-col a:hover{color:var(--green);}
.footer-bottom{
  max-width:1160px;margin:28px auto 0;
  display:flex;justify-content:space-between;align-items:center;
  font-size:12px;color:rgba(255,255,255,0.25);
}
.footer-green{color:var(--green);}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .features-grid{grid-template-columns:repeat(3,1fr);}
  .targets-grid{grid-template-columns:repeat(3,1fr);}
  .numbers-inner{grid-template-columns:repeat(2,1fr);}
  .number-item:nth-child(2){border-right:none;}
}
@media(max-width:768px){
  header{padding:0 16px;}
  nav{gap:10px;}
  nav .hide-mob-nav{display:none;}
  .nav-login{
    font-size:13px;
    padding:8px 12px;
    border:1px solid var(--border);
    border-radius:7px;
    white-space:nowrap;
  }
  .nav-cta{padding:8px 14px;font-size:13px;}
  .logo{font-size:18px;}
  .logo-icon{width:28px;height:28px;font-size:14px;}
  .lp-page-main{padding:88px 0 56px;}
  .lp-page-title{font-size:26px;}
  .lp-page-card{padding:22px 18px 24px;border-radius:14px;}
  .lp-form-grid{grid-template-columns:1fr;}
  .lp-legal-table th,
  .lp-legal-table td{display:block;width:100%;padding:10px 0;}
  .lp-legal-table th{padding-bottom:4px;}
  .lp-legal-table tr + tr td{border-top:none;padding-top:0;}
  .hero{padding:90px 20px 48px;}
  .hero-inner{grid-template-columns:1fr;gap:40px;}
  .hero-visual-wrap{display:none;}
  h1{font-size:34px;}
  .feat-cats-grid{grid-template-columns:1fr;}
  .features-grid{grid-template-columns:repeat(2,1fr);}
  .flow-steps{grid-template-columns:repeat(2,1fr);}
  .flow-steps::before{display:none;}
  .plans-scroll-wrap{margin-top:32px;}
  .plans-grid{justify-content:flex-start;}
  .plan-card{flex-basis:min(340px,88vw);width:min(340px,88vw);}
  .footer-inner{grid-template-columns:1fr 1fr;}
  .targets-grid{grid-template-columns:repeat(2,1fr);}
  .section-title{font-size:28px;}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center;}
  .numbers-inner{grid-template-columns:repeat(2,1fr);}
  .number-item:nth-child(2){border-right:none;}
  .number-item:nth-child(3){border-top:1px solid rgba(255,255,255,0.2);}
  .number-item:nth-child(4){border-top:1px solid rgba(255,255,255,0.2);}
  .plans-scroll-wrap--auto{
    overflow-x:auto;
    -webkit-mask-image:none;
    mask-image:none;
  }
  .plans-grid--marquee{animation:none;}
}
@media (prefers-reduced-motion: reduce){
  .plans-scroll-wrap--auto{
    overflow-x:auto;
    -webkit-mask-image:none;
    mask-image:none;
  }
  .plans-grid--marquee{animation:none;}
}