/* shared-page.css — used by secondary pages (pricing/features/cases/faq/aio/contact) */
*{box-sizing:border-box}html{scrollbar-gutter:stable}html,body{margin:0;padding:0}
.skip-link{position:absolute;top:-40px;left:8px;padding:8px 14px;background:#0f172a;color:#fff;text-decoration:none;font-weight:700;font-size:13px;border-radius:0 0 8px 8px;z-index:100}
.skip-link:focus{top:0;outline:2px solid #1e88e5;outline-offset:2px}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN','Hiragino Sans','Yu Gothic',YuGothic,sans-serif;color:#1e293b;background:#fff;font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;line-height:1.7;letter-spacing:.02em;line-break:strict;word-break:normal;overflow-wrap:anywhere;font-kerning:normal}
h1,h2,h3,h4{margin:0;line-height:1.4;letter-spacing:0;font-feature-settings:"palt" 1,"kern" 1;text-wrap:balance;word-break:keep-all;overflow-wrap:break-word;line-break:strict}
p,.lead,li{text-wrap:pretty}
.pc-br{display:inline}
.sp-br{display:none}
@supports (word-break:auto-phrase){
  h1,h2,h3,h4,p,li{word-break:auto-phrase}
}
a{color:inherit}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid #e2e8f0}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 32px;height:64px;display:flex;align-items:center;gap:32px}
.logo{display:flex;align-items:center;gap:8px;text-decoration:none;font-weight:800;font-size:16px;font-family:'Inter','Noto Sans JP',sans-serif}
.logo .b{color:#1565c0}.logo .o{color:#c2410c}
.nav ul{list-style:none;margin:0;padding:0;display:flex;gap:4px}
.nav a.link{padding:8px 14px;font-size:14px;color:#475569;text-decoration:none;font-weight:500;border-radius:8px}
.nav a.link:hover{color:#0f172a}
.nav a.link[aria-current=page]{color:#0f172a;background:#f1f5f9}
.nav .cta{margin-left:auto;display:flex;gap:10px;align-items:center}
.btn-primary{padding:10px 18px;border-radius:10px;background:#0f172a;color:#fff;text-decoration:none;font-size:13px;font-weight:700}
.btn-outline{padding:10px 18px;border-radius:10px;border:1px solid #e2e8f0;color:#0f172a;text-decoration:none;font-size:13px;font-weight:600}
.crumb{font-size:12px;color:#64748b;padding:24px 0 0}.crumb a{color:#64748b;text-decoration:none}.crumb a:hover{color:#0f172a}
.eyebrow{display:block;font-family:'Inter',sans-serif;font-size:12px;font-weight:700;letter-spacing:.24em;color:#1565c0;text-transform:uppercase;margin:0 0 16px}
.sec-label{display:block;font-family:'Inter',sans-serif;font-size:11px;font-weight:700;letter-spacing:.24em;color:#1565c0;text-transform:uppercase;margin:0 0 10px}
.sec-label.center{text-align:center}
.hero-page{padding:48px 0 48px;text-align:center;max-width:820px;margin:0 auto}
h1.page{font-family:'Noto Serif JP','Hiragino Mincho ProN','Yu Mincho',serif;font-size:52px;letter-spacing:.01em;line-height:1.45;font-weight:700}
.lead{color:#475569;font-size:16px;margin-top:20px;line-height:1.9}
.section{padding:80px 0}.section.alt{background:#f8fafc;border-top:1px solid #e2e8f0}
.section h2{font-size:32px;font-weight:800;letter-spacing:-.5px;line-height:1.4}
.section h2.center{text-align:center}
.footer{background:#050811;color:rgba(255,255,255,.6);padding:60px 0 32px;margin-top:80px}
.footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:40px}
.footer .cols>*{min-width:0;overflow-wrap:anywhere}
.footer .co{overflow-wrap:anywhere;word-break:normal}
.footer h4{color:#fff;font-size:11px;letter-spacing:1.5px;font-weight:700;margin:0 0 14px}
.footer a{display:block;font-size:13px;padding:6px 0;text-decoration:none;color:#cbd5e1}.footer a:hover{color:#fff;text-decoration:underline}
.footer .co{margin-top:20px;padding:14px 16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:8px}
.footer .co h5{color:rgba(255,255,255,.4);font-size:10px;letter-spacing:1.5px;font-weight:700;margin:0 0 6px}
.footer .co .nm{color:#fff;font-weight:700;font-size:13px;margin-bottom:4px}
.footer .co p{font-size:11px;line-height:1.8;margin:0}
.footer .co a{color:#93c5fd;display:inline}
.footer .bottom{margin-top:40px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;font-size:11px}
.article{max-width:780px;margin:0 auto;font-size:16px;line-height:1.9;color:#1e293b}
.article h2{font-size:28px;margin:48px 0 16px;letter-spacing:-.3px;padding-top:12px;border-top:1px solid #f1f5f9}
.article h3{font-size:20px;margin:32px 0 12px;color:#0f172a}
.article p{margin:0 0 18px}
.article ul,.article ol{padding-left:24px;margin:0 0 20px}.article li{margin-bottom:10px}
.article .callout{background:#eff6ff;border-left:3px solid #1e88e5;padding:18px 22px;border-radius:8px;margin:24px 0;font-size:14px}
.article .callout strong{color:#1565c0}
.article a.inline{color:#1565c0;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.toc{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px 24px;margin:0 0 32px}
.toc h4{font-size:11px;letter-spacing:1.5px;color:#64748b;font-weight:700;margin:0 0 10px}
.toc ol{margin:0;padding-left:20px;font-size:14px;color:#334155}.toc li{margin:4px 0}
.toc a{text-decoration:none;color:#334155}.toc a:hover{color:#1565c0}
.faq-item{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px 24px;margin-bottom:12px}
.faq-item summary{cursor:pointer;font-weight:700;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:15px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:#64748b;font-size:22px;line-height:1}
.faq-item[open] summary::after{content:"−"}
.faq-item p{margin:14px 0 0;color:#475569;font-size:14px;line-height:1.9}
.related{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.related a{display:block;padding:20px 22px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;text-decoration:none;transition:all .2s}
.related a:hover{border-color:#1565c0;box-shadow:0 4px 16px rgba(30,136,229,.1)}
.related .cat{font-size:10px;color:#1565c0;font-weight:700;letter-spacing:1px;margin-bottom:6px}
.related .t{font-size:15px;font-weight:700;color:#0f172a;margin-bottom:4px;line-height:1.4}
.related .d{font-size:12px;color:#64748b;line-height:1.6}
/* Japanese LP accents */
.sec-label .num,.sec-label .slash{color:#475569;font-weight:500}
.sec-label .num{margin-right:8px}
.sec-label .slash{margin-right:8px}
.problem-list{list-style:none;padding:0;margin:40px auto 0;max-width:720px;display:grid;gap:14px}
.problem-list li{display:flex;gap:14px;align-items:flex-start;padding:18px 22px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;font-size:15px;color:#334155;line-height:1.7}
.problem-list li .x{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:#fee2e2;color:#dc2626;font-weight:800;display:flex;align-items:center;justify-content:center;font-size:13px;margin-top:1px}
.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.promise-grid .it{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:28px 24px;position:relative}
.promise-grid .it .n{font-family:'Inter',sans-serif;font-size:48px;font-weight:800;color:#dbeafe;letter-spacing:-.02em;line-height:1;position:absolute;top:18px;right:20px}
.promise-grid .it h3{font-size:17px;font-weight:700;margin:0 0 10px;color:#0f172a;letter-spacing:-.01em;line-height:1.5}
.promise-grid .it p{font-size:13px;color:#475569;line-height:1.9;margin:0}
@media(max-width:900px){.promise-grid{grid-template-columns:1fr}}
.final-cta{background:linear-gradient(135deg,#1e88e5,#6366f1);color:#fff;padding:80px 32px;text-align:center;border-radius:0}
.final-cta h2{font-size:36px;font-weight:800;letter-spacing:-.5px;line-height:1.4;margin-bottom:14px}
.final-cta p{font-size:15px;color:rgba(255,255,255,.85);margin:0 0 28px}
.final-cta a{display:inline-block;background:#fff;color:#1565c0;padding:14px 28px;border-radius:10px;text-decoration:none;font-weight:700;font-size:15px}

/* ── Mobile Nav Hamburger (button + JS toggle, a11y compliant 2026-04-26) ── */
.nav-hamburger{display:none;background:transparent;border:0;width:44px;height:44px;cursor:pointer;padding:10px;align-items:center;justify-content:center;border-radius:8px;color:#0f172a}
.nav-hamburger:hover{background:#f1f5f9}
.nav-hamburger:focus-visible{outline:2px solid #1e88e5;outline-offset:2px}
.nav-hamburger .bars,.nav-hamburger .bars::before,.nav-hamburger .bars::after{content:"";display:block;width:22px;height:2px;background:#0f172a;border-radius:2px;transition:transform .25s ease,opacity .2s ease,top .25s ease}
.nav-hamburger .bars{position:relative}
.nav-hamburger .bars::before{position:absolute;top:-7px;left:0}
.nav-hamburger .bars::after{position:absolute;top:7px;left:0}
.nav.is-open .nav-hamburger .bars{background:transparent}
.nav.is-open .nav-hamburger .bars::before{top:0;transform:rotate(45deg)}
.nav.is-open .nav-hamburger .bars::after{top:0;transform:rotate(-45deg)}

/* ── Global responsive refinements ── */
.hero-page{padding:40px 0 40px}
.hero-page .lead{max-width:640px;margin-left:auto;margin-right:auto}
input,select,textarea,button{font-family:inherit}
input[type=text],input[type=email],input[type=tel],input[type=url],select,textarea{font-size:16px}
.form input,.form select,.form textarea{width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:8px;background:#fff;min-height:44px;line-height:1.5}
.form textarea{min-height:120px;resize:vertical}
.form label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.section table,.article table,.compare{min-width:100%}
.section .table-scroll,.article .table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
img{max-width:100%;height:auto}

/* ── Tablet (≤1024px) ── */
@media (max-width:1024px){
  .wrap{padding:0 24px}
  .nav-inner{padding:0 24px;gap:20px}
  .section{padding:64px 0}
  .section h2{font-size:28px}
  h1.page{font-size:clamp(32px,5vw,46px);line-height:1.4}
  .related{grid-template-columns:1fr 1fr}
  .promise-grid{grid-template-columns:1fr 1fr}
  .footer .cols{grid-template-columns:1.2fr 1fr 1fr 1fr}
}

/* ── Narrow tablet / large phone (≤768px) ── */
@media (max-width:768px){
  .nav-hamburger{display:flex}
  .nav-inner{height:60px;padding:0 16px;gap:12px}
  .nav-inner>ul{position:fixed;top:60px;left:0;right:0;max-height:calc(100vh - 60px);overflow-y:auto;flex-direction:column;background:#fff;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:10px 16px 20px;gap:2px;transform:translateY(-8px);opacity:0;pointer-events:none;visibility:hidden;transition:opacity .2s ease,transform .2s ease}
  .nav.is-open .nav-inner>ul{transform:translateY(0);opacity:1;pointer-events:auto;visibility:visible;box-shadow:0 20px 40px rgba(15,23,42,.12)}
  .nav-inner>ul>li{width:100%}
  .nav-inner>ul>li>a.link{display:flex;align-items:center;min-height:48px;padding:12px 14px;font-size:15px;border-radius:8px}
  .nav-inner>ul>li>a.link[aria-current=page]{background:#eff6ff;color:#1e40af}
  .nav .cta{gap:8px;margin-left:0}
  .nav .cta .btn-outline{display:none}
  .nav .cta .btn-primary{padding:10px 12px;font-size:0;line-height:1;min-width:92px;text-align:center}
  .nav .cta .btn-primary::before{content:"14日無料";font-size:12px;font-weight:800;letter-spacing:0}
  .crumb{padding:16px 0 0;font-size:12px}
  .wrap{padding:0 16px}
  .section{padding:48px 0}
  .section h2{font-size:clamp(22px,4.2vw,28px);line-height:1.45}
  h1.page{font-size:clamp(26px,5.6vw,36px);line-height:1.4}
  .hero-page{padding:28px 0 32px}
  .lead{font-size:15px;line-height:1.85;margin-top:16px}
  .promise-grid{grid-template-columns:1fr;gap:14px;margin-top:28px}
  .promise-grid .it{padding:22px 20px}
  .problem-list{margin-top:28px}
  .problem-list li{padding:16px 18px;font-size:14px}
  .related{grid-template-columns:1fr;gap:12px;margin-top:24px}
  .related a{padding:16px 18px}
  .footer{padding:48px 0 24px;margin-top:48px}
  .footer .cols{grid-template-columns:1fr;gap:24px}
  .footer .cols>div:first-child{grid-column:1/-1}
  .footer h4{margin-bottom:8px}
  .footer a{padding:9px 0;font-size:14px}
  .footer .bottom{flex-direction:column;gap:10px;text-align:center;align-items:center}
  .final-cta{padding:56px 20px}
  .final-cta h2{font-size:clamp(22px,4.4vw,28px)}
  .final-cta p{font-size:14px}
  .final-cta a{padding:13px 24px;font-size:14px}
  .toc{padding:16px 18px}
  .article{font-size:15px;line-height:1.9}
  .article h2{font-size:22px;margin:40px 0 14px}
  .article h3{font-size:18px;margin:28px 0 10px}
  .faq-item{padding:16px 18px}
  .faq-item summary{font-size:14px}
  .faq-item p{font-size:13px}
  .pc-br{display:none !important}
  .sp-br{display:inline !important}
  main h1.page br,
  main .lead br,
  main .sect-title br,
  main .sect-lead br,
  main h2 br,
  main h3 br,
  main h4 br,
  main .metric-card .label br{
    display:none;
  }
}

/* ── Phones (≤480px) ── */
@media (max-width:480px){
  .nav-inner{padding:0 12px}
  .wrap{padding:0 14px}
  .section{padding:40px 0}
  .section h2{font-size:22px;line-height:1.45}
  h1.page{font-size:clamp(24px,6vw,30px)}
  .hero-page{padding:24px 0 28px}
  .lead{font-size:14px}
  .eyebrow,.sec-label{font-size:10px;letter-spacing:.18em;margin-bottom:12px}
  .footer{padding:40px 0 20px;margin-top:36px}
  .footer .cols{grid-template-columns:1fr;gap:24px}
  .final-cta{padding:44px 16px}
  .final-cta h2{font-size:22px;line-height:1.45}
  .article{font-size:14.5px}
  .article h2{font-size:20px}
  .article h3{font-size:16.5px}
  .article p{margin:0 0 14px}
  .crumb{font-size:11px}
}

/* ── Extra-narrow (≤360px) ── */
@media (max-width:360px){
  .nav-inner{gap:8px}
  .nav .cta .btn-primary{padding:9px 10px;min-width:82px}
  .nav .cta .btn-primary::before{content:"無料体験";font-size:11.5px}
  .section h2{font-size:20px}
  .logo span{font-size:14px}
}

/* ── Added 2026-04-24: global table-scroll + responsive helpers ── */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%;border-radius:10px}
.table-scroll table{min-width:480px}
@media(max-width:768px){
  main table:not(.table-scroll table){display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
  .wp-tbl,.tbl-sec,.tbl-co,.tbl-sla{font-size:12px}
  .wp-tbl th,.wp-tbl td,.tbl-sec th,.tbl-sec td,.tbl-co th,.tbl-co td,.tbl-sla th,.tbl-sla td{padding:8px 10px}
}
