﻿: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;}
body{font-family:var(--font);color:var(--black);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased;}
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);}

/* ===== 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-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;
}

/* ===== 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-grid {
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:48px;
}
.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;
}
.plan-card:hover{box-shadow:var(--shadow-lg);}
.plan-card.featured {
  border-color:var(--green);
  box-shadow:0 0 0 2px var(--green), var(--shadow-md);
  background:var(--white);
}
.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-desc{font-size:13px;color:var(--gray);margin-bottom:26px;line-height:1.6;}
.plan-divider{border:none;border-top:1px solid var(--border);margin:20px 0;}
.plan-features{list-style:none;margin-bottom:32px;}
.plan-features li {
  font-size:13px;padding:7px 0;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:9px;color:var(--gray-dark);
}
.plan-features li:last-child{border-bottom:none;}
.pf-check{color:var(--green);font-weight:900;font-size:14px;}
.plan-btn {
  display:block;width:100%;padding:14px;border-radius:9px;
  font-weight:700;font-size:15px;text-align:center;transition:all 0.2s;
}
.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 20px;}
  nav .hide-mob{display:none;}
  .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-grid{grid-template-columns:1fr;}
  .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);}
}
