
:root{--navy:#06182d;--navy2:#0b2745;--ink:#06182d;--muted:#5d6d80;--line:rgba(6,24,45,.13);--paper:#f5f7fa;--white:#fff;--blue:#1d6eaf;--aqua:#70c8d8;--gold:#c79543;--shadow:0 24px 60px rgba(6,24,45,.14);--soft:0 14px 36px rgba(6,24,45,.09);--radius:24px;--max:1180px;--ease:cubic-bezier(.2,.8,.2,1)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Yu Gothic",YuGothic,Meiryo,sans-serif;color:var(--ink);background:#fff;line-height:1.85;letter-spacing:.025em;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.site{overflow:hidden}.container{width:min(var(--max),calc(100% - 48px));margin:auto}.section{padding:96px 0}.section-soft{background:var(--paper)}.section-dark{background:linear-gradient(135deg,var(--navy),var(--navy2));color:#fff}.section-dark .title,.section-dark h2,.section-dark h3{color:#fff}.section-dark .lead,.section-dark p{color:rgba(255,255,255,.78)}
.header{position:fixed;inset:12px 0 auto;z-index:50;pointer-events:none}.nav{pointer-events:auto;width:min(1280px,calc(100% - 24px));margin:auto;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:10px 14px 10px 28px;border-radius:999px;background:rgba(255,255,255,.90);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.72);box-shadow:0 14px 42px rgba(6,24,45,.12)}.brand{display:flex;align-items:center;min-width:max-content}.brand-logo{width:132px;height:auto;max-height:58px;object-fit:contain}.nav-links{display:flex;align-items:center;gap:3px;font-size:13px;font-weight:850;color:rgba(11,22,38,.70)}.nav-links a{padding:9px 10px;border-radius:999px;transition:.2s var(--ease);white-space:nowrap}.nav-links a:hover,.nav-links a.active{background:rgba(29,110,175,.10);color:var(--navy)}.nav-cta{margin-left:6px}.menu{display:none;width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--navy);font-weight:900}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:0 22px;border-radius:999px;border:1px solid transparent;font-weight:900;font-size:14px;white-space:nowrap;transition:.2s var(--ease)}.btn:hover{transform:translateY(-2px)}.btn-dark,.btn.primary{background:var(--navy);color:#fff;box-shadow:0 16px 40px rgba(6,24,45,.22)}.btn-white,.btn.secondary{background:#fff;color:var(--navy);border-color:rgba(6,24,45,.14);box-shadow:0 12px 28px rgba(6,24,45,.08)}.btn-outline,.btn.ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28)}.btn-muted{background:#eef5f8;color:var(--navy);border-color:#d8e8ee}
.hero,.page-hero{position:relative;min-height:88vh;display:grid;align-items:center;background:var(--navy);color:#fff;overflow:hidden}.page-hero{min-height:70vh}.hero-media,.page-hero-media{position:absolute;inset:0}.hero-media img,.page-hero-media img{width:100%;height:100%;object-fit:cover}.hero-media:after,.page-hero-media:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(3,15,30,.88) 0%,rgba(3,15,30,.72) 38%,rgba(3,15,30,.20) 76%,rgba(3,15,30,.08) 100%),linear-gradient(180deg,rgba(3,15,30,.22),rgba(3,15,30,.36))}.hero-inner,.page-hero-inner{position:relative;z-index:1;padding:150px 0 64px}.hero-copy,.page-copy{max-width:820px}.hero h1,.page-hero h1{margin:24px 0 18px;font-size:clamp(44px,7vw,86px);line-height:1.08;font-weight:900;letter-spacing:-.06em;text-shadow:0 10px 30px rgba(0,0,0,.25)}.page-hero h1{font-size:clamp(38px,5.6vw,72px)}.hero p,.page-hero p{max-width:720px;margin:0;color:rgba(255,255,255,.82);font-size:17px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}.eyebrow,.kicker{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.eyebrow{padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.86)}.eyebrow:before,.kicker:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--aqua);box-shadow:0 0 18px var(--aqua)}.kicker{color:var(--blue);margin-bottom:10px}.kicker:before{width:30px;height:1px;border-radius:0;background:var(--blue);box-shadow:none}.breadcrumb{font-size:13px;margin-bottom:28px;color:rgba(255,255,255,.78)}.breadcrumb a{text-decoration:underline;text-underline-offset:4px}.title{margin:0;color:var(--navy);font-size:clamp(30px,4.6vw,52px);line-height:1.2;letter-spacing:-.045em;font-weight:900}.lead{margin:0;color:var(--muted);font-size:16px;max-width:700px}.section-head{display:flex;justify-content:space-between;align-items:end;gap:42px;margin-bottom:38px}.section-head .lead{max-width:560px}.center{text-align:center}.center .lead{margin:14px auto 0}.center .kicker{justify-content:center}.center .kicker:before{display:none}
.grid{display:grid;gap:18px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.card,.platform-card,.tool-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--soft);padding:26px;min-width:0}.card h3,.platform-card h3,.tool-card h3{margin:8px 0 10px;color:var(--navy);font-size:22px;line-height:1.34}.card p,.platform-card p,.tool-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.85}.card:hover,.platform-card:hover,.tool-card:hover{transform:translateY(-4px);transition:.24s var(--ease);box-shadow:var(--shadow)}.text-link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;color:var(--blue);font-size:13px;font-weight:900}.text-link:after{content:"›";font-size:18px;line-height:1}.status{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;font-size:11px;font-weight:900}.status-live{background:#e6f6f0;color:#13704d}.status-dev,.status-plan{background:#eef5fb;color:#1d6eaf}.status-ready{background:#f6f1e5;color:#87612a}.tool-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.tool-code{color:var(--gold);font-size:12px;font-weight:900;text-transform:uppercase}.tag-list,.keyword-tags,.status-row,.mini-nav{display:flex;flex-wrap:wrap;gap:9px;margin-top:18px}.tag-list span,.keyword-tags span{display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border-radius:999px;background:#f2f7fb;border:1px solid #dce9f3;color:var(--navy);font-size:12px;font-weight:850}.mini-nav a{display:inline-flex;align-items:center;min-height:40px;padding:0 16px;border-radius:999px;background:#fff;border:1px solid var(--line);color:var(--navy);font-size:13px;font-weight:900}.feature-strip{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center;padding:34px;border-radius:30px;background:linear-gradient(135deg,var(--navy),#0d3157);color:#fff;box-shadow:var(--shadow);overflow:hidden}.feature-strip .kicker{color:#bfe8f0}.feature-strip .kicker:before{background:#bfe8f0}.feature-strip h3{margin:10px 0 12px;color:#fff;font-size:32px;line-height:1.45}.feature-strip p{color:rgba(255,255,255,.78)}.feature-strip img{max-height:260px;margin:auto}.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:42px;align-items:start}.process-list{counter-reset:num;display:grid;gap:16px}.process-step{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:20px;padding:22px;box-shadow:var(--soft)}.process-step:before{counter-increment:num;content:"0" counter(num);display:grid;place-items:center;width:48px;height:48px;border-radius:50%;background:#e9f4fb;color:var(--blue);font-weight:900}.process-step h3{margin:0 0 6px;color:var(--navy)}.process-step p{margin:0;color:var(--muted)}.faq-list{display:grid;gap:12px}.faq-item{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden}.faq-q{width:100%;display:flex;justify-content:space-between;gap:16px;align-items:center;background:#fff;border:0;padding:20px 22px;color:var(--navy);font:inherit;font-weight:900;text-align:left;cursor:pointer}.faq-a{display:none;padding:0 22px 20px;color:var(--muted)}.faq-item.open .faq-a{display:block}.cta{position:relative;color:#fff;overflow:hidden;background:var(--navy)}.cta .container{position:relative;z-index:1}.cta-bg{position:absolute;inset:0}.cta-bg img{width:100%;height:100%;object-fit:cover}.cta-bg:after{content:"";position:absolute;inset:0;background:rgba(3,15,30,.82)}.cta-inner{display:grid;grid-template-columns:1fr auto;gap:42px;align-items:center;padding:86px 0}.cta h2{margin:18px 0 14px;font-size:clamp(34px,5vw,58px);line-height:1.2;letter-spacing:-.05em}.cta p{color:rgba(255,255,255,.78);max-width:700px}.cta-contact{display:flex;gap:18px;align-items:center}.cta-actions{display:grid;gap:10px}.mail-link{display:flex;align-items:center;justify-content:center;min-height:46px;padding:0 18px;border:1px solid rgba(255,255,255,.22);border-radius:999px;color:#fff;font-weight:900}.line-card{background:#fff;color:var(--navy);border-radius:22px;padding:16px;text-align:center;box-shadow:var(--shadow)}.line-card img{width:116px;margin:auto}.line-card b{display:block;margin-top:8px}.line-card small{display:block;color:var(--muted);font-size:12px;line-height:1.55}.footer{background:var(--navy);color:#fff;padding:64px 0 28px}.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:36px}.footer .brand-logo{width:150px}.footer p,.footer a{color:rgba(255,255,255,.74);font-size:14px}.footer h3{margin:0 0 12px;color:#fff;font-size:15px}.footer-links{display:grid;align-content:start;gap:8px}.footer a:hover{color:#fff}.company-info{font-size:13px}.copy{display:flex;justify-content:space-between;gap:20px;border-top:1px solid rgba(255,255,255,.12);margin-top:38px;padding-top:22px;color:rgba(255,255,255,.55);font-size:12px}.note-box{border-left:4px solid var(--blue);background:#f4f9fd;border-radius:14px;padding:18px 20px;color:var(--muted)}
@media(max-width:980px){.menu{display:block}.nav{border-radius:28px;align-items:flex-start}.brand-logo{width:112px}.nav-links{display:none;position:absolute;left:12px;right:12px;top:70px;padding:16px;border-radius:22px;background:#fff;box-shadow:var(--shadow);flex-direction:column;align-items:stretch}.nav-links.open{display:flex}.nav-links a{padding:12px 14px}.nav-cta{margin:8px 0 0}.hero-inner,.page-hero-inner{padding-top:118px}.grid-2,.grid-3,.grid-4,.split,.feature-strip,.cta-inner,.footer-grid{grid-template-columns:1fr}.section-head{display:block}.cta-contact{align-items:stretch;flex-direction:column}.line-card{width:max-content}.hero h1,.page-hero h1{font-size:clamp(38px,12vw,58px)}.section{padding:72px 0}.container{width:min(var(--max),calc(100% - 32px))}}
@media(max-width:560px){.header{inset:8px 0 auto}.nav{width:calc(100% - 16px);padding:8px 10px 8px 16px}.brand-logo{width:104px}.hero,.page-hero{min-height:78vh}.hero-actions,.cta-actions{align-items:stretch;flex-direction:column}.btn{width:100%}.copy{display:block}.grid{gap:14px}.card,.platform-card,.tool-card{padding:22px}.feature-strip{padding:24px}.hero p,.page-hero p{font-size:15px}}


/* =====================================================
   Smart unified header refinement
   2026-07-02
   - Header is slimmer and less dominant.
   - Menu spacing is unified across all pages.
   - Active state is changed from a heavy pill to a subtle underline.
   - Mobile menu remains compact and readable.
===================================================== */
.header{
  inset:14px 0 auto !important;
}
.nav{
  position:relative !important;
  overflow:visible !important;
  width:min(1168px,calc(100% - 40px)) !important;
  min-height:64px !important;
  padding:8px 12px 8px 30px !important;
  gap:16px !important;
  border-radius:28px !important;
  background:rgba(255,255,255,.84) !important;
  -webkit-backdrop-filter:blur(20px) saturate(1.15) !important;
  backdrop-filter:blur(20px) saturate(1.15) !important;
  border:1px solid rgba(255,255,255,.82) !important;
  box-shadow:0 12px 34px rgba(6,24,45,.10) !important;
}
.nav::before{
  content:"";
  position:absolute;
  inset:1px;
  border-radius:27px;
  pointer-events:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.70), inset 0 -1px 0 rgba(6,24,45,.035);
}
.brand{
  padding:2px 0 !important;
  margin-right:8px !important;
}
.brand-logo{
  width:118px !important;
  max-height:46px !important;
  object-fit:contain !important;
}
.nav-links{
  flex:1 1 auto !important;
  justify-content:flex-end !important;
  gap:2px !important;
  font-size:12.5px !important;
  font-weight:850 !important;
  letter-spacing:.015em !important;
  color:rgba(6,24,45,.68) !important;
}
.nav-links a:not(.nav-cta){
  padding:7px 9px !important;
  border-radius:12px !important;
  background:transparent !important;
  color:rgba(6,24,45,.68) !important;
  line-height:1.2 !important;
}
.nav-links a:not(.nav-cta):hover{
  background:rgba(29,110,175,.07) !important;
  color:var(--navy) !important;
  transform:none !important;
}
.nav-links a:not(.nav-cta).active{
  background:transparent !important;
  color:var(--navy) !important;
  border-radius:0 !important;
  box-shadow:inset 0 -2px 0 rgba(29,110,175,.58) !important;
}
.nav-cta{
  margin-left:10px !important;
  min-height:42px !important;
  padding:0 18px !important;
  font-size:12.5px !important;
  border-radius:999px !important;
  box-shadow:0 10px 24px rgba(6,24,45,.16) !important;
  background:linear-gradient(135deg,#09213d 0%,#16517f 100%) !important;
  color:#fff !important;
}
.nav-cta:hover{
  transform:translateY(-1px) !important;
  box-shadow:0 14px 28px rgba(6,24,45,.20) !important;
}
.menu{
  width:40px !important;
  height:40px !important;
  background:rgba(255,255,255,.88) !important;
  box-shadow:0 8px 22px rgba(6,24,45,.08) !important;
}
.hero-inner,.page-hero-inner{
  padding-top:138px !important;
}
@media(max-width:1180px) and (min-width:981px){
  .nav{
    width:calc(100% - 22px) !important;
    padding:7px 10px 7px 22px !important;
    gap:10px !important;
  }
  .brand-logo{
    width:106px !important;
    max-height:42px !important;
  }
  .nav-links{
    gap:0 !important;
    font-size:11.5px !important;
  }
  .nav-links a:not(.nav-cta){
    padding:6px 6px !important;
  }
  .nav-cta{
    min-height:40px !important;
    padding:0 12px !important;
    margin-left:6px !important;
    font-size:11.5px !important;
  }
}
@media(max-width:980px){
  .header{
    inset:10px 0 auto !important;
  }
  .nav{
    width:calc(100% - 24px) !important;
    min-height:58px !important;
    padding:8px 12px 8px 16px !important;
    border-radius:22px !important;
    align-items:center !important;
  }
  .nav::before{
    border-radius:21px !important;
  }
  .brand-logo{
    width:104px !important;
    max-height:42px !important;
  }
  .nav-links{
    display:none;
    left:0 !important;
    right:0 !important;
    top:66px !important;
    padding:10px !important;
    border-radius:20px !important;
    background:rgba(255,255,255,.96) !important;
    -webkit-backdrop-filter:blur(16px) !important;
    backdrop-filter:blur(16px) !important;
    border:1px solid rgba(255,255,255,.82) !important;
    gap:3px !important;
  }
  .nav-links.open{
    display:flex !important;
  }
  .nav-links a:not(.nav-cta){
    width:100% !important;
    padding:12px 14px !important;
    border-radius:14px !important;
    box-shadow:none !important;
  }
  .nav-links a:not(.nav-cta).active{
    background:rgba(29,110,175,.09) !important;
    border-radius:14px !important;
    box-shadow:none !important;
  }
  .nav-cta{
    width:100% !important;
    min-height:46px !important;
    margin:8px 0 0 !important;
    padding:0 16px !important;
    font-size:13px !important;
  }
  .hero-inner,.page-hero-inner{
    padding-top:116px !important;
  }
}
@media(max-width:560px){
  .header{
    inset:8px 0 auto !important;
  }
  .nav{
    width:calc(100% - 16px) !important;
    min-height:56px !important;
    padding:7px 10px 7px 14px !important;
    border-radius:20px !important;
  }
  .nav::before{
    border-radius:19px !important;
  }
  .brand-logo{
    width:98px !important;
    max-height:40px !important;
  }
  .menu{
    width:38px !important;
    height:38px !important;
  }
  .nav-links{
    top:62px !important;
    left:0 !important;
    right:0 !important;
  }
}
