:root {
  --ink:#142033;
  --muted:#5b677a;
  --line:#dde3ec;
  --paper:#ffffff;
  --surface:#ffffff;
  --brand:#142b4d;
  --brand-2:#b08a46;
  --accent:#d4b06a;
  --shadow:0 18px 46px rgba(20,32,51,.11);
  --shadow-soft:0 8px 22px rgba(20,32,51,.07);
  --radius:18px;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; width:100%; max-width:100%; overflow-x:hidden; }
body {
  margin:0;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  font-family:"AEO Noto Sans JP", "Noto Sans CJK JP", "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#faf8f2 0%, #f6f2ea 38%, #ffffff 82%);
  line-height:1.62;
}
img, video, iframe { max-width:100%; }
a { color:var(--brand); }
.skip-link { position:absolute; left:12px; top:-48px; z-index:10000; padding:10px 14px; border-radius:10px; background:#fff; color:var(--brand); font-weight:900; box-shadow:0 12px 28px rgba(15,23,42,.18); transition:top .15s ease; }
.skip-link:focus { top:12px; }
.site-header { position:sticky; top:0; z-index:20; background:rgba(255,255,255,.94); backdrop-filter:blur(18px); border-bottom:1px solid rgba(176,138,70,.18); padding:9px 18px; }
.wrap { width:100%; max-width:1120px; margin:0 auto; }
.site-header .wrap { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.header-left { display:flex; align-items:center; gap:10px; min-width:120px; text-decoration:none; color:var(--ink); }
.header-logo { display:block; max-width:112px; max-height:58px; object-fit:contain; }
.header-logo.service-logo { width:112px; height:auto; max-height:38px; }
.brand-text { display:grid; gap:2px; max-width:240px; font-family:var(--brand-font-family, "AEO Noto Sans JP", "Noto Sans CJK JP", "Noto Sans JP", "Yu Gothic", "Meiryo", sans-serif); font-size:calc(var(--brand-font-size, 20px) * .9); font-weight:950; line-height:1.08; letter-spacing:0; }
.brand-text span { display:block; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.brand { margin:0; font-size:20px; font-weight:900; }
.header-right { display:flex; flex-direction:column; align-items:flex-end; gap:5px; min-width:0; }
.header-contact { display:flex; flex-wrap:wrap; justify-content:flex-end; gap:5px 12px; font-size:12px; font-weight:800; color:#2b3443; }
.header-contact strong { color:var(--brand); }
.nav { display:flex; flex-wrap:wrap; gap:10px; align-items:center; justify-content:flex-end; }
.nav a { text-decoration:none; color:#364152; font-weight:700; font-size:13px; }
.nav a:hover { color:var(--brand); }
.header-cta { display:inline-flex; align-items:center; justify-content:center; min-height:36px; padding:8px 15px; border-radius:999px; background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff !important; box-shadow:0 10px 22px rgba(20,43,77,.16); }
.nav-check { position:absolute; inline-size:1px; block-size:1px; overflow:hidden; clip:rect(0 0 0 0); clip-path:inset(50%); white-space:nowrap; }
.nav-toggle { display:none; width:46px; height:46px; border:1px solid var(--line); border-radius:12px; background:#fff; box-shadow:0 10px 22px rgba(15,23,42,.08); cursor:pointer; }
.nav-toggle span { display:block; width:22px; height:2px; margin:5px auto; border-radius:999px; background:var(--brand); }
main { background:transparent; }
section { padding:48px 20px; }
section:nth-of-type(even) { background:rgba(255,255,255,.56); }
.hero { padding:58px 20px 48px; background:radial-gradient(circle at 12% 8%, rgba(212,176,106,.18), transparent 28%), radial-gradient(circle at 88% 12%, rgba(20,43,77,.10), transparent 34%), linear-gradient(135deg,#fffdfa 0%, #f7f2e7 48%, #ffffff 100%); }
.hero-inner { display:grid; grid-template-columns:minmax(360px,1.08fr) minmax(0,.92fr); gap:32px; align-items:center; }
.hero-copy, .hero-visual, .card, .action-panel, .info-list, .grid, .feature-list, .flow-list, .gallery-grid, .check-list, .used-list { min-width:0; }
.hero h1 { margin:0; font-size:clamp(32px,4.2vw,54px); line-height:1.08; font-weight:950; }
.hero p { max-width:640px; font-size:15px; color:#405066; }
.hero-meta { display:flex; flex-wrap:wrap; gap:7px; margin:14px 0 0; padding:0; list-style:none; }
.hero-meta li { padding:6px 11px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.8); font-size:12px; font-weight:700; color:#46556a; }
.header-image, .hero-placeholder { border-radius:22px; overflow:hidden; background:#efe8db; border:1px solid rgba(255,255,255,.95); box-shadow:var(--shadow); }
.header-image { aspect-ratio:16/10; display:grid; place-items:center; }
.header-image img { width:100%; height:100%; max-height:clamp(240px,34vw,420px); object-fit:contain; display:block; background:#f7f4ec; }
.hero-carousel { position:relative; border-radius:22px; overflow:hidden; background:#f7f4ec; border:1px solid rgba(255,255,255,.95); box-shadow:var(--shadow); aspect-ratio:16/10; min-height:240px; max-height:clamp(260px,34vw,430px); }
.hero-carousel img { position:absolute; inset:0; width:100%; height:100%; object-fit:contain; opacity:0; animation:heroFade 18s infinite; background:#f7f4ec; }
.hero-carousel img:nth-child(1) { opacity:1; animation-delay:0s; }
.hero-carousel img:nth-child(2) { animation-delay:6s; }
.hero-carousel img:nth-child(3) { animation-delay:12s; }
@keyframes heroFade { 0%, 28% { opacity:1; } 35%, 95% { opacity:0; } 100% { opacity:1; } }
.hero-placeholder { min-height:280px; background:linear-gradient(135deg,#efe7db,#f9f6ef); }
.logo-block img { max-width:142px; max-height:82px; object-fit:contain; display:block; margin:0 0 12px; }
h1 { line-height:1.22; }
h1, h2, h3, p, li, dd, dt, a, span { overflow-wrap:anywhere; }
h2 { margin:0 0 16px; font-size:clamp(24px,2.4vw,34px); line-height:1.16; font-weight:900; }
h3 { margin:0 0 8px; font-size:18px; }
.grid { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px; }
.card, .action-panel, .gallery-item, .check-list li, .used-list li, .feature-list li, .flow-list li { background:rgba(255,255,255,.82); border:1px solid var(--line); box-shadow:var(--shadow-soft); }
.card, .action-panel { border-radius:var(--radius); padding:20px; }
.info-list { display:grid; grid-template-columns:150px 1fr; gap:7px 12px; font-size:14px; }
.info-list dt { font-weight:800; color:#334155; }
.info-list dd { margin:0; }
.company-overview-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; }
.company-overview-group { min-width:0; padding:16px; border:1px solid var(--line); border-radius:16px; background:rgba(255,255,255,.78); }
.company-overview-group h3 { margin:0 0 12px; font-size:16px; color:var(--brand); }
.company-overview-group .info-list { grid-template-columns:110px 1fr; font-size:13px; }
.company-overview-group.company-overview-wide { grid-column:span 2; }
.feature-list, .flow-list { display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:13px; margin:0; padding:0; list-style:none; }
.feature-list li, .flow-list li { border-radius:16px; padding:16px; }
.ai-service-html-section { background:linear-gradient(180deg,rgba(255,255,255,.72),rgba(248,250,252,.86)); }
.ai-slot-grid { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px; }
.ai-slot-card { min-width:0; padding:20px; border:1px solid var(--line); border-radius:var(--radius); background:rgba(255,255,255,.86); box-shadow:var(--shadow-soft); }
.ai-slot-card h3 { margin:0 0 12px; font-size:clamp(18px,1.9vw,23px); }
.ai-slot-card ul { display:grid; gap:10px; margin:0; padding:0; list-style:none; }
.ai-slot-card li { display:grid; gap:4px; padding:0 0 10px; border-bottom:1px solid rgba(203,213,225,.72); }
.ai-slot-card li:last-child { padding-bottom:0; border-bottom:0; }
.ai-slot-card strong { color:var(--brand); font-size:12px; letter-spacing:.02em; }
.ai-slot-card span { color:#334155; line-height:1.7; }
.ai-slot-thumb { margin:0 0 14px; overflow:hidden; border-radius:16px; border:1px solid var(--line); background:#eef6ff; aspect-ratio:16/10; }
.ai-slot-thumb img { display:block; width:100%; height:100%; object-fit:cover; }
.ai-comp-page { background:#f8fbff; color:#0f172a; }
.ai-comp-page section:nth-of-type(even) { background:transparent; }
.ai-comp-hero { position:relative; overflow:hidden; padding:62px 20px 52px; background:linear-gradient(180deg,#ffffff 0%,#f3f8ff 100%); }
.ai-comp-hero::before { content:""; position:absolute; right:5%; top:12%; width:34%; height:58%; border-radius:999px; background:radial-gradient(circle,rgba(56,216,255,.18),transparent 65%); pointer-events:none; }
.ai-comp-hero .wrap { position:relative; display:grid; grid-template-columns:minmax(0,.92fr) minmax(320px,1.08fr); gap:34px; align-items:center; }
.ai-comp-hero-copy { color:#0f172a; }
.ai-comp-hero-copy h1 { margin:0; max-width:820px; font-size:clamp(34px,4.8vw,64px); line-height:1.02; font-weight:950; }
.ai-comp-hero-copy p { max-width:660px; color:#334155; }
.ai-comp-hero-panel, .ai-comp-visual-shell { display:grid; gap:12px; padding:22px; border:1px solid rgba(56,216,255,.24); border-radius:var(--radius); background:rgba(255,255,255,.76); box-shadow:0 28px 80px rgba(15,23,42,.12); backdrop-filter:blur(14px); }
.ai-comp-visual-lines { display:grid; gap:8px; }
.ai-comp-visual-lines span { display:block; height:9px; border-radius:999px; background:linear-gradient(90deg,rgba(15,23,42,.78),rgba(56,216,255,.28)); }
.ai-comp-visual-lines span:nth-child(1) { width:62%; }
.ai-comp-visual-lines span:nth-child(2) { width:94%; }
.ai-comp-visual-lines span:nth-child(3) { width:78%; }
.ai-comp-metric-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; }
.ai-comp-metric { min-height:78px; border:1px solid rgba(15,23,42,.08); border-radius:14px; background:rgba(255,255,255,.72); }
.ai-comp-hero-photo { overflow:hidden; border-radius:18px; border:1px solid rgba(148,163,184,.28); box-shadow:0 24px 70px rgba(15,23,42,.16); }
.ai-comp-hero-photo img { display:block; width:100%; aspect-ratio:16/10; object-fit:cover; }
.ai-comp-mini-row { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:10px; }
.ai-comp-mini-card { min-height:78px; padding:14px; border:1px solid rgba(148,163,184,.24); border-radius:14px; background:rgba(255,255,255,.78); color:#0f172a; }
.ai-comp-mini-card b { display:block; margin-bottom:8px; color:var(--brand); font-size:12px; }
.ai-comp-platform-visual { position:relative; padding:22px; border:1px solid rgba(37,99,235,.16); border-radius:24px; background:radial-gradient(circle at 70% 18%,rgba(56,189,248,.22),transparent 30%),linear-gradient(135deg,#ffffff,#edf7ff); box-shadow:0 28px 80px rgba(37,99,235,.13); }
.ai-comp-platform-core { display:grid; grid-template-columns:1fr 1fr; gap:14px; align-items:center; }
.ai-comp-platform-diagram { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
.ai-comp-platform-node { min-height:84px; border-radius:16px; border:1px solid rgba(37,99,235,.18); background:rgba(255,255,255,.82); box-shadow:0 12px 28px rgba(37,99,235,.08); }
.ai-comp-brochure-visual { display:grid; gap:16px; padding:22px; border-radius:24px; background:linear-gradient(135deg,#ffffff,#eef6ff); border:1px solid rgba(15,23,42,.08); box-shadow:0 24px 70px rgba(15,23,42,.12); }
.ai-comp-brochure-icons { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:10px; }
.ai-comp-brochure-icons span { display:grid; place-items:center; min-height:74px; border-radius:14px; background:#fff; color:var(--brand); font-weight:950; border:1px solid rgba(37,99,235,.12); }
.ai-comp-inquiry-visual { display:grid; grid-template-columns:.95fr 1.05fr; gap:14px; align-items:stretch; padding:18px; border-radius:24px; background:linear-gradient(135deg,#ffffff,#eaf8ff); border:1px solid rgba(37,99,235,.14); box-shadow:0 28px 80px rgba(37,99,235,.12); }
.ai-comp-form-mock { display:grid; gap:10px; padding:18px; border-radius:18px; background:#fff; box-shadow:0 20px 50px rgba(15,23,42,.12); }
.ai-comp-form-head { height:46px; border-radius:12px; background:linear-gradient(135deg,#0b4ea2,#0f172a); }
.ai-comp-form-line { height:38px; border-radius:10px; border:1px solid #dbeafe; background:#f8fbff; }
.ai-comp-form-submit { height:48px; border-radius:12px; background:linear-gradient(135deg,#f97316,#fb923c); }
.ai-comp-premium-visual { position:relative; overflow:hidden; display:grid; gap:14px; padding:18px; border-radius:20px; border:1px solid rgba(214,168,79,.28); background:radial-gradient(circle at 70% 10%,rgba(214,168,79,.18),transparent 34%),#070b12; box-shadow:0 30px 90px rgba(0,0,0,.38); }
.ai-comp-premium-visual .ai-comp-hero-photo { border-color:rgba(214,168,79,.18); box-shadow:none; opacity:.88; }
.ai-comp-premium-badge { display:inline-flex; width:max-content; padding:8px 12px; border:1px solid rgba(214,168,79,.4); color:#f1d99b; border-radius:999px; font-weight:900; }
.ai-comp-section { position:relative; padding:48px 20px; overflow:hidden; }
.ai-comp-section .wrap { position:relative; z-index:1; }
.ai-comp-section-head { max-width:760px; margin-bottom:20px; }
.ai-comp-section-head h2 { margin-bottom:8px; }
.ai-comp-card-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; }
.ai-comp-card { min-width:0; padding:20px; border:1px solid var(--line); border-radius:var(--radius); background:rgba(255,255,255,.9); box-shadow:var(--shadow-soft); }
.ai-comp-card h3 { margin:0 0 10px; font-size:clamp(18px,1.8vw,23px); }
.ai-comp-card figure { margin:0 0 14px; overflow:hidden; border-radius:14px; border:1px solid rgba(148,163,184,.25); aspect-ratio:16/9; background:#eef6ff; }
.ai-comp-card figure img { display:block; width:100%; height:100%; object-fit:cover; }
.ai-comp-card ul { display:grid; gap:9px; margin:0; padding:0; list-style:none; }
.ai-comp-card li { display:grid; gap:4px; padding-bottom:9px; border-bottom:1px solid rgba(203,213,225,.72); }
.ai-comp-card li:last-child { padding-bottom:0; border-bottom:0; }
.ai-comp-card strong { color:var(--brand); font-size:12px; }
.ai-comp-card span { color:#334155; }
.ai-comp-link { display:inline-flex; margin-top:14px; font-weight:900; text-decoration:none; color:var(--brand); }
.ai-comp-process { background:linear-gradient(180deg,#ffffff,#eef7ff); }
.ai-comp-process .ai-comp-card-grid { grid-template-columns:repeat(4,minmax(0,1fr)); }
.ai-comp-process .ai-comp-card { text-align:center; }
.ai-comp-proof { background:linear-gradient(135deg,#f8fbff,#ffffff 42%,#eaf6ff); }
.ai-comp-proof::before { content:""; position:absolute; right:6%; top:18%; width:36%; height:58%; background:linear-gradient(135deg,rgba(56,216,255,.18),rgba(20,43,77,.08)); clip-path:polygon(0 42%,100% 12%,100% 84%,0 70%); }
.ai-comp-gallery .ai-comp-card-grid { grid-template-columns:1.25fr .9fr .9fr; }
.ai-comp-faq .ai-comp-card-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
.ai-comp-final { background:linear-gradient(135deg,var(--brand),#0b1220); color:#fff; }
.ai-comp-final h2, .ai-comp-final .note { color:#fff; }
.ai-comp-final .action-panel { border-color:rgba(255,255,255,.18); background:rgba(255,255,255,.08); color:#fff; }
body.layout-a-official-aeo .ai-comp-page { background:linear-gradient(180deg,#ffffff,#f7fbff); }
body.layout-a-official-aeo .ai-comp-hero { background:linear-gradient(180deg,#ffffff 0%,#eef6ff 100%); }
body.layout-a-official-aeo .ai-comp-hero .wrap { grid-template-columns:minmax(0,.9fr) minmax(360px,1.1fr); }
body.layout-a-official-aeo .ai-comp-hero-copy h1 { color:#082f63; }
body.layout-a-official-aeo .ai-comp-card-grid { grid-template-columns:repeat(4,minmax(0,1fr)); }
body.layout-a-official-aeo .ai-comp-final { background:linear-gradient(135deg,#073b79,#0b1220); }
body.layout-b-readable-lp .ai-comp-page { background:#f7fbff; }
body.layout-b-readable-lp .ai-comp-hero { background:linear-gradient(180deg,#ffffff 0%,#f1f8ff 100%); }
body.layout-b-readable-lp .ai-comp-hero .wrap { grid-template-columns:minmax(0,.82fr) minmax(380px,1.18fr); }
body.layout-b-readable-lp .ai-comp-hero-copy h1 { color:#0f172a; }
body.layout-b-readable-lp .ai-comp-process { background:linear-gradient(90deg,#ffffff 0%,#ffffff 38%,#eaf7ff 100%); }
body.layout-b-readable-lp .ai-comp-card { box-shadow:0 16px 44px rgba(37,99,235,.08); }
body.layout-b-readable-lp .ai-comp-final { background:linear-gradient(135deg,#0068d9,#00b8e6); }
body.layout-c-premium-ai .ai-comp-page { background:#05070d; color:#ead9b7; }
body.layout-c-premium-ai .ai-comp-hero { background:radial-gradient(circle at 76% 18%,rgba(214,168,79,.2),transparent 30%),linear-gradient(135deg,#03050b 0%,#08182a 54%,#111012 100%); }
body.layout-c-premium-ai .ai-comp-hero .wrap { grid-template-columns:minmax(0,1.04fr) minmax(360px,.96fr); min-height:58vh; }
body.layout-c-premium-ai .ai-comp-hero-copy h1, body.layout-c-premium-ai .ai-comp-section h2 { color:#f1d99b; font-family:"AEO Noto Serif JP", "Noto Serif CJK JP", "Noto Serif JP", "Yu Mincho", "Hiragino Mincho ProN", serif; }
body.layout-c-premium-ai .ai-comp-hero-copy, body.layout-c-premium-ai .ai-comp-hero-copy p { color:#f8ecd0; }
body.layout-c-premium-ai .ai-comp-section { background:#05070d; border-top:1px solid rgba(214,168,79,.16); }
body.layout-c-premium-ai .ai-comp-card { background:rgba(30,24,16,.58); border-color:rgba(214,168,79,.18); color:#f8ecd0; box-shadow:none; }
body.layout-c-premium-ai .ai-comp-card span, body.layout-c-premium-ai .ai-comp-card strong { color:#ead9b7; }
body.layout-c-premium-ai .ai-comp-final { background:radial-gradient(circle at 30% 0%,rgba(214,168,79,.22),transparent 36%),#05070d; }
body.layout-d-inquiry-focus .ai-comp-page { background:#ffffff; }
body.layout-d-inquiry-focus .ai-comp-hero { background:linear-gradient(135deg,#ffffff 0%,#f5fbff 58%,#e7f7ff 100%); }
body.layout-d-inquiry-focus .ai-comp-hero-copy h1 { color:#102a56; }
body.layout-d-inquiry-focus .btn.primary, body.layout-d-inquiry-focus .cta-reserve, body.layout-d-inquiry-focus .cta-list { background:linear-gradient(135deg,#f97316,#fb923c); }
body.layout-d-inquiry-focus .ai-comp-card-grid { grid-template-columns:repeat(3,minmax(0,1fr)); }
body.layout-d-inquiry-focus .ai-comp-final { background:linear-gradient(135deg,#f97316,#0b4ea2); }
body.layout-a-official-aeo .ai-comp-page :where(p,li,dd,span,small,label),
body.layout-b-readable-lp .ai-comp-page :where(p,li,dd,span,small,label),
body.layout-d-inquiry-focus .ai-comp-page :where(p,li,dd,span,small,label) { color:#334155; opacity:1; }
body.layout-a-official-aeo .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]),
body.layout-b-readable-lp .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]),
body.layout-d-inquiry-focus .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) { color:#0f172a; }
body.layout-a-official-aeo .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) :where(p,li,dd,span,small,label),
body.layout-b-readable-lp .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) :where(p,li,dd,span,small,label),
body.layout-d-inquiry-focus .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) :where(p,li,dd,span,small,label) { color:#334155; opacity:1; }
body.layout-a-official-aeo .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) :where(h1,h2,h3,h4,strong),
body.layout-b-readable-lp .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) :where(h1,h2,h3,h4,strong),
body.layout-d-inquiry-focus .ai-comp-page :where(.ai-comp-card,.action-panel,.card,[class*="card"],[class*="panel"]) :where(h1,h2,h3,h4,strong) { color:#0f172a; }
.ai-comp-page + .fixed-cta { display:flex; }
.service-page-visual { margin:22px 0; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:#f8fafc; box-shadow:var(--shadow-soft); aspect-ratio:16/9; }
.service-page-visual img { display:block; width:100%; height:100%; object-fit:cover; }
.eyebrow { display:inline-flex; margin-bottom:10px; padding:5px 10px; border-radius:999px; background:rgba(20,43,77,.08); color:var(--brand); font-size:12px; font-weight:800; letter-spacing:.02em; }
.check-list, .used-list { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:9px; margin:0; padding:0; list-style:none; }
.check-list li, .used-list li { border-radius:14px; padding:11px 13px; }
.cta-row { display:flex; flex-wrap:wrap; gap:9px; margin-top:14px; }
.btn { display:inline-flex; align-items:center; justify-content:center; min-height:42px; padding:9px 16px; border-radius:999px; border:1px solid var(--brand); text-decoration:none; font-weight:800; font-size:14px; box-shadow:0 8px 18px rgba(20,43,77,.10); }
.btn.primary, .cta-reserve, .cta-list { background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; border-color:transparent; }
.cta-phone { background:#fff; color:var(--brand); border-color:var(--brand); }
.cta-map { background:#fff; color:var(--brand); }
.action-panel h2 { font-size:20px; margin-bottom:6px; }
.note { color:var(--muted); font-size:13px; }
.inquiry-form-panel { margin-top:18px; padding:22px; border:1px solid var(--line); border-radius:var(--radius); background:rgba(255,255,255,.9); box-shadow:var(--shadow-soft); }
.inquiry-form { display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px; margin-top:14px; }
.inquiry-form label { display:grid; gap:6px; font-weight:800; font-size:13px; color:#334155; }
.inquiry-form .full, .inquiry-form .note, .inquiry-form button { grid-column:1 / -1; }
.inquiry-form input, .inquiry-form select, .inquiry-form textarea { width:100%; border:1px solid #cbd5e1; border-radius:12px; padding:11px 12px; font:inherit; background:#fff; color:var(--ink); }
.inquiry-form textarea { resize:vertical; min-height:140px; }
.inquiry-form input[name="website"] { position:absolute; left:-9999px; width:1px; height:1px; opacity:1; clip-path:inset(50%); overflow:hidden; }
.share-panel { margin:0 0 22px; padding:22px; border:1px solid var(--line); border-radius:22px; background:#fff; box-shadow:var(--shadow-soft); color:#1f2937; }
.share-panel h2 { margin:0 0 8px; font-size:20px; line-height:1.25; }
.share-panel .note { margin:0 0 12px; }
.share-row { display:flex; flex-wrap:wrap; gap:10px; }
.share-link { display:inline-flex; align-items:center; justify-content:center; min-height:44px; padding:10px 16px; border-radius:999px; border:1px solid #cbd5e1; background:#fff; color:var(--brand); font:inherit; font-weight:800; text-decoration:none; cursor:pointer; }
.share-link.primary-share { border-color:transparent; background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff; }
.compact-share { gap:6px; justify-content:flex-start; }
.compact-share .share-link { min-height:34px; padding:7px 10px; font-size:.82rem; }
.share-copy { appearance:none; -webkit-appearance:none; }
.access-map-panel { margin-top:18px; padding:0; overflow:hidden; }
.access-map-panel__body { padding:18px 20px; }
.access-map-panel iframe { display:block; width:100%; min-height:360px; border:0; background:#e2e8f0; }
.gallery-grid { display:grid; grid-template-columns:repeat(3, minmax(0,1fr)); gap:13px; }
.gallery-item { margin:0; border-radius:18px; overflow:hidden; }
.gallery-item img { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.news-list { display:grid; gap:9px; margin:0; padding:0; list-style:none; }
.news-group { display:grid; gap:10px; margin-top:14px; }
.news-group h3 { margin:0; font-size:clamp(1.05rem, 1.8vw, 1.35rem); }
.news-list li { display:grid; grid-template-columns:130px 1fr; gap:10px; align-items:start; padding:12px 14px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.86); box-shadow:var(--shadow-soft); }
.news-list time { font-weight:900; color:var(--brand); }
.news-list p { margin:0; color:#405066; }
table { width:100%; border-collapse:collapse; }
th, td { padding:9px 7px; border-bottom:1px solid var(--line); text-align:left; vertical-align:top; word-break:break-word; }
.footer { padding:22px 20px 34px; background:#f7f8fb; color:var(--muted); border-top:1px solid var(--line); }
.fixed-cta { display:none; }
.demo-stamp { position:fixed; top:88px; right:18px; z-index:9998; padding:8px 14px; border:4px solid #dc2626; color:#dc2626; background:rgba(255,255,255,.92); font-size:22px; font-weight:950; letter-spacing:.08em; transform:rotate(4deg); pointer-events:none; box-shadow:0 12px 28px rgba(220,38,38,.14); }
.demo-watermark { position:fixed; inset:0; z-index:9997; display:grid; place-items:center; pointer-events:none; color:rgba(220,38,38,.08); font-size:clamp(92px,18vw,260px); font-weight:950; letter-spacing:.08em; transform:rotate(-24deg); user-select:none; }

body.design-standard { --brand:#1f4e8c; --brand-2:#3d74b8; --accent:#7da4da; background:linear-gradient(180deg,#f7fbff 0%, #ffffff 72%); }
body.design-standard .hero { background:radial-gradient(circle at 12% 8%, rgba(61,116,184,.12), transparent 28%), linear-gradient(135deg,#ffffff,#eef5ff 58%,#ffffff 100%); }
body.design-standard .card, body.design-standard .action-panel { background:#ffffff; }

body.design-simple { --brand:#202938; --brand-2:#4b5563; --accent:#94a3b8; --shadow:0 12px 30px rgba(15,23,42,.06); --shadow-soft:0 8px 18px rgba(15,23,42,.04); --radius:18px; background:#ffffff; }
body.design-simple .hero { background:linear-gradient(180deg,#ffffff 0%, #f8fafc 100%); padding:54px 20px 46px; }
body.design-simple .hero-inner { grid-template-columns:minmax(0,1fr); }
body.design-simple .header-image, body.design-simple .hero-placeholder { border-radius:16px; box-shadow:var(--shadow-soft); }
body.design-simple .card, body.design-simple .action-panel { background:#ffffff; border-radius:14px; box-shadow:var(--shadow-soft); }
body.design-simple .feature-list, body.design-simple .flow-list, body.design-simple .gallery-grid, body.design-simple .check-list, body.design-simple .used-list { grid-template-columns:1fr; }
body.design-simple .btn { box-shadow:none; }

body.design-warm, body.design-modern { background:inherit; }
body.design-warm .hero, body.design-modern .hero { background:inherit; }
body.design-warm .card, body.design-modern .card, body.design-warm .action-panel, body.design-modern .action-panel { background:rgba(255,255,255,.82); }

body.layout-a-official-aeo .hero { padding:48px 20px 40px; background:linear-gradient(180deg,#ffffff 0%,#f8fafc 100%); }
body.layout-a-official-aeo .hero-inner { grid-template-columns:minmax(0,1fr); gap:18px; }
body.layout-a-official-aeo .hero-visual { order:2; max-width:760px; }
body.layout-a-official-aeo .hero-copy { order:1; max-width:920px; }
body.layout-a-official-aeo .hero h1 { font-size:clamp(30px,3.8vw,48px); }
body.layout-a-official-aeo .action-panel { border-left:5px solid var(--brand); }

body.layout-b-readable-lp { --radius:20px; }
body.layout-b-readable-lp section { padding:42px 20px; }
body.layout-b-readable-lp .hero-inner { grid-template-columns:minmax(0,.95fr) minmax(330px,1.05fr); gap:24px; }
body.layout-b-readable-lp .card, body.layout-b-readable-lp .action-panel { box-shadow:none; border-color:#dbe4f0; }
body.layout-b-readable-lp h2 { font-size:clamp(23px,2.2vw,31px); }

body.layout-c-premium-ai { --brand:#18233f; --brand-2:#b08a46; --accent:#d6b86a; background:linear-gradient(180deg,#fffaf0 0%,#ffffff 58%,#f6f8fb 100%); }
body.layout-c-premium-ai .hero { padding:66px 20px 56px; background:radial-gradient(circle at 18% 8%,rgba(176,138,70,.22),transparent 32%),linear-gradient(135deg,#fffaf0,#ffffff 56%,#eef3f8); }
body.layout-c-premium-ai .hero-inner { grid-template-columns:minmax(330px,.9fr) minmax(0,1.1fr); gap:30px; }
body.layout-c-premium-ai .hero-visual { order:2; }
body.layout-c-premium-ai .hero-copy { order:1; }
body.layout-c-premium-ai .header-image, body.layout-c-premium-ai .hero-carousel { border-radius:8px; }
body.layout-c-premium-ai .gallery-grid { grid-template-columns:1.2fr .9fr .9fr; }

body.layout-d-inquiry-focus .hero { padding:52px 20px 44px; background:linear-gradient(135deg,#ffffff,#eef5ff 60%,#ffffff); }
body.layout-d-inquiry-focus .hero-inner { grid-template-columns:minmax(0,1.05fr) minmax(320px,.95fr); }
body.layout-d-inquiry-focus .hero-copy .action-panel { background:linear-gradient(135deg,rgba(16,42,86,.98),rgba(9,24,49,.98)); color:#fff; border-color:#102a56; text-shadow:0 1px 2px rgba(0,0,0,.42); }
body.layout-d-inquiry-focus .hero-copy .action-panel .note { color:rgba(255,255,255,.9); text-shadow:0 1px 2px rgba(0,0,0,.42); }
body.layout-d-inquiry-focus .hero-copy .action-panel .btn { background:#fff; color:#102a56; border-color:#fff; }
body.layout-d-inquiry-focus .fixed-cta { display:flex; }

@media (max-width: 980px) {
  .site-header { padding:10px 14px; }
  .site-header .wrap { position:relative; flex-direction:row; align-items:center; gap:12px; min-height:50px; }
  .header-left { flex:1; min-width:0; }
  .header-logo { max-width:116px; max-height:56px; }
  .header-logo.service-logo { width:116px; max-height:40px; }
  .brand-text { max-width:160px; font-size:calc(var(--brand-font-size, 20px) * .86); }
  .brand { font-size:17px; }
  .nav-toggle { display:grid; place-content:center; flex:0 0 auto; margin-left:auto; }
  .nav-check:focus-visible + .nav-toggle { outline:3px solid rgba(20,43,77,.25); outline-offset:3px; }
  .header-right { display:none; position:absolute; top:calc(100% + 10px); right:0; left:auto; width:min(360px, calc(100vw - 28px)); align-items:stretch; gap:12px; padding:14px; border:1px solid var(--line); border-radius:18px; background:rgba(255,255,255,.98); box-shadow:0 18px 42px rgba(15,23,42,.16); }
  .nav-check:checked ~ .header-right { display:flex; }
  .header-contact { justify-content:flex-start; gap:6px 10px; font-size:12px; }
  .header-contact span { display:none; }
  .header-contact span:first-child, .header-contact span:nth-child(4) { display:inline-flex; }
  .nav { display:grid; grid-template-columns:1fr; gap:6px; justify-content:stretch; width:100%; }
  .nav a { display:flex; align-items:center; min-height:44px; padding:8px 10px; border-radius:10px; background:#f8fafc; font-size:15px; }
  .nav .header-cta { min-height:46px; margin-top:4px; background:linear-gradient(135deg,var(--brand),var(--brand-2)); color:#fff !important; }
  .hero-inner, .grid, .info-list, .company-overview-grid, .check-list, .used-list, .gallery-grid, .feature-list, .flow-list, .ai-slot-grid { grid-template-columns:1fr; }
  .company-overview-group.company-overview-wide { grid-column:auto; }
  .ai-comp-hero .wrap, .ai-comp-card-grid, .ai-comp-process .ai-comp-card-grid, .ai-comp-gallery .ai-comp-card-grid, .ai-comp-faq .ai-comp-card-grid, .ai-comp-platform-core, .ai-comp-inquiry-visual, body.layout-a-official-aeo .ai-comp-hero .wrap, body.layout-b-readable-lp .ai-comp-hero .wrap, body.layout-c-premium-ai .ai-comp-hero .wrap { grid-template-columns:1fr; }
  .ai-comp-mini-row, .ai-comp-brochure-icons { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .news-list li { grid-template-columns:1fr; gap:6px; }
  .hero { padding:42px 18px 36px; }
  .hero p { font-size:14px; }
  .header-image, .hero-carousel, .hero-placeholder { min-height:220px; max-height:none; }
  .header-image img { height:100%; min-height:220px; }
  .btn { width:100%; }
  body { padding-bottom:88px; }
  .fixed-cta { position:fixed; left:0; right:0; bottom:0; z-index:20; display:flex; gap:8px; padding:10px; background:rgba(255,255,255,.96); border-top:1px solid var(--line); box-shadow:0 -8px 20px rgba(15,23,42,.10); }
  .fixed-cta .btn { min-height:46px; font-size:14px; padding:8px 10px; }
  .demo-stamp { top:70px; right:12px; padding:6px 10px; border-width:3px; font-size:17px; }
}

@media (max-width: 600px) {
  body { padding-bottom:104px; }
  .site-header { padding:8px 10px; }
  .site-header .wrap { width:100%; max-width:100%; gap:8px; }
  .header-left { max-width:calc(100vw - 68px); }
  .header-logo { max-width:88px; max-height:42px; }
  .header-logo.service-logo { width:88px; max-height:34px; }
  .brand-text { max-width:calc(100vw - 166px); font-size:14px; line-height:1.12; }
  .nav-toggle { width:42px; height:42px; border-radius:10px; }
  .header-right { position:fixed; top:62px; left:10px; right:10px; width:auto; max-height:calc(100vh - 78px); overflow:auto; border-radius:14px; }
  section { padding:30px 14px; }
  .hero { padding:32px 14px 30px; }
  body.layout-a-official-aeo .hero,
  body.layout-b-readable-lp .hero,
  body.layout-c-premium-ai .hero,
  body.layout-d-inquiry-focus .hero { padding:32px 14px 30px; }
  .hero-inner,
  body.layout-b-readable-lp .hero-inner,
  body.layout-c-premium-ai .hero-inner,
  body.layout-d-inquiry-focus .hero-inner { display:grid; grid-template-columns:minmax(0,1fr); gap:16px; }
  .hero h1,
  body.layout-a-official-aeo .hero h1 { font-size:clamp(25px,7vw,32px); line-height:1.16; }
  h2 { font-size:clamp(21px,6vw,27px); }
  h3 { font-size:17px; }
  .hero p { font-size:14px; line-height:1.62; }
  .card, .action-panel { padding:16px; border-radius:14px; }
  .inquiry-form-panel { padding:16px; border-radius:14px; }
  .inquiry-form { grid-template-columns:1fr; }
  .header-image, .hero-carousel, .hero-placeholder { border-radius:14px; min-height:0; aspect-ratio:4/3; }
  .header-image img, .hero-carousel img { min-height:0; object-fit:cover; }
  .hero-meta, .cta-row { display:grid; grid-template-columns:1fr; gap:8px; }
  .share-panel { padding:18px; border-radius:18px; }
  .share-row { display:grid; grid-template-columns:1fr; gap:8px; }
  .share-link { width:100%; }
  .access-map-panel iframe { min-height:300px; }
  .info-list { display:grid; grid-template-columns:1fr; gap:6px; }
  .info-list dd { padding-bottom:8px; border-bottom:1px solid rgba(221,227,236,.72); }
  table { display:block; max-width:100%; overflow-x:auto; white-space:normal; }
  th, td { min-width:130px; }
  .fixed-cta { display:grid; grid-template-columns:1fr; padding:7px 10px; max-height:94px; overflow:auto; }
  .fixed-cta .btn { width:100%; min-height:38px; }
  .demo-watermark { font-size:72px; }
  .demo-stamp { top:66px; right:10px; font-size:14px; border-width:3px; }
}