/* =========================================================
   ホームページ制作＆運用代行 by なるテック
   共通スタイル / デザインシステム
   ========================================================= */

:root{
  --brand:#0676BC;
  --brand-dark:#054F7C;
  --brand-deep:#063a5c;
  --brand-pale:#D6EAF7;
  --brand-soft:#eef6fc;
  --accent:#f5a623;       /* おすすめ・強調バッジ */
  --ink:#16242f;
  --body:#33424f;
  --muted:#67788a;
  --line:#e4eaf0;
  --line-strong:#cfd9e3;
  --bg:#ffffff;
  --bg-soft:#f4f8fb;
  --bg-soft2:#eef3f8;
  /* 幾何学背景＝散らばるコンフェッティ（傾いた小さな四角＋点。intloop調・極薄・上品） */
  --geo:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='480' height='480' viewBox='0 0 480 480'%3E%3Crect x='44' y='70' width='28' height='28' rx='5' transform='rotate(18 58 84)' fill='%230676BC' fill-opacity='0.075'/%3E%3Crect x='392' y='110' width='22' height='22' rx='4' transform='rotate(-14 403 121)' fill='%232e96e6' fill-opacity='0.06'/%3E%3Crect x='70' y='320' width='32' height='32' rx='6' transform='rotate(22 86 336)' fill='%230676BC' fill-opacity='0.055'/%3E%3Crect x='410' y='350' width='20' height='20' rx='4' transform='rotate(10 420 360)' fill='%235aa9dd' fill-opacity='0.075'/%3E%3Crect x='235' y='40' width='15' height='15' rx='3' transform='rotate(-20 242 47)' fill='%230676BC' fill-opacity='0.05'/%3E%3Crect x='318' y='430' width='24' height='24' rx='5' transform='rotate(16 330 442)' fill='%232e96e6' fill-opacity='0.05'/%3E%3Crect x='160' y='210' width='17' height='17' rx='3' transform='rotate(12 168 218)' fill='%23f4b740' fill-opacity='0.05'/%3E%3Ccircle cx='200' cy='380' r='3.5' fill='%230676BC' fill-opacity='0.07'/%3E%3Ccircle cx='442' cy='210' r='3' fill='%230676BC' fill-opacity='0.06'/%3E%3Ccircle cx='30' cy='180' r='3' fill='%232e96e6' fill-opacity='0.06'/%3E%3C/svg%3E");
  --geo-dark:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='480' height='480' viewBox='0 0 480 480'%3E%3Crect x='44' y='70' width='28' height='28' rx='5' transform='rotate(18 58 84)' fill='%23ffffff' fill-opacity='0.06'/%3E%3Crect x='392' y='110' width='22' height='22' rx='4' transform='rotate(-14 403 121)' fill='%23ffffff' fill-opacity='0.05'/%3E%3Crect x='70' y='320' width='32' height='32' rx='6' transform='rotate(22 86 336)' fill='%23ffffff' fill-opacity='0.045'/%3E%3Crect x='410' y='350' width='20' height='20' rx='4' transform='rotate(10 420 360)' fill='%23ffffff' fill-opacity='0.06'/%3E%3Crect x='318' y='430' width='24' height='24' rx='5' transform='rotate(16 330 442)' fill='%23ffffff' fill-opacity='0.045'/%3E%3Ccircle cx='200' cy='380' r='3.5' fill='%23ffffff' fill-opacity='0.06'/%3E%3Ccircle cx='442' cy='210' r='3' fill='%23ffffff' fill-opacity='0.05'/%3E%3C/svg%3E");
  /* ヒーローの同心円（リップル）。極薄 */
  --rings:repeating-radial-gradient(circle at 72% 30%, transparent 0 56px, rgba(6,118,188,.05) 56px 57.5px, transparent 57.5px 113px);
  --ok:#2f9e5e;
  --ng:#c2410c;
  --shadow-s:0 2px 8px rgba(16,40,64,.06);
  --shadow-m:0 8px 28px rgba(16,40,64,.10);
  --shadow-l:0 18px 50px rgba(16,40,64,.16);
  --radius:14px;
  --radius-s:10px;
  --maxw:1120px;
  --maxw-narrow:820px;
  --font:"Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","游ゴシック体",Meiryo,sans-serif;
  --font-head:"Noto Sans JP","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","游ゴシック体",Meiryo,sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--font);
  color:var(--body);
  line-height:1.75;
  background:var(--bg);
  font-size:16px;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ---------- レイアウト ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 24px}
.section{padding:104px 0}
.section--soft{background:var(--bg-soft)}
.section--brand{background:linear-gradient(160deg,var(--brand-dark),var(--brand-deep));color:#fff}
.section--tight{padding:76px 0}

.eyebrow{
  display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.22em;
  color:var(--brand);text-transform:uppercase;margin-bottom:18px;
}
.section--brand .eyebrow{color:#9fd0f0}
.sec-title{
  font-family:var(--font-head);
  font-size:clamp(1.9rem,3.9vw,2.7rem);font-weight:900;line-height:1.4;
  color:var(--ink);letter-spacing:-.01em;
}
.section--brand .sec-title{color:#fff}
.sec-lead{margin-top:22px;color:var(--muted);font-size:1.06rem;line-height:1.9;max-width:720px}
.section--brand .sec-lead{color:#cfe4f4}
.center{text-align:center}
.center .sec-lead,.center.sec-lead{margin-left:auto;margin-right:auto}

/* ---------- ボタン ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-weight:800;font-size:1rem;line-height:1;
  padding:17px 30px;border-radius:12px;border:2px solid transparent;
  cursor:pointer;transition:.18s ease;white-space:nowrap;
}
.btn--primary{background:var(--brand);color:#fff;box-shadow:0 6px 18px rgba(6,118,188,.32)}
.btn--primary:hover{background:#0a83cf;transform:translateY(-2px);box-shadow:0 10px 24px rgba(6,118,188,.4)}
.btn--accent{background:var(--accent);color:#3a2600;box-shadow:0 6px 18px rgba(245,166,35,.34)}
.btn--accent:hover{background:#ffb733;transform:translateY(-2px)}
.btn--ghost{background:#fff;color:var(--brand);border-color:var(--line-strong)}
.btn--ghost:hover{border-color:var(--brand);color:var(--brand-dark)}
.btn--line{background:#06c755;color:#fff}
.btn--line:hover{background:#05b54d;transform:translateY(-2px)}
.btn--lg{padding:18px 36px;font-size:1.06rem}
.btn--block{display:flex;width:100%}
.btn--ghost-white{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost-white:hover{background:rgba(255,255,255,.12);border-color:#fff}
.lang-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:36px;padding:0 12px;border:1px solid var(--line-strong);border-radius:999px;font-size:.8rem;font-weight:800;color:var(--brand-dark);letter-spacing:.04em;transition:background .2s,border-color .2s}
.lang-toggle:hover{background:var(--brand-soft);border-color:var(--brand)}
.plans-common{margin-top:22px;display:flex;align-items:center;justify-content:center;gap:9px;text-align:center;font-size:.88rem;font-weight:600;color:var(--body)}
.plans-common::before{content:"";flex:0 0 auto;width:9px;height:9px;border-radius:50%;background:#06c755;box-shadow:0 0 0 4px rgba(6,199,85,.14)}
/* 濃青バンド内のCTAは白ボタンで際立たせる */
.cta-band .btn--primary,.section--brand .btn--primary{background:#fff;color:var(--brand);border-color:#fff;box-shadow:var(--shadow-s)}
.cta-band .btn--primary:hover,.section--brand .btn--primary:hover{background:#eaf4fb;color:var(--brand-dark);transform:translateY(-2px);box-shadow:var(--shadow-m)}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:66px;gap:20px}
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand .logo-mark{width:32px;height:32px;flex:none}
.brand-txt{display:flex;flex-direction:column;line-height:1.18}
.brand-txt b{font-size:1.02rem;font-weight:800;color:var(--ink);letter-spacing:.02em}
.brand-txt small{font-size:.67rem;font-weight:600;color:var(--muted);letter-spacing:.01em}
.gnav{display:flex;align-items:center;gap:21px;flex:none}
.gnav a{font-size:.9rem;font-weight:600;color:var(--body);white-space:nowrap;transition:.15s}
.gnav a:hover{color:var(--brand)}
.header-cta{display:flex;align-items:center;gap:12px;flex:none}
.header-cta .btn{padding:11px 22px;font-size:.9rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}

/* ---------- 実績ストリップ ---------- */
.worksstrip{background:#fff;padding:36px 0 44px}
.ws-label{text-align:center;font-size:.8rem;font-weight:800;letter-spacing:.12em;color:var(--muted);margin-bottom:22px}
.ws-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.ws-item{display:block;transition:transform .4s cubic-bezier(.16,1,.3,1)}
.ws-item:hover{transform:translateY(-4px)}
.ws-shot{position:relative;aspect-ratio:16/10;overflow:hidden;border-radius:11px;border:1px solid var(--line);box-shadow:var(--shadow-s);background:#fff}
.ws-shot::before{content:"";position:absolute;top:0;left:0;right:0;height:18px;background:#eef2f6;z-index:2;border-bottom:1px solid var(--line)}
.ws-shot::after{content:"";position:absolute;top:6px;left:9px;width:5px;height:5px;border-radius:50%;background:#c4cfda;box-shadow:9px 0 0 #c4cfda,18px 0 0 #c4cfda;z-index:3}
.ws-shot img{position:absolute;top:18px;left:0;width:100%;height:calc(100% - 18px);object-fit:cover;object-position:top center;display:block}
.ws-item span{display:block;margin-top:11px;font-size:.83rem;color:var(--body);font-weight:700;text-align:center}

/* ---------- 信頼バンド（数値） ---------- */
.trustband{background:#fff;border-bottom:1px solid var(--line);padding:30px 0}
.tb-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.tb-item{text-align:center;padding:6px 18px;border-left:1px solid var(--line)}
.tb-item:first-child{border-left:0}
.tb-num{font-size:2.05rem;font-weight:900;color:var(--brand);line-height:1;letter-spacing:-.01em}
.tb-num small{font-size:.9rem;font-weight:800;margin-left:2px;letter-spacing:0}
.tb-lbl{font-size:.82rem;color:var(--muted);margin-top:9px;font-weight:600}

/* ---------- フッター ---------- */
.site-footer{background:var(--brand-deep);color:#cfe0ee;padding:64px 0 28px;font-size:.92rem}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer-brand .logo-mark{width:38px;height:38px;margin-bottom:14px}
.footer-brand .fb-name{color:#fff;font-weight:800;font-size:1.05rem;margin-bottom:6px;word-break:keep-all;line-height:1.55}
.footer-brand p{color:#9fbdd6;font-size:.85rem;line-height:1.8}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.08em;margin-bottom:14px;font-weight:700}
.footer-col li{margin-bottom:9px}
.footer-col a{color:#bcd4e6;font-size:.88rem;transition:.15s}
.footer-col a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.13);margin-top:46px;padding-top:22px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:#88a8c2;font-size:.8rem}
.footer-bottom a{color:#88a8c2}
.footer-bottom a:hover{color:#fff}

/* ---------- ファーストビュー ---------- */
.hero{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(102deg,rgba(6,49,81,.975) 0%,rgba(6,51,84,.945) 48%,rgba(8,58,92,.9) 100%),
            url("../img/sec-bg.jpg") center 30%/cover no-repeat;}
.hero::before{content:"";position:absolute;inset:0;
  background:radial-gradient(1040px 520px at 85% -12%,rgba(22,150,224,.24),transparent 60%);pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.18fr .82fr;gap:54px;align-items:center;
  padding:104px 0 116px}
.hero-tag{display:inline-flex;align-items:center;position:relative;padding-left:15px;font-size:.95rem;font-weight:700;
  color:#bcdcf3;margin-bottom:22px;letter-spacing:.03em}
.hero-tag::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:16px;background:#6cc6f5;border-radius:2px}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:7px 14px;font-size:.78rem;font-weight:600}
.hero h1{font-family:var(--font-head);font-size:clamp(2.05rem,3.9vw,2.85rem);line-height:1.44;font-weight:900;letter-spacing:-.01em;
  text-shadow:0 1px 14px rgba(0,18,36,.22)}
.hero h1 .hl{color:#fff;background:linear-gradient(transparent 58%,rgba(96,201,255,.55) 58%);padding:0 .05em}
.hero-sub{margin-top:24px;font-size:1.02rem;line-height:1.95;color:#e6f0f9;max-width:484px;letter-spacing:.01em}
.hero-price{margin-top:26px;display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.hero-price .pnum{font-size:2.5rem;font-weight:800;color:#fff;line-height:1}
.hero-price .pnum small{font-size:1rem;font-weight:700}
.hero-price .ptag{background:var(--accent);color:#3a2600;font-weight:800;font-size:.82rem;padding:7px 14px;border-radius:8px}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-note{margin-top:18px;font-size:.82rem;color:#9fc3df}
/* FV右：デザインサンプル ショーケース */
.hero-works{max-width:460px;margin-left:auto}
.hw-label{display:inline-block;font-size:.72rem;font-weight:800;letter-spacing:.14em;color:#9fd0f0;margin-bottom:14px}
.hw-main{display:block;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 30px 70px rgba(0,10,25,.42);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.hw-main:hover{transform:translateY(-4px);box-shadow:0 38px 82px rgba(0,10,25,.5)}
.hw-shot{position:relative;aspect-ratio:16/10;overflow:hidden;background:#eef2f6}
.hw-shot::before{content:"";position:absolute;top:0;left:0;right:0;height:26px;background:#eef2f6;z-index:2;border-bottom:1px solid #dfe6ee}
.hw-shot::after{content:"";position:absolute;top:9px;left:13px;width:7px;height:7px;border-radius:50%;background:#c4cfda;box-shadow:13px 0 0 #c4cfda,26px 0 0 #c4cfda;z-index:3}
.hw-shot img{position:absolute;top:26px;left:0;width:100%;height:calc(100% - 26px);object-fit:cover;object-position:top center;display:block}
.hw-cap{display:flex;align-items:baseline;gap:10px;padding:14px 18px;background:#fff}
.hw-cap strong{font-size:1.04rem;font-weight:800;color:var(--ink)}
.hw-cap span{font-size:.78rem;color:var(--muted)}
.hw-note{margin-top:16px;font-size:.82rem;color:#cfe4f4;line-height:1.7}
/* FV：制作実績ショーケース（中の device-laptop に統一） */
.hero-showcase{max-width:510px;margin-left:auto}
.hero-device{display:block;margin-top:4px;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.hero-device:hover{transform:translateY(-5px)}
.hero-device .dl-screen{box-shadow:0 34px 80px rgba(0,8,22,.55)}
.hero-cap{display:flex;align-items:baseline;gap:10px;margin-top:20px}
.hero-cap strong{color:#fff;font-size:1.06rem;font-weight:800}
.hero-cap span{color:#9fd0f0;font-size:.8rem;font-weight:600}

/* セキュリティ認証バッジ */
.cert-row{display:flex;justify-content:center;margin-top:48px}
.cert{display:flex;align-items:center;gap:20px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 28px;max-width:700px;box-shadow:var(--shadow-s)}
.cert-mark{flex:none;width:56px;height:56px;border-radius:13px;background:linear-gradient(140deg,#15a0e6 0%,#0561a0 100%);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 22px rgba(6,118,188,.32)}
.cert-mark svg{width:30px;height:30px}
.cert-tx{font-size:.9rem;color:var(--muted);line-height:1.65}
.cert-tx strong{display:block;color:var(--ink);font-size:1.04rem;font-weight:800;margin-bottom:3px}

.hero-visual{position:relative}
.hero-card{background:#fff;border-radius:20px;box-shadow:0 28px 66px rgba(6,26,48,.32);padding:30px 28px 28px;color:var(--ink)}
.hero-card .hc-head{display:flex;align-items:baseline;justify-content:space-between;
  margin-bottom:4px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.hero-card .hc-head .t{font-size:1.1rem;font-weight:800;letter-spacing:.02em}
.hero-card .hc-head .s{font-size:.71rem;color:var(--muted);font-weight:600}
.hero-card .mini-plan{display:flex;justify-content:space-between;align-items:center;padding:16px 4px}
.hero-card .mini-plan + .mini-plan{border-top:1px solid #eef2f6}
.hero-card .mini-plan.reco{border-top:0}
.hero-card .mp-name{font-weight:800;font-size:1rem;color:var(--ink);line-height:1.3}
.hero-card .mp-name .ds{display:block;font-size:.73rem;color:var(--muted);font-weight:500;margin-top:3px}
.hero-card .mp-name .rb{display:inline-block;background:var(--accent);color:#3a2600;font-size:.63rem;
  font-weight:800;padding:2px 9px;border-radius:999px;margin-left:8px;vertical-align:1.5px;letter-spacing:.02em}
.hero-card .mp-price{font-weight:800;color:var(--brand);font-size:1.42rem;letter-spacing:-.01em;white-space:nowrap}
.hero-card .mp-price small{font-size:.66rem;color:var(--muted);font-weight:600;margin-left:1px}
.hero-card .reco{background:var(--brand-soft);border:1.5px solid var(--brand-pale);border-radius:13px;
  padding:14px;margin:10px -8px 0}
.hero-card .reco .mp-price{color:var(--brand-dark)}

/* ---------- 汎用カード ---------- */
.cards{display:grid;gap:22px}
.cards-2{grid-template-columns:repeat(2,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-4{grid-template-columns:repeat(4,1fr)}
.card{position:relative;background:#fff;border:1px solid #edf1f6;border-radius:18px;padding:32px 30px;
  box-shadow:0 2px 8px rgba(16,40,64,.05);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.card:hover{box-shadow:0 18px 44px rgba(16,40,64,.12);transform:translateY(-4px)}
.card h3{font-size:1.12rem;font-weight:800;color:var(--ink);margin-bottom:11px}
.card p{font-size:.93rem;color:var(--muted)}
.card .inc{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.card .inc li{position:relative;padding-left:23px;font-size:.9rem;color:var(--body);line-height:1.72}
.card .inc li::before{content:"✓";position:absolute;left:0;top:0;color:var(--brand);font-weight:900}
.card .ic{width:58px;height:58px;border-radius:17px;color:#fff;
  background:linear-gradient(140deg,#15a0e6 0%,#0561a0 100%);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  box-shadow:0 10px 22px rgba(6,118,188,.34);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.card .ic svg{width:28px;height:28px;stroke-width:2}
.card:hover .ic{transform:translateY(-3px)}

/* 課題（アイコン図解カード） */
.issue-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.issue{position:relative;background:#fff;border:1px solid #edf1f6;border-radius:20px;padding:36px 32px;
  box-shadow:0 2px 8px rgba(16,40,64,.05);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.issue-no{position:absolute;top:24px;right:28px;font-size:2.5rem;font-weight:800;line-height:1;
  color:#e9eff6;letter-spacing:.01em;font-style:italic}
.issue:hover{box-shadow:0 18px 44px rgba(16,40,64,.12);transform:translateY(-4px)}
.issue-ic{width:58px;height:58px;border-radius:17px;color:#fff;
  background:linear-gradient(140deg,#15a0e6 0%,#0561a0 100%);
  display:flex;align-items:center;justify-content:center;margin-bottom:22px;
  box-shadow:0 10px 22px rgba(6,118,188,.34);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.issue-ic svg{width:28px;height:28px;stroke-width:2}
.issue:hover .issue-ic{transform:translateY(-3px)}
.issue p{font-size:1rem;color:var(--ink);font-weight:700;line-height:1.65}

/* 比較表 */
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:8px 2px 10px}
table.cmp{width:100%;border-collapse:separate;border-spacing:0;min-width:880px;font-size:.92rem}
/* セルは横の薄lineのみ・縦罫線なし */
table.cmp th,table.cmp td{padding:18px 22px;text-align:left;border-bottom:1px solid var(--line);font-size:.94rem;vertical-align:middle}
/* ヘッダー：白地・他社列はmuted・下に濃line（軽量化） */
table.cmp thead th{background:#fff;color:var(--muted);font-weight:700;font-size:.92rem;border-bottom:2px solid var(--ink);vertical-align:middle;line-height:1.4;text-align:center}
table.cmp thead th:first-child{text-align:left}
/* 左の比較項目列を立てる */
table.cmp tbody th{font-weight:700;color:var(--ink);width:20%;background:#fff}
table.cmp tbody td{color:var(--body)}
/* 行ホバーで横の視線ガイド */
table.cmp tbody tr:hover td,table.cmp tbody tr:hover th{background:#f7fafd}
/* カテゴリ帯 */
table.cmp tr.cmp-cat th,table.cmp tr.cmp-cat:hover th{background:var(--brand-soft);color:var(--brand-dark);font-size:.74rem;font-weight:800;letter-spacing:.12em;padding:11px 22px}
/* ★ 自社列＝1本の柱カードとして浮かせる（淡青背景＋濃青枠＋濃青ヘッダー） */
table.cmp .col-naru{background:var(--brand-soft);color:var(--brand-dark);font-weight:700;border-left:2px solid var(--brand);border-right:2px solid var(--brand)}
table.cmp thead th.col-naru{background:var(--brand);color:#fff;font-size:1.02rem;font-weight:800;border-top:2px solid var(--brand);border-top-left-radius:13px;border-top-right-radius:13px}
table.cmp tbody tr:last-child td.col-naru,table.cmp tbody tr:last-child th.col-naru{border-bottom:2px solid var(--brand);border-bottom-left-radius:13px;border-bottom-right-radius:13px}
table.cmp tbody tr:hover td.col-naru{background:var(--brand-pale)}
/* 記号 */
.cmark{display:inline-flex;width:19px;height:19px;border-radius:50%;background:var(--brand);color:#fff;
  font-size:.68rem;align-items:center;justify-content:center;margin-right:8px;font-weight:800;vertical-align:-3px}
.cell-yes{color:var(--brand);font-weight:800}
.cell-no{color:#aab6c2}

/* 料金プラン */
.plans{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:stretch}
.plan{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:28px 22px;
  display:flex;flex-direction:column;box-shadow:var(--shadow-s)}
.plan--reco{border:2px solid var(--brand);box-shadow:var(--shadow-l);transform:translateY(-8px)}
.plan-flag{position:absolute;top:-15px;left:50%;transform:translateX(-50%);background:var(--accent);color:#3a2600;
  font-weight:800;font-size:.78rem;padding:7px 20px;border-radius:999px;white-space:nowrap;box-shadow:var(--shadow-s)}
.plan-name{font-size:1.16rem;font-weight:800;color:var(--ink)}
.plan-tagline{font-size:.85rem;color:var(--muted);margin-top:4px;min-height:2.6em}
.plan-price{margin:16px 0 6px;display:flex;align-items:baseline;gap:5px;flex-wrap:nowrap}
.plan-price .num{font-size:2.95rem;font-weight:900;color:var(--brand);letter-spacing:-.02em;line-height:1}
.plan-price .unit{font-size:.82rem;color:var(--muted);font-weight:800;white-space:nowrap}
.plan-price .unit small{font-size:.82em;font-weight:600;opacity:.85;margin-left:1px}
.plan-init{font-size:.86rem;color:var(--body);font-weight:600;margin-bottom:20px}
.plan-init .free{color:var(--ng);font-weight:800}
.plan-init .strike{color:var(--muted);text-decoration:line-through;font-weight:500;margin-right:6px}
.plan ul.feat{margin:6px 0 24px;border-top:1px solid var(--line);padding-top:18px;flex:1}
.plan ul.feat li{display:flex;gap:9px;align-items:flex-start;font-size:.9rem;padding:6px 0;color:var(--body)}
.plan ul.feat li .fi{flex:none;color:var(--brand);font-weight:800;margin-top:1px}
.plan ul.feat li.off{color:var(--line-strong)}
.plan ul.feat li.off .fi{color:var(--line-strong)}
.plan .btn{margin-top:auto}

/* 料金：パッケージ・タブ */
.pkg-tabwrap{display:flex;justify-content:center;margin-bottom:14px}
.pkg-tabs{display:inline-flex;gap:4px;background:#e7eef5;border-radius:999px;padding:5px}
.pkg-tab{border:0;background:none;cursor:pointer;font-family:inherit;font-weight:800;font-size:.96rem;
  color:var(--muted);padding:12px 28px;border-radius:999px;transition:.2s;white-space:nowrap;
  display:inline-flex;align-items:center;gap:8px}
.pkg-tab:hover{color:var(--brand-dark)}
.pkg-tab.is-active{background:var(--brand);color:#fff;box-shadow:0 6px 16px rgba(6,118,188,.3)}
.pkg-reco{font-size:.64rem;background:var(--accent);color:#3a2600;padding:2px 8px;border-radius:999px;font-weight:800;letter-spacing:.02em}
.pkg-tab.is-active .pkg-reco{background:#fff;color:var(--brand-dark)}
.pkg-desc{text-align:center;color:var(--muted);font-size:.94rem;line-height:1.8;max-width:660px;margin:0 auto 34px}
.pkg-step{display:flex;align-items:center;justify-content:center;gap:10px;font-size:1.02rem;font-weight:800;color:var(--brand-dark);margin:0 0 16px}
.pkg-step-no{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:.84rem;flex:none}
.pkg-step em{font-style:normal;color:var(--muted);font-weight:600;font-size:.86rem}

/* STEP / 流れ（縦タイムライン＋カード） */
.steps{position:relative;display:flex;flex-direction:column;gap:0;max-width:780px;margin:0 auto}
.step{position:relative;display:grid;grid-template-columns:56px 1fr;gap:24px;padding-bottom:24px;align-items:flex-start}
.step:not(:last-child)::before{content:"";position:absolute;left:27px;top:58px;bottom:-2px;width:2px;background:var(--brand-pale)}
.step-no{position:relative;z-index:1;width:56px;height:56px;border-radius:50%;background:var(--brand);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.2rem;box-shadow:0 5px 14px rgba(6,118,188,.32)}
.step-body{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 24px;box-shadow:var(--shadow-s);transition:.18s}
.step-body:hover{box-shadow:var(--shadow-m);border-color:var(--brand-pale)}
.step-body h3{font-size:1.08rem;font-weight:800;color:var(--ink);margin-bottom:6px}
.step-body p{font-size:.94rem;color:var(--muted);line-height:1.8}

/* FAQ */
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq-q{display:flex;gap:14px;align-items:flex-start;width:100%;text-align:left;background:none;border:0;
  padding:20px 22px;cursor:pointer;font-weight:700;color:var(--ink);font-size:1rem;font-family:inherit}
.faq-q .qmark{flex:none;color:var(--brand);font-weight:800}
.faq-q .arr{margin-left:auto;flex:none;transition:.2s;color:var(--muted)}
.faq-q[aria-expanded="true"] .arr{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s ease;color:var(--body)}
.faq-a-inner{padding:0 22px 22px 50px;font-size:.94rem;color:var(--muted)}
.faq-cat{font-size:1.15rem;font-weight:800;color:var(--brand-dark);margin:34px 0 16px}

/* CTAバンド */
.cta-band{position:relative;overflow:hidden;color:#fff;border-radius:24px;
  background:linear-gradient(130deg,rgba(6,118,188,.93),rgba(5,79,124,.95)),url("../img/band-bg.jpg") center 35%/cover no-repeat;
  padding:72px 52px;text-align:center;box-shadow:var(--shadow-l)}
.cta-band h2{font-family:var(--font-head);font-size:clamp(1.8rem,3.6vw,2.6rem);font-weight:900;line-height:1.36;letter-spacing:-.01em}
.cta-band p{margin-top:16px;color:#e3eff9;font-size:1.04rem}
.cta-band .row{margin-top:32px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* セキュリティ診断バンド（中央寄せ） */
.sec-check{position:relative;overflow:hidden;background:linear-gradient(135deg,#063a5c,#0a4f7c);color:#fff;
  border-radius:24px;padding:66px 48px;text-align:center;box-shadow:var(--shadow-m)}
.sec-check .eyebrow{color:#9fd0f0}
.sec-check h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:800;line-height:1.42}
.sec-check p{margin:16px auto 0;color:#cfe4f4;font-size:1.02rem;max-width:600px;line-height:1.85}
.sec-form{max-width:600px;margin:32px auto 0;display:flex;gap:12px}
.sec-form input{flex:1;padding:16px 18px;border-radius:12px;border:1px solid rgba(255,255,255,.3);
  background:rgba(255,255,255,.97);font-size:1rem;font-family:inherit;color:var(--ink)}
.sec-form input:focus{outline:none;box-shadow:0 0 0 3px rgba(127,208,255,.45)}
.sec-form .btn{flex:none;white-space:nowrap}
.sc-note{margin-top:18px;font-size:.8rem;color:#9fc3df}

/* バッジ・チップ */
.chips{display:flex;flex-wrap:wrap;gap:9px}
.chip{background:var(--brand-soft);color:var(--brand-dark);border:1px solid var(--brand-pale);
  border-radius:999px;padding:7px 15px;font-size:.82rem;font-weight:700}

/* ピックアップ事例（デバイスモック：ノートPC＋スマホ） */
.pickup{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.pickup-device{position:relative;padding:0 26px 26px 0}
.device-laptop{position:relative;width:100%;max-width:560px}
.dl-screen{background:#141414;border-radius:14px 14px 0 0;padding:12px 12px 0;box-shadow:0 24px 56px rgba(8,26,48,.24)}
.dl-screen img{width:100%;border-radius:4px 4px 0 0;display:block;aspect-ratio:16/10;object-fit:cover;object-position:top center}
.dl-base{height:15px;background:linear-gradient(#d3d9df,#aeb6bf);border-radius:0 0 5px 5px;margin:0 -14px;position:relative}
.dl-base::after{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:96px;height:6px;background:#9aa3ad;border-radius:0 0 8px 8px}
.device-phone{position:absolute;right:0;bottom:0;width:128px;background:#141414;border-radius:20px;padding:7px;box-shadow:0 18px 42px rgba(8,26,48,.32)}
.device-phone img{width:100%;border-radius:13px;display:block;aspect-ratio:9/19;object-fit:cover;object-position:top center}
.pickup-text .sec-lead{margin-bottom:26px}
.pickup--rev .pickup-device{order:2;padding:0 0 26px 26px}
.pickup--rev .pickup-text{order:1}
.pickup--rev .device-phone{right:auto;left:0}

/* 制作事例（ブラウザモック風カード） */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.work{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-s);transition:transform .5s cubic-bezier(.16,1,.3,1),box-shadow .5s cubic-bezier(.16,1,.3,1)}
.work:hover{box-shadow:0 18px 44px rgba(16,40,64,.12);transform:translateY(-4px);border-color:var(--brand-pale)}
.work-shot{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft)}
.work-shot::before{content:"";position:absolute;top:0;left:0;right:0;height:27px;background:#eef2f6;
  z-index:2;border-bottom:1px solid var(--line)}
.work-shot::after{content:"";position:absolute;top:9.5px;left:14px;width:8px;height:8px;border-radius:50%;
  background:#c4cfda;box-shadow:14px 0 0 #c4cfda,28px 0 0 #c4cfda;z-index:3}
.work-shot img{position:absolute;top:27px;left:0;width:100%;height:calc(100% - 27px);
  object-fit:cover;object-position:top center;display:block;transition:transform .7s cubic-bezier(.16,1,.3,1)}
.work:hover .work-shot img{transform:scale(1.04)}
.work-meta{padding:18px 20px}
.work-cat{display:inline-block;background:var(--brand-soft);color:var(--brand-dark);font-size:.7rem;
  font-weight:700;padding:3px 11px;border-radius:999px;margin-bottom:9px}
.work-meta h3{font-size:1rem;font-weight:800;color:var(--ink);line-height:1.4}

/* SERVICE 本番フロー（作って終わりでない） */
/* SERVICE：横一本タイムライン（左=準備・小／右=運用・大） */
.biz-flow{display:grid;grid-template-columns:.82fr auto 1.74fr;align-items:center;max-width:1040px;margin:0 auto 36px}
/* 左：公開までの準備（淡色・控えめ） */
.bf-prep{background:var(--bg-soft);border:1px solid var(--line);border-radius:16px;padding:24px 24px 22px}
.bf-cap{display:block;font-size:.78rem;font-weight:700;color:var(--muted);letter-spacing:.05em;margin-bottom:18px}
.bf-track{display:flex;flex-direction:column}
.bf-step{display:flex;align-items:center;gap:12px;position:relative;padding-bottom:18px}
.bf-step:last-child{padding-bottom:0}
.bf-step::before{content:"";position:absolute;left:15px;top:30px;bottom:-2px;width:2px;background:var(--line-strong)}
.bf-step:last-child::before{display:none}
.bf-num{flex:none;width:32px;height:32px;border-radius:50%;background:#fff;border:2px solid var(--brand-pale);color:var(--brand);font-weight:800;font-size:.82rem;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}
.bf-step .bf-t{font-weight:700;color:var(--body);font-size:.95rem}
.bf-prepnote{display:block;margin-top:16px;font-size:.72rem;color:var(--muted)}
/* 中央：転換（ここからが本番） */
.bf-turn{display:flex;flex-direction:column;align-items:center;gap:12px;padding:0 20px;color:var(--brand)}
.bf-turn-txt{writing-mode:vertical-rl;font-size:.82rem;font-weight:800;color:var(--brand-dark);letter-spacing:.14em;white-space:nowrap}
.bf-turn-arw{width:32px;height:32px}
/* 右：公開してからの運用（青・主役） */
.bf-main{background:linear-gradient(135deg,var(--brand),var(--brand-dark));color:#fff;border-radius:18px;padding:28px 30px;box-shadow:var(--shadow-m)}
.bf-cap--main{color:#bfe0f5;letter-spacing:.04em;margin-bottom:16px}
.bf-goals{display:flex;flex-direction:column;gap:11px}
.bf-goal{display:flex;align-items:flex-start;gap:14px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:15px 18px}
.bf-cat{flex:none;min-width:46px;text-align:center;font-size:.68rem;font-weight:800;letter-spacing:.05em;color:#dcefff;border:1px solid rgba(255,255,255,.4);border-radius:6px;padding:3px 0;margin-top:2px}
.bf-goal-tx strong{display:block;font-size:1rem;font-weight:800;margin-bottom:3px}
.bf-goal-tx span{font-size:.85rem;color:#cfe4f4;line-height:1.55}
.bf-note{margin-top:18px;font-size:.83rem;color:#cfe4f4}

/* 数値タイル */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.stat{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px;text-align:center;box-shadow:var(--shadow-s)}
.stat .big{font-size:2.3rem;font-weight:800;color:var(--brand);line-height:1}
.stat .lbl{margin-top:8px;font-size:.86rem;color:var(--muted);font-weight:600}

/* リスト（サービス内容など） */
.feature-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.feature-list li{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1px solid var(--line);
  border-radius:10px;padding:16px 18px}
.feature-list .fi{flex:none;width:26px;height:26px;border-radius:7px;background:var(--brand-soft);color:var(--brand);
  display:flex;align-items:center;justify-content:center;font-weight:800;margin-top:1px}
.feature-list strong{display:block;color:var(--ink);font-size:.96rem}
.feature-list span{font-size:.85rem;color:var(--muted)}
.feature-list--3{grid-template-columns:repeat(3,1fr)}
.contact-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:40px;align-items:start}
/* 注意・補足ボックス（料金の前提・別途見積りの注記など） */
.note-box{margin:24px 0 4px;padding:20px 22px;background:var(--brand-soft);border:1px solid var(--brand-pale);
  border-left:4px solid var(--brand);border-radius:12px}
.note-box strong{display:block;color:var(--brand-dark);font-size:.98rem;font-weight:800;margin-bottom:8px}
.note-box p{margin:0;color:var(--body);font-size:.92rem;line-height:1.85}
.note-box p strong{display:inline;font-size:inherit;color:var(--ink);margin:0}

/* ---------- フォーム ---------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:36px;box-shadow:var(--shadow-s)}
.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.88rem;font-weight:700;color:var(--ink);margin-bottom:7px}
.field label .req{color:var(--ng);font-size:.78rem;margin-left:6px;font-weight:700}
.field label .opt{color:var(--muted);font-size:.74rem;margin-left:6px;font-weight:600}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--line-strong);border-radius:10px;
  font-size:.96rem;font-family:inherit;color:var(--ink);background:#fff;transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(6,118,188,.14)}
.field textarea{min-height:120px;resize:vertical}
.field .hint{font-size:.78rem;color:var(--muted);margin-top:6px}
.check-line{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--body)}
.check-line input{width:auto;margin-top:4px;flex:none}
.form-note{font-size:.82rem;color:var(--muted);background:var(--bg-soft);border:1px solid var(--line);
  border-radius:10px;padding:14px 16px;margin-bottom:18px;line-height:1.7}

/* ---------- 御見積書 ---------- */
.est-layout{display:grid;grid-template-columns:1fr;gap:32px}
.plan-select{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.plan-opt{position:relative;cursor:pointer;background:#fff;border:2px solid var(--line);border-radius:14px;
  padding:22px;transition:.15s;display:block}
.plan-opt:hover{border-color:var(--brand-pale)}
.plan-opt input{position:absolute;opacity:0}
.plan-opt .po-name{font-weight:800;color:var(--ink);font-size:1.05rem}
.plan-opt .po-price{color:var(--brand);font-weight:800;font-size:1.4rem;margin-top:8px}
.plan-opt .po-price small{font-size:.72rem;color:var(--muted);font-weight:600}
.plan-opt .po-init{font-size:.82rem;color:var(--muted);margin-top:4px}
.plan-opt .po-check{position:absolute;top:14px;right:14px;width:24px;height:24px;border-radius:50%;
  border:2px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:#fff;font-size:.8rem}
.plan-opt input:checked ~ .po-check{background:var(--brand);border-color:var(--brand)}
.plan-opt:has(input:checked){border-color:var(--brand);box-shadow:0 0 0 3px rgba(6,118,188,.12)}
.plan-opt .po-flag{display:inline-block;background:var(--accent);color:#3a2600;font-size:.7rem;font-weight:800;
  padding:3px 10px;border-radius:6px;margin-top:10px}

/* 見積書プレビュー（印刷対象） */
.quote{background:#fff;border:1px solid var(--line);border-radius:8px;padding:44px;max-width:820px;margin:0 auto;
  box-shadow:var(--shadow-m);color:#1a1a1a;font-size:.9rem;line-height:1.7}
.quote-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;
  border-bottom:3px solid var(--brand);padding-bottom:18px}
.quote-head .q-title{font-size:1.6rem;font-weight:800;letter-spacing:.3em;color:var(--ink)}
.quote-head .q-meta{text-align:right;font-size:.82rem;color:#555}
.quote-head .q-meta .q-no{font-weight:700;color:var(--ink);font-size:.9rem}
.quote-to{font-size:1.15rem;font-weight:700;border-bottom:1px solid #888;padding-bottom:6px;display:inline-block;margin-bottom:8px}
.quote-from{text-align:right;font-size:.82rem;color:#444;margin-bottom:20px;line-height:1.7}
.quote-from .qf-name{font-weight:700;color:var(--ink);font-size:.95rem}
.quote-total-box{background:var(--brand-soft);border:1px solid var(--brand-pale);border-radius:8px;
  padding:16px 22px;display:flex;justify-content:space-between;align-items:center;margin:18px 0}
.quote-total-box .lbl{font-weight:700;color:var(--brand-dark)}
.quote-total-box .amt{font-size:1.7rem;font-weight:800;color:var(--brand-dark)}
table.q-table{width:100%;border-collapse:collapse;margin:6px 0 18px;font-size:.88rem}
table.q-table th,table.q-table td{border:1px solid #d5d5d5;padding:11px 14px}
table.q-table thead th{background:var(--brand-dark);color:#fff;font-weight:700;text-align:center}
table.q-table td.num{text-align:right;font-variant-numeric:tabular-nums}
table.q-table .row-sub td{background:#f7f7f7;font-weight:700}
table.q-table .row-total td{background:var(--brand-soft);font-weight:800;color:var(--brand-dark);font-size:1rem}
.quote-notes{font-size:.76rem;color:#555;line-height:1.7;border-top:1px solid #ddd;padding-top:14px;margin-top:18px}
.quote-notes h5{font-weight:700;color:var(--ink);margin-bottom:6px;font-size:.8rem}
.quote-foot{margin-top:18px;font-size:.78rem;color:#444;border-top:1px solid #ddd;padding-top:12px}

/* ページヘッダー（下層共通） */
.page-hero{position:relative;overflow:hidden;color:#fff;padding:84px 0 76px;
  background:linear-gradient(150deg,rgba(5,79,124,.93),rgba(6,58,92,.92)),url("../img/page-bg.jpg") center 35%/cover no-repeat}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 420px at 85% -20%,rgba(13,160,233,.3),transparent 62%)}
.page-hero .wrap{position:relative}
.page-hero .crumb{font-size:.82rem;color:#a9cbe2;margin-bottom:16px}
.page-hero .crumb a:hover{color:#fff}
.page-hero h1{font-family:var(--font-head);font-size:clamp(2.05rem,4.1vw,2.95rem);font-weight:900;line-height:1.36;letter-spacing:-.01em;text-shadow:0 2px 20px rgba(0,20,40,.25)}
.page-hero p{margin-top:16px;color:#d6e8f5;font-size:1.04rem;line-height:1.9;max-width:680px}

/* 汎用テキストブロック（規約等） */
.doc{font-size:.94rem;color:var(--body);line-height:1.9}
.doc h2{font-size:1.2rem;font-weight:800;color:var(--ink);margin:38px 0 12px;padding-bottom:8px;border-bottom:2px solid var(--brand-pale)}
.doc h3{font-size:1.02rem;font-weight:700;color:var(--brand-dark);margin:24px 0 8px}
.doc p{margin-bottom:12px}
.doc ul{list-style:disc;padding-left:1.4em;margin-bottom:14px}
.doc ol{list-style:decimal;padding-left:1.5em;margin-bottom:14px}
.doc li{margin-bottom:6px}
.doc table{width:100%;border-collapse:collapse;margin:14px 0;font-size:.88rem}
.doc table th,.doc table td{border:1px solid var(--line-strong);padding:10px 12px;text-align:left}
.doc table th{background:var(--bg-soft);font-weight:700}
.doc .updated{color:var(--muted);font-size:.85rem;margin-bottom:24px}

/* セクション間ヘルパー */
.mt-s{margin-top:18px}.mt-m{margin-top:30px}.mt-l{margin-top:48px}
.mb-m{margin-bottom:30px}
.divider{height:1px;background:var(--line);margin:48px 0}
.tag-soft{display:inline-block;background:var(--brand-soft);color:var(--brand-dark);font-size:.74rem;font-weight:700;
  padding:4px 10px;border-radius:6px}

/* ---------- レスポンシブ ---------- */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr;gap:36px;padding:56px 0 64px}
  .hero-visual{max-width:440px}
  .pickup{grid-template-columns:1fr;gap:40px}
  .pickup-device,.pickup--rev .pickup-device{max-width:500px;margin:0 auto;order:-1;padding:0 0 26px 0}
  .sec-check,.footer-grid{grid-template-columns:1fr 1fr}
  .footer-grid{gap:30px}
  .plan-select,.issue-grid,.cards-3,.cards-4,.stats,.works-grid,.feature-list--3{grid-template-columns:repeat(2,1fr)}
  .plans{grid-template-columns:repeat(2,1fr);gap:22px}
  .plan--reco{transform:none}
  /* biz-flow：縦積みにして矢印を下向きに */
  .biz-flow{grid-template-columns:1fr;gap:0;max-width:560px}
  .bf-turn{flex-direction:row;justify-content:center;gap:10px;padding:16px 0}
  .bf-turn-txt{writing-mode:horizontal-tb;letter-spacing:.06em}
  .bf-turn-arw{transform:rotate(90deg)}
}
@media(max-width:760px){
  .section{padding:60px 0}
  .gnav,.header-cta .btn-nav-only{display:none}
  .nav-toggle{display:flex}
  .gnav.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;
    background:#fff;border-bottom:1px solid var(--line);padding:18px 24px;gap:4px;box-shadow:var(--shadow-m)}
  .gnav.open a{padding:12px 0;border-bottom:1px solid var(--line);width:100%}
  .form-row{grid-template-columns:1fr}
  .feature-list,.issue-grid,.cards-3,.cards-4,.cards-2,.stats,.plan-select,.footer-grid,.works-grid,.plans,.contact-grid{grid-template-columns:1fr}
  .btn{max-width:100%;white-space:normal}
  .sec-form{flex-direction:column}
  .sec-check{padding:48px 26px}
  .cta-band,.sec-check{padding:32px 24px}
  .quote{padding:24px 18px}
  .quote-head{flex-direction:column;gap:14px}
  .quote-head .q-meta{text-align:left}
  .footer-bottom{flex-direction:column}
  .tb-grid{grid-template-columns:1fr 1fr;gap:22px 0}
  .tb-item:nth-child(odd){border-left:0}
  .tb-num{font-size:1.7rem}
  .ws-grid{grid-template-columns:1fr 1fr;gap:16px}
  /* ヘッダー：モバイルで横はみ出しを防ぐ（ブランド名が長い＋CTA） */
  .header-inner{height:58px;gap:8px}
  .brand{flex:1 1 auto;min-width:0}
  .brand-txt b{font-size:.84rem;letter-spacing:0}
  .brand-txt small{font-size:.58rem}
  .header-cta{gap:8px}
  .header-cta .btn{padding:9px 14px;font-size:.82rem}
  /* セキュリティ認証バッジ：縦積み中央 */
  .cert{flex-direction:column;text-align:center;gap:14px;padding:24px 20px}
  .pkg-tabs{display:flex;width:100%;gap:3px;padding:4px}
  .pkg-tab{flex:1;justify-content:center;padding:11px 4px;font-size:.8rem}
  .pkg-reco{display:none}
}

/* ---------- 印刷（見積書のみ） ---------- */
@page{size:A4 portrait;margin:11mm 12mm}
@media print{
  html,body{background:#fff!important}
  *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
  /* 見積書以外は全部隠す */
  .site-header,.site-footer,.no-print,.est-controls,.page-hero,.cta-band,#estimate-form{display:none!important}
  .section{padding:0!important}
  .est-layout{gap:0!important}
  #quote-output{margin:0!important;display:block!important}
  /* A4 1枚に収める：余白・文字を圧縮し、改ページを禁止 */
  .quote{box-shadow:none!important;border:0!important;max-width:100%!important;margin:0!important;padding:0!important;
    font-size:10px;line-height:1.5;page-break-inside:avoid;break-inside:avoid}
  .quote,.quote *{break-inside:avoid}
  .quote-head{margin-bottom:12px!important;padding-bottom:10px!important}
  .quote-head .q-title{font-size:1.2rem!important;letter-spacing:.22em!important}
  .quote-head .q-meta{font-size:.72rem!important}
  .quote-head .q-meta .q-no{font-size:.78rem!important}
  .quote-to{font-size:1rem!important;margin-bottom:4px!important;padding-bottom:4px!important}
  .quote-from{font-size:.72rem!important;margin-bottom:12px!important;line-height:1.5!important}
  .quote-total-box{padding:11px 16px!important;margin:12px 0!important;gap:24px!important}
  .quote-total-box .lbl{font-size:.74rem!important}
  .quote-total-box .amt{font-size:1.3rem!important}
  table.q-table{font-size:9.5px!important;margin:0!important;table-layout:fixed!important;width:100%!important}
  table.q-table th,table.q-table td{padding:5px 7px!important;line-height:1.45!important;word-break:break-word!important;overflow-wrap:anywhere!important}
  table.q-table td span{font-size:8.5px!important}
  .quote p{font-size:8.5px!important;margin:6px 0!important;line-height:1.5!important}
  .quote-notes{font-size:8px!important;line-height:1.5!important;margin-top:10px!important;padding-top:8px!important}
  .quote-notes h5{font-size:9px!important;margin-bottom:4px!important}
  .quote-notes p{font-size:8px!important;margin:3px 0!important}
  .quote-foot{font-size:8px!important;margin-top:8px!important;padding-top:8px!important}
}

/* ---------- 幾何学背景パターン（全体・極薄） ---------- */
.section,.section--soft{background-image:var(--geo)}
.page-hero::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:var(--geo-dark)}
.page-hero > .wrap{position:relative;z-index:1}
@media print{ .section,.section--soft,.page-hero::after{background-image:none!important} }
