/* ============================================
   PROCLIA Common CSS
   Header, Footer, Design System, Shared Components
   ============================================ */

html { scroll-behavior: smooth; }

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;900&display=swap');

/* ── Header ── */
header { position: sticky; top: 0; z-index: 100; background: rgba(255,255,255,0.97); backdrop-filter: blur(8px); border-bottom: 1px solid #e5e7eb; }
.hd { max-width: 1040px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; padding: 0 24px; height: 64px; }
.logo { text-decoration: none; display: flex; align-items: center; }
.logo img { height: 36px; width: auto; }
nav { display: flex; align-items: center; gap: 24px; }
nav a { text-decoration: none; font-size: 13px; font-weight: 500; color: #2d3748; transition: color 0.2s; }
nav a:hover { color: #4a8fba; }
.nav-cta { font-size: 12px !important; border: 1.5px solid #1a2e50; padding: 6px 14px; border-radius: 5px; color: #1a2e50 !important; font-weight: 600 !important; }
.nav-cta:hover { background: #1a2e50; color: #fff !important; }
.sp-toggle { display: none; font-size: 24px; cursor: pointer; color: #1a2e50; line-height: 1; padding: 4px; }
@media (max-width: 768px) {
  .sp-toggle { display: block; }
  nav { display: none; flex-direction: column; position: absolute; top: 64px; left: 0; right: 0; background: #fff; padding: 20px 24px; border-bottom: 1px solid #e5e7eb; gap: 16px; }
  header.open nav { display: flex; }
}

/* ── Footer ── */
footer { background: #1a2e50; color: rgba(255,255,255,0.7); padding: 56px 24px 0; }
.ft-inner { max-width: 1040px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 40px; }
.ft-brand .logo { font-size: 20px; font-weight: 900; color: #fff; letter-spacing: 2px; margin-bottom: 12px; }
.ft-brand p { font-size: 12px; line-height: 1.8; margin: 0; }
.ft-col h4 { font-size: 12px; font-weight: 700; color: #fff; margin: 0 0 14px 0; letter-spacing: 1px; }
.ft-col a { display: block; font-size: 12px; color: rgba(255,255,255,0.5); text-decoration: none; margin-bottom: 8px; transition: color 0.2s; }
.ft-col a:hover { color: #fff; }
.ft-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding: 20px 0; max-width: 1040px; margin: 0 auto; display: flex; justify-content: space-between; font-size: 11px; }
.ft-bottom a { color: rgba(255,255,255,0.4); text-decoration: none; }
@media (max-width: 768px) {
  .ft-inner { grid-template-columns: 1fr 1fr; gap: 28px; }
  .ft-brand { grid-column: 1 / -1; }
  .ft-bottom { flex-direction: column; gap: 8px; text-align: center; }
}

/* ── PROCLIA Design System Variables ── */
.proclia-page {
  --navy: #1a2e50;
  --navy-mid: #2c4a7c;
  --navy-soft: #3d5f8a;
  --navy-pale: #edf0f5;
  --accent: #4a8fba;
  --accent-dark: #3a7399;
  --sage: #5a8a7a;
  --warm-bg: #fafaf8;
  --cool-bg: #f5f6f8;
  --border: #e5e7eb;
  --border-light: #f0f0f2;
  --text: #2d3748;
  --text-sub: #718096;
  --text-light: #a0aec0;
  --white: #ffffff;
  --max-w: 1040px;

  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic ProN', sans-serif;
  color: var(--text);
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
}

/* ── Base Resets ── */
.proclia-page *, .proclia-page *::before, .proclia-page *::after {
  box-sizing: border-box;
}
.proclia-page img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ── Common Section Layout ── */
.proclia-page section { padding: 80px 24px; }
.proclia-page .inner { max-width: var(--max-w); margin: 0 auto; }

/* ── Section Labels / Titles ── */
.proclia-page .sec-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--text-light);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.proclia-page .sec-title {
  font-size: 24px;
  font-weight: 900;
  color: var(--navy);
  margin: 0 0 14px 0;
  line-height: 1.5;
}
.proclia-page .sec-desc {
  font-size: 15px;
  color: var(--text-sub);
  max-width: 600px;
  margin-bottom: 48px;
  line-height: 1.9;
}

/* ── Buttons ── */
.proclia-page .btn {
  display: inline-block;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  padding: 13px 28px;
  border-radius: 6px;
  transition: all 0.2s;
}
.proclia-page .btn-fill {
  background: var(--navy);
  color: var(--white);
}
.proclia-page .btn-fill:hover { background: var(--navy-mid); }
.proclia-page .btn-ghost {
  border: 1.5px solid var(--border);
  color: var(--text-sub);
  background: var(--white);
}
.proclia-page .btn-ghost:hover { border-color: var(--navy); color: var(--navy); }
.proclia-page .btn-buy {
  display: block;
  text-align: center;
  text-decoration: none;
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
  border: 1.5px solid var(--navy);
  padding: 11px;
  border-radius: 6px;
  transition: all 0.2s;
}
.proclia-page .btn-buy:hover { background: var(--navy); color: var(--white); }
.proclia-page .btn-buy .sub {
  display: block;
  font-size: 10px;
  font-weight: 400;
  color: var(--text-light);
  margin-top: 2px;
}
.proclia-page .btn-buy:hover .sub { color: rgba(255,255,255,0.6); }

/* ── CTA Section ── */
.proclia-page .cta {
  background: var(--navy);
  padding: 52px 24px;
  text-align: center;
}
.proclia-page .cta h2 {
  font-size: 22px;
  font-weight: 800;
  color: var(--white);
  margin: 0 0 10px 0;
}
.proclia-page .cta p {
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  margin: 0 0 24px 0;
}
.proclia-page .cta .btn-fill {
  background: var(--white);
  color: var(--navy);
  font-weight: 700;
}
.proclia-page .cta .btn-fill:hover { background: rgba(255,255,255,0.9); }

/* ── Page Title (technology, faq) ── */
.proclia-page .page-title {
  padding: 72px 24px 48px;
  background: linear-gradient(170deg, var(--white) 0%, var(--navy-pale) 50%, var(--white) 100%);
  text-align: center;
}
.proclia-page .page-title h1 {
  font-size: 30px;
  font-weight: 900;
  color: var(--navy);
  line-height: 1.5;
  margin: 0 0 12px 0;
}
.proclia-page .page-title .subtitle {
  font-size: 15px;
  color: var(--text-sub);
  line-height: 1.9;
  margin: 0;
}

/* ── Page Header (company, contact, stability) ── */
.proclia-page .page-header {
  padding: 48px 24px 40px;
}
.proclia-page .page-header-inner {
  max-width: 720px;
  margin: 0 auto;
}
.proclia-page .page-header h1 {
  font-size: 24px;
  font-weight: 900;
  color: var(--navy);
  margin: 0;
  line-height: 1.5;
}
.proclia-page .page-header p {
  font-size: 14px;
  color: var(--text-sub);
  margin: 0;
  line-height: 1.8;
}

/* ── Page Hero (about) ── */
.proclia-page .page-hero {
  padding: 80px 24px 64px;
  background: var(--warm-bg);
  text-align: center;
}
.proclia-page .page-hero-inner {
  max-width: 720px;
  margin: 0 auto;
}
.proclia-page .page-hero .breadcrumb {
  font-size: 12px;
  color: var(--text-light);
  margin-bottom: 32px;
}
.proclia-page .page-hero .breadcrumb a {
  color: var(--text-light);
  text-decoration: none;
}
.proclia-page .page-hero .breadcrumb a:hover {
  color: var(--text-sub);
}
.proclia-page .page-hero h1 {
  font-size: 28px;
  font-weight: 900;
  color: var(--navy);
  line-height: 1.5;
  margin: 0 0 16px 0;
  letter-spacing: 0.5px;
}
.proclia-page .page-hero .subtitle {
  font-size: 16px;
  color: var(--text-sub);
  font-weight: 400;
  line-height: 1.8;
  margin: 0;
}
.proclia-page .page-hero .hero-line {
  width: 40px;
  height: 2px;
  background: var(--accent);
  margin: 28px auto 0;
}

/* ── Breadcrumb (articles, stability) ── */
.proclia-page .breadcrumb {
  font-size: 12px;
  color: var(--text-light);
  margin-bottom: 20px;
}
.proclia-page .breadcrumb a { color: var(--text-light); text-decoration: none; }
.proclia-page .breadcrumb a:hover { color: var(--accent); }

/* ── Compare Box (index, products/kaigo) ── */
.proclia-page .compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.proclia-page .cmp-box {
  padding: 24px 20px;
  border-radius: 10px;
  text-align: center;
}
.proclia-page .cmp-box.ng {
  background: #faf5f5;
  border: 1px solid #e8dada;
}
.proclia-page .cmp-box.ok {
  background: var(--navy-pale);
  border: 1.5px solid var(--navy-mid);
}
.proclia-page .cmp-box .cmp-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-light);
  margin-bottom: 8px;
}
.proclia-page .cmp-box.ok .cmp-label { color: var(--navy-mid); }
.proclia-page .cmp-box h4 { font-size: 16px; font-weight: 800; margin: 0 0 10px 0; }
.proclia-page .cmp-box.ng h4 { color: #9b4d4d; }
.proclia-page .cmp-box.ok h4 { color: var(--navy); }
.proclia-page .cmp-box p { font-size: 12px; color: var(--text-sub); line-height: 1.7; margin: 0; }

/* ── Product Cards (index, products/kaigo) ── */
.proclia-page .prod-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.proclia-page .prod-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: box-shadow 0.3s;
}
.proclia-page .prod-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,0.06); }
.proclia-page .prod-img {
  height: 220px;
  background: var(--navy-pale);
  display: flex; align-items: center; justify-content: center;
  border-bottom: 1px solid var(--border);
  overflow: hidden;
}
.proclia-page .prod-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 16px;
}
.proclia-page .prod-body { padding: 24px; }
.proclia-page .prod-body h3 { font-size: 16px; font-weight: 700; margin: 0 0 4px 0; }
.proclia-page .prod-body .size { font-size: 13px; color: var(--text-sub); margin-bottom: 14px; }
.proclia-page .prod-body ul {
  list-style: none;
  margin: 0 0 20px 0;
  padding: 0;
}
.proclia-page .prod-body li {
  font-size: 12px;
  color: var(--text-sub);
  padding: 3px 0 3px 18px;
  position: relative;
}
.proclia-page .prod-body li::before {
  content: "";
  position: absolute;
  left: 0; top: 10px;
  width: 6px; height: 6px;
  background: var(--accent);
  border-radius: 50%;
}

/* ── Article Cards (index, products/kaigo) ── */
.proclia-page .art-section-title {
  font-size: 1.3rem;
  font-weight: 700;
  text-align: center;
  margin: 0 0 32px 0;
  color: var(--navy);
}
.proclia-page .art-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.proclia-page .art-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s, transform 0.2s;
  display: flex;
  flex-direction: column;
}
.proclia-page .art-card:hover {
  box-shadow: 0 6px 20px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.proclia-page .art-thumb {
  aspect-ratio: 3 / 2;
  background: var(--navy-pale);
  overflow: hidden;
  border-bottom: 1px solid var(--border);
}
.proclia-page .art-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.proclia-page .art-body {
  padding: 16px 18px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.proclia-page .art-body h3 {
  font-size: 14px;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 8px 0;
  color: var(--navy);
}
.proclia-page .art-body p {
  font-size: 12px;
  color: var(--text-sub);
  line-height: 1.7;
  margin: 0 0 12px 0;
  flex: 1;
}
.proclia-page .art-read {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 600;
  color: var(--navy);
  border: 1px solid var(--border);
  padding: 6px 14px;
  border-radius: 4px;
  align-self: flex-start;
  transition: background 0.2s;
}
.proclia-page .art-card:hover .art-read {
  background: var(--navy-pale);
}
.proclia-page .art-divider {
  width: 40px;
  height: 2px;
  background: var(--navy);
  margin: 40px auto;
}
.proclia-page .art-sub-title {
  font-size: 1.1rem;
  font-weight: 700;
  text-align: center;
  margin: 0 0 24px 0;
  color: var(--navy);
}
.proclia-page .art-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  color: var(--accent-dark);
  background: #eef5fa;
  padding: 2px 8px;
  border-radius: 3px;
  margin-bottom: 8px;
}

/* ── FAQ Styles (index, faq) ── */
.proclia-page .faq { background: var(--cool-bg); }
.proclia-page .faq-list { max-width: 680px; margin: 0 auto; }
.proclia-page .faq-item {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 10px;
  overflow: hidden;
  cursor: pointer;
}
.proclia-page .faq-q {
  padding: 18px 22px;
  font-size: 14px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: background 0.2s;
}
.proclia-page .faq-q:hover { background: var(--navy-pale); }
.proclia-page .faq-q .ql {
  flex: 0 0 24px; height: 24px;
  background: var(--navy);
  color: var(--white);
  border-radius: 4px;
  font-size: 11px;
  font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.proclia-page .faq-q .q-text { flex: 1; }
.proclia-page .faq-q .toggle {
  flex: 0 0 20px;
  font-size: 18px;
  color: var(--text-light);
  transition: transform 0.3s;
  text-align: center;
}
.proclia-page .faq-item.open .faq-q .toggle { transform: rotate(45deg); }
.proclia-page .faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.proclia-page .faq-item.open .faq-a { max-height: 500px; }
.proclia-page .faq-a-inner {
  padding: 0 22px 18px 58px;
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.9;
}
.proclia-page .faq-more { text-align: center; margin-top: 28px; }

/* ── Article Template (care articles) ── */
.proclia-page .article-header {
  background: var(--cool-bg);
  padding: 48px 24px 40px;
}
.proclia-page .article-header-inner {
  max-width: 720px;
  margin: 0 auto;
}
.proclia-page .article-tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-dark);
  background: var(--white);
  border: 1px solid var(--border);
  padding: 3px 10px;
  border-radius: 4px;
  margin-bottom: 14px;
}
.proclia-page .article-header h1 {
  font-size: 26px;
  font-weight: 900;
  line-height: 1.5;
  color: var(--navy);
  margin-bottom: 12px;
}
.proclia-page .article-meta {
  font-size: 12px;
  color: var(--text-light);
}
.proclia-page .eyecatch {
  width: 100%;
  border-radius: 12px;
  margin-top: 24px;
}

/* Article Body */
.proclia-page .article-body {
  max-width: 720px;
  margin: 0 auto;
  padding: 48px 24px 80px;
}
.proclia-page .article-body h2 {
  font-size: 20px;
  font-weight: 800;
  color: var(--navy);
  margin: 48px 0 16px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--navy-pale);
}
.proclia-page .article-body h3 {
  font-size: 17px;
  font-weight: 700;
  color: var(--navy);
  margin: 32px 0 12px;
}
.proclia-page .article-body p {
  font-size: 15px;
  color: var(--text);
  line-height: 2.0;
  margin-bottom: 20px;
}
.proclia-page .article-body strong { color: var(--navy); }

/* Callout */
.proclia-page .callout {
  background: var(--navy-pale);
  border-left: 3px solid var(--accent);
  border-radius: 0 8px 8px 0;
  padding: 24px 28px;
  margin: 28px 0;
}
.proclia-page .callout h4 {
  font-size: 14px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 8px;
}
.proclia-page .callout p {
  font-size: 14px;
  color: var(--text-sub);
  margin-bottom: 0;
}
.proclia-page .callout ul {
  margin: 8px 0 0;
  padding-left: 20px;
}
.proclia-page .callout li {
  font-size: 14px;
  color: var(--text-sub);
  padding: 3px 0;
}

/* Warning */
.proclia-page .warning {
  background: #fef7f0;
  border-left: 3px solid #e0a060;
  border-radius: 0 8px 8px 0;
  padding: 20px 24px;
  margin: 28px 0;
}
.proclia-page .warning h4 {
  font-size: 14px;
  font-weight: 700;
  color: #9a6a30;
  margin-bottom: 6px;
}
.proclia-page .warning p { font-size: 14px; color: var(--text-sub); margin-bottom: 0; }

/* Related Articles (care articles) */
.proclia-page .related {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px 60px;
}
.proclia-page .related h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 16px;
}
.proclia-page .related-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.proclia-page .rel-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  text-decoration: none;
  color: inherit;
  transition: box-shadow 0.2s;
}
.proclia-page .rel-card:hover { box-shadow: 0 3px 12px rgba(0,0,0,0.06); }
.proclia-page .rel-card .rel-tag {
  font-size: 10px;
  color: var(--accent-dark);
  font-weight: 600;
  margin-bottom: 6px;
}
.proclia-page .rel-card h4 {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.5;
  margin: 0;
}

/* Article Images */
.proclia-page .article-img {
  margin: 32px 0;
  text-align: center;
}
.proclia-page .article-img img {
  max-width: 100%;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.08);
}

/* Product CTA Bar (care articles) */
.proclia-page .product-bar {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 24px 60px;
}
.proclia-page .product-cta {
  background: var(--navy);
  border-radius: 12px;
  padding: 32px 36px;
  display: flex;
  align-items: center;
  gap: 24px;
}
.proclia-page .product-cta-text { flex: 1; }
.proclia-page .product-cta-text h4 { font-size: 15px; font-weight: 700; color: var(--white); margin: 0 0 4px 0; }
.proclia-page .product-cta-text p { font-size: 13px; color: rgba(255,255,255,0.6); margin: 0 0 16px 0; }
.proclia-page .btn-sm {
  display: inline-block;
  text-decoration: none;
  font-size: 12px;
  font-weight: 600;
  color: var(--navy);
  background: var(--white);
  padding: 8px 20px;
  border-radius: 5px;
  transition: all 0.2s;
}
.proclia-page .btn-sm:hover { background: rgba(255,255,255,0.9); }

/* ── Common Responsive ── */
@media (max-width: 768px) {
  .proclia-page .sec-title { font-size: 20px; }
  .proclia-page section { padding: 56px 20px; }

  /* Page Title */
  .proclia-page .page-title h1 { font-size: 22px; }

  /* Page Hero */
  .proclia-page .page-hero { padding: 56px 20px 48px; }
  .proclia-page .page-hero h1 { font-size: 22px; }
  .proclia-page .page-hero .subtitle { font-size: 14px; }

  /* Compare */
  /* (compare grid stays 2-col on mobile by default; pages can override) */

  /* Product Cards */
  .proclia-page .prod-grid { grid-template-columns: 1fr; }

  /* Article Cards */
  .proclia-page .art-grid { grid-template-columns: 1fr; }

  /* Article Template */
  .proclia-page .article-header h1 { font-size: 20px; }
  .proclia-page .article-body h2 { font-size: 18px; margin-top: 36px; }
  .proclia-page .article-body h3 { font-size: 16px; }
  .proclia-page .article-body p { font-size: 14px; }
  .proclia-page .related-cards { grid-template-columns: 1fr; }
  .proclia-page .product-cta { flex-direction: column; text-align: center; }
}

/* ── Dark Section Text Visibility Fix ── */
/* Navy background sections: ensure all text is white/light */
.proclia-page [style*="background: var(--navy)"] h2,
.proclia-page [style*="background: var(--navy)"] h3,
.proclia-page [style*="background: var(--navy)"] p,
.proclia-page [style*="background: var(--navy)"] li,
.proclia-page [style*="background: var(--navy)"] strong,
.proclia-page [style*="background: var(--navy)"] span,
.proclia-page .safety h2,
.proclia-page .safety h3,
.proclia-page .safety p,
.proclia-page .safety strong,
.proclia-page .safety .sec-title,
.proclia-page .safety .sec-desc,
.proclia-page .dual h2,
.proclia-page .dual h3,
.proclia-page .dual p,
.proclia-page .dual strong,
.proclia-page .dual .sec-title,
.proclia-page .dual .sec-desc,
.proclia-page .dual .big-num {
  color: var(--white) !important;
}
.proclia-page .safety .sec-label,
.proclia-page .dual .sec-label {
  color: rgba(255,255,255,0.5) !important;
}
.proclia-page .safety .sec-desc,
.proclia-page .dual .sec-desc {
  color: rgba(255,255,255,0.7) !important;
}
.proclia-page .dual .big-num {
  color: var(--accent) !important;
}
.proclia-page .dual .big-unit {
  color: rgba(255,255,255,0.8) !important;
}

/* ============================================
   Page-Specific Styles
   ============================================ */

/* ── Top Page ── */
.proclia-page .hero {
  padding: 80px 24px 72px;
  background: linear-gradient(170deg, #f8f9fc 0%, var(--navy-pale) 40%, #f0f2f8 100%);
  overflow: hidden;
}
.proclia-page .hero-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 56px;
}
.proclia-page .hero-text { flex: 1; }
.proclia-page .hero-label {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 2px;
  border: 1px solid var(--accent);
  padding: 3px 10px;
  border-radius: 3px;
  margin-bottom: 20px;
}
.proclia-page .hero h1 {
  font-size: 30px;
  font-weight: 900;
  line-height: 1.5;
  color: var(--navy);
  margin: 0 0 20px 0;
}
.proclia-page .hero h1 em {
  font-style: normal;
  color: var(--navy);
  background: linear-gradient(transparent 60%, rgba(74, 143, 186, 0.18) 60%);
  padding: 0 2px;
}
.proclia-page .hero-desc {
  font-size: 15px;
  color: var(--text-sub);
  margin-bottom: 32px;
  line-height: 2;
}
.proclia-page .hero-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.proclia-page .hero-img {
  flex: 0 0 360px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.proclia-page .hero-img::before {
  content: '';
  position: absolute;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(74, 143, 186, 0.08) 0%, rgba(26, 46, 80, 0.04) 60%, transparent 70%);
  z-index: 0;
}
.proclia-page .hero-img img {
  max-width: 280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 8px 24px rgba(26, 46, 80, 0.15));
}
.proclia-page .problem { background: var(--cool-bg); }
.proclia-page .prob-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.proclia-page .prob-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px 24px;
}
.proclia-page .prob-card .num {
  display: inline-block;
  width: 28px; height: 28px;
  background: var(--navy-pale);
  color: var(--navy);
  font-size: 12px;
  font-weight: 700;
  border-radius: 50%;
  text-align: center;
  line-height: 28px;
  margin-bottom: 14px;
}
.proclia-page .prob-card h3 { font-size: 15px; font-weight: 700; margin: 0 0 10px 0; color: var(--navy); }
.proclia-page .prob-card p { font-size: 13px; color: var(--text-sub); line-height: 1.8; margin: 0; }
.proclia-page .sol-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: start;
}
.proclia-page .sol-text h3 { font-size: 18px; font-weight: 800; color: var(--navy); margin: 0 0 14px 0; }
.proclia-page .sol-text > p { font-size: 14px; color: var(--text-sub); line-height: 1.9; margin: 0 0 20px 0; }
.proclia-page .steps { display: flex; flex-direction: column; gap: 10px; }
.proclia-page .step {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px;
  background: var(--navy-pale);
  border-radius: 8px;
}
.proclia-page .step .sn {
  flex: 0 0 26px; height: 26px;
  background: var(--navy);
  color: var(--white);
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.proclia-page .step .st { font-size: 13px; line-height: 1.6; }
.proclia-page .step .st strong { color: var(--navy); }
.proclia-page .trust {
  background: var(--navy);
  color: var(--white);
}
.proclia-page .trust .sec-label { color: var(--text-light); }
.proclia-page .trust .sec-title { color: var(--white); }
.proclia-page .trust .sec-desc { color: rgba(255,255,255,0.55); }
.proclia-page .trust-nums {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 36px;
}
.proclia-page .t-num {
  text-align: center;
  padding: 32px 16px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
}
.proclia-page .t-num .val {
  font-size: 44px;
  font-weight: 900;
  color: var(--white);
  line-height: 1;
}
.proclia-page .t-num .unit { font-size: 15px; color: rgba(255,255,255,0.6); font-weight: 600; }
.proclia-page .t-num .desc { font-size: 13px; color: rgba(255,255,255,0.4); margin-top: 8px; }
.proclia-page .trust-badges {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.proclia-page .badge {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  padding: 10px 16px;
  font-size: 12px;
  color: rgba(255,255,255,0.55);
  font-weight: 500;
}
.proclia-page .product { background: var(--warm-bg); }
@media (max-width: 768px) {
  .proclia-page .hero-inner { flex-direction: column-reverse; gap: 28px; text-align: center; }
  .proclia-page .hero-img { flex: none; }
  .proclia-page .hero-img::before { width: 220px; height: 220px; }
  .proclia-page .hero-img img { max-width: 180px; }
  .proclia-page .hero h1 { font-size: 22px; }
  .proclia-page .hero-actions { justify-content: center; }
  .proclia-page .prob-grid { grid-template-columns: 1fr; }
  .proclia-page .sol-layout { grid-template-columns: 1fr; }
  .proclia-page .trust-nums { grid-template-columns: 1fr; }
}

/* ── Product Page ── */
.proclia-page .hero h1 em {
  font-style: normal;
  color: var(--accent-dark);
  border-bottom: 2px solid var(--accent);
}
.proclia-page .problem-stmt {
  background: var(--cool-bg);
}
.proclia-page .problem-stmt .inner {
  max-width: 720px;
  text-align: center;
}
.proclia-page .problem-stmt .sec-desc {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
.proclia-page .why-fail .fail-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}
.proclia-page .fail-text h3 { font-size: 18px; font-weight: 800; color: var(--navy); margin: 0 0 14px 0; }
.proclia-page .fail-text p { font-size: 14px; color: var(--text-sub); line-height: 1.9; margin: 0 0 16px 0; }
.proclia-page .fail-text p:last-child { margin-bottom: 0; }
.proclia-page .reasons { background: var(--warm-bg); }
.proclia-page .reason-list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.proclia-page .reason-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 36px 40px;
  display: flex;
  align-items: flex-start;
  gap: 28px;
}
.proclia-page .reason-num {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.proclia-page .reason-num .label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 1px;
}
.proclia-page .reason-num .num {
  width: 40px; height: 40px;
  background: var(--navy);
  color: var(--white);
  font-size: 18px;
  font-weight: 900;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.proclia-page .reason-body { flex: 1; }
.proclia-page .reason-body h3 {
  font-size: 17px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 10px 0;
  line-height: 1.5;
}
.proclia-page .reason-body p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 1.9;
  margin: 0;
}
.proclia-page .reason-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 14px;
}
.proclia-page .reason-tag {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-dark);
  background: #eef5fa;
  padding: 4px 10px;
  border-radius: 4px;
}
.proclia-page .how-to { background: var(--cool-bg); }
.proclia-page .steps-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.proclia-page .step-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 36px 32px;
}
.proclia-page .step-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}
.proclia-page .step-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--navy);
  color: var(--white);
  font-size: 12px;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 6px;
  letter-spacing: 1px;
}
.proclia-page .step-card h3 {
  font-size: 17px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 12px 0;
}
.proclia-page .step-card p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 1.9;
  margin: 0 0 16px 0;
}
.proclia-page .use-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.proclia-page .use-list li {
  font-size: 13px;
  color: var(--text-sub);
  padding: 6px 0 6px 20px;
  position: relative;
  line-height: 1.7;
}
.proclia-page .use-list li::before {
  content: "";
  position: absolute;
  left: 0; top: 13px;
  width: 6px; height: 6px;
  background: var(--accent);
  border-radius: 50%;
}
.proclia-page .safety {
  background: var(--navy);
  color: var(--white);
}
.proclia-page .safety .sec-label { color: var(--text-light); }
.proclia-page .safety .sec-title { color: var(--white); }
.proclia-page .safety .sec-desc { color: rgba(255,255,255,0.55); }
.proclia-page .safety-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.proclia-page .safety-card {
  text-align: center;
  padding: 32px 20px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
}
.proclia-page .safety-icon {
  width: 48px; height: 48px;
  background: rgba(255,255,255,0.08);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
  font-size: 20px;
}
.proclia-page .safety-card h3 {
  font-size: 14px;
  font-weight: 700;
  color: var(--white);
  margin: 0 0 8px 0;
}
.proclia-page .safety-card p {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  line-height: 1.7;
  margin: 0;
}
.proclia-page .safety-note {
  text-align: center;
  margin-top: 28px;
  font-size: 12px;
  color: rgba(255,255,255,0.35);
}
.proclia-page .specs { background: var(--white); }
.proclia-page .spec-table {
  max-width: 680px;
  margin: 0 auto;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.proclia-page .spec-row {
  display: flex;
  border-bottom: 1px solid var(--border-light);
}
.proclia-page .spec-row:last-child { border-bottom: none; }
.proclia-page .spec-label {
  flex: 0 0 180px;
  background: var(--navy-pale);
  padding: 14px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
}
.proclia-page .spec-value {
  flex: 1;
  padding: 14px 20px;
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.7;
}
.proclia-page .art-card { border-radius: 10px; }
.proclia-page .art-body { padding: 18px 20px; }
.proclia-page .art-body h3 { margin: 0 0 6px 0; }
.proclia-page .art-body p { margin: 0; }
@media (max-width: 768px) {
  .proclia-page .why-fail .fail-layout { grid-template-columns: 1fr; }
  .proclia-page .steps-grid { grid-template-columns: 1fr; }
  .proclia-page .safety-grid { grid-template-columns: 1fr; }
  .proclia-page .reason-card { flex-direction: column; padding: 28px 24px; gap: 16px; }
  .proclia-page .spec-label { flex: 0 0 120px; font-size: 12px; padding: 12px 14px; }
  .proclia-page .spec-value { font-size: 12px; padding: 12px 14px; }
}

/* ── About Page ── */
.proclia-page .chapter {
  padding: 80px 24px;
}
.proclia-page .chapter-inner {
  max-width: 720px;
  margin: 0 auto;
}
.proclia-page .chapter-num {
  font-size: 64px;
  font-weight: 900;
  color: var(--border);
  line-height: 1;
  margin-bottom: 16px;
  letter-spacing: 2px;
}
.proclia-page .chapter-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  line-height: 1.6;
  margin: 0 0 32px 0;
}
.proclia-page .chapter p {
  font-size: 15px;
  color: var(--text-sub);
  line-height: 2.1;
  margin: 0 0 20px 0;
}
.proclia-page .chapter p:last-child {
  margin-bottom: 0;
}
.proclia-page .chapter-with-image {
  max-width: var(--max-w);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 56px;
  align-items: start;
}
.proclia-page .chapter-text {
  max-width: 720px;
}
.proclia-page .chapter-side-img {
  position: sticky;
  top: 100px;
}
.proclia-page .chapter-side-img img {
  width: 100%;
  border-radius: 16px;
}
.proclia-page .pull-quote {
  border-left: 3px solid var(--accent);
  padding: 20px 0 20px 28px;
  margin: 36px 0;
}
.proclia-page .pull-quote p {
  font-size: 17px !important;
  font-weight: 700;
  color: var(--navy) !important;
  line-height: 1.9 !important;
  margin-bottom: 0 !important;
}
.proclia-page .highlight {
  color: var(--navy);
  font-weight: 700;
}
.proclia-page .standards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
}
.proclia-page .standard-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 32px 24px;
  text-align: center;
  transition: box-shadow 0.3s;
}
.proclia-page .standard-card:hover {
  box-shadow: 0 6px 24px rgba(0,0,0,0.06);
}
.proclia-page .standard-card .card-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--navy);
  color: var(--white);
  font-size: 16px;
  font-weight: 800;
  border-radius: 50%;
  margin-bottom: 20px;
}
.proclia-page .standard-card h3 {
  font-size: 15px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 12px 0;
  line-height: 1.6;
}
.proclia-page .standard-card .card-detail {
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.9;
  margin: 0;
}
.proclia-page .chapter-wide {
  max-width: var(--max-w);
  margin: 0 auto;
}
.proclia-page .bg-white { background: var(--white); }
.proclia-page .bg-cool { background: var(--cool-bg); }
.proclia-page .bg-warm { background: var(--warm-bg); }
.proclia-page .cta { padding: 56px 24px; }
.proclia-page .cta p { margin: 0 0 28px 0; }
.proclia-page .cta-inner {
  max-width: 720px;
  margin: 0 auto;
}
.proclia-page .cta .closing-msg {
  font-size: 14px;
  color: rgba(255,255,255,0.4);
  margin: 0 0 24px 0;
  line-height: 1.9;
}
@media (max-width: 768px) {
  .proclia-page .chapter { padding: 56px 20px; }
  .proclia-page .chapter-num { font-size: 48px; }
  .proclia-page .chapter-title { font-size: 19px; margin-bottom: 24px; }
  .proclia-page .chapter p { font-size: 14px; }
  .proclia-page .chapter-with-image {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .proclia-page .chapter-side-img {
    position: static;
    order: -1;
  }
  .proclia-page .pull-quote { padding: 16px 0 16px 20px; margin: 28px 0; }
  .proclia-page .pull-quote p { font-size: 15px !important; }
  .proclia-page .standards-grid { grid-template-columns: 1fr; gap: 16px; }
  .proclia-page .standard-card { padding: 24px 20px; }
}

/* ── Technology Page ── */
.proclia-page .page-title { padding: 72px 24px 56px; }
.proclia-page .mech-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.proclia-page .mech-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 32px 24px;
  text-align: center;
}
.proclia-page .mech-card .icon {
  width: 48px;
  height: 48px;
  background: var(--navy-pale);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  font-size: 20px;
  color: var(--navy);
}
.proclia-page .mech-card h3 {
  font-size: 16px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 10px 0;
}
.proclia-page .mech-card p {
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.8;
  margin: 0;
}
.proclia-page .safety .sec-desc { max-width: 720px; }
.proclia-page .safety-intro {
  font-size: 14px;
  color: rgba(255,255,255,0.6);
  line-height: 2;
  max-width: 720px;
  margin-bottom: 40px;
}
.proclia-page .safety-intro p {
  margin: 0;
}
.proclia-page .safety-intro strong {
  color: rgba(255,255,255,0.9);
  font-weight: 700;
}
.proclia-page .safety-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.proclia-page .safety-card .test-name {
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  margin-bottom: 12px;
  font-weight: 500;
}
.proclia-page .safety-card .result {
  font-size: 18px;
  font-weight: 800;
  color: var(--white);
  margin-bottom: 6px;
}
.proclia-page .safety-card .classification {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  background: rgba(74,143,186,0.15);
  padding: 3px 10px;
  border-radius: 4px;
}
.proclia-page .safety-note {
  margin-top: 16px;
  margin-bottom: 40px;
}
.proclia-page .cert-img {
  text-align: center;
  margin-top: 24px;
}
.proclia-page .cert-img img {
  max-width: 100%;
  border-radius: 12px;
  margin: 0 auto;
}
.proclia-page .cert-caption {
  font-size: 12px;
  color: rgba(255,255,255,0.4);
  text-align: center;
  margin-top: 12px;
}
.proclia-page .disinfection { background: var(--warm-bg); }
.proclia-page .disinfection-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
.proclia-page .disinfection-text h3 {
  font-size: 18px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 16px 0;
  line-height: 1.6;
}
.proclia-page .disinfection-text p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 2;
  margin: 0 0 20px 0;
}
.proclia-page .use-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.proclia-page .use-tag {
  font-size: 12px;
  font-weight: 500;
  color: var(--navy-mid);
  background: var(--navy-pale);
  padding: 6px 14px;
  border-radius: 6px;
}
.proclia-page .disinfection-visual {
  text-align: center;
}
.proclia-page .big-number {
  font-size: 72px;
  font-weight: 900;
  color: var(--navy);
  line-height: 1;
}
.proclia-page .big-number .unit {
  font-size: 28px;
  font-weight: 700;
  color: var(--navy-mid);
}
.proclia-page .big-number-label {
  font-size: 14px;
  color: var(--text-sub);
  margin-top: 8px;
}
.proclia-page .stability { background: var(--cool-bg); }
.proclia-page .stability-box {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 48px;
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.proclia-page .stability-box h3 {
  font-size: 20px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 16px 0;
}
.proclia-page .stability-box p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 2;
  margin: 0 0 28px 0;
}
.proclia-page .link-arrow {
  display: inline-block;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent-dark);
  transition: color 0.2s;
}
.proclia-page .link-arrow:hover { color: var(--navy); }
.proclia-page .disclaimer {
  padding: 24px;
  text-align: center;
}
.proclia-page .disclaimer p {
  font-size: 11px;
  color: var(--text-light);
  margin: 0;
}
@media (max-width: 768px) {
  .proclia-page .mech-grid { grid-template-columns: 1fr; }
  .proclia-page .safety-grid { grid-template-columns: 1fr 1fr; }
  .proclia-page .disinfection-layout { grid-template-columns: 1fr; }
  .proclia-page .stability-box { padding: 32px 24px; }
  .proclia-page .big-number { font-size: 52px; }
}

/* ── Stability Page ── */
.proclia-page .narrow { max-width: 720px; margin: 0 auto; }
.proclia-page .breadcrumb {
  color: var(--text-sub);
  padding: 16px 24px 0;
  max-width: var(--max-w);
  margin: 0 auto;
}
.proclia-page .breadcrumb a { color: var(--accent); }
.proclia-page .breadcrumb a:hover { text-decoration: underline; }
.proclia-page .breadcrumb span { margin: 0 6px; color: var(--text-light); }
.proclia-page .page-header {
  text-align: center;
  padding: 56px 24px 48px;
  background: var(--cool-bg);
}
.proclia-page .page-header h1 { font-size: 28px; margin-bottom: 12px; }
.proclia-page .page-header p { font-size: 15px; }
.proclia-page .sec-title { font-size: 22px; margin: 0 0 16px 0; }
.proclia-page .sec-desc { margin: 0 0 40px 0; }
.proclia-page .big-number-section {
  background: var(--white);
  padding: 64px 24px;
}
.proclia-page .big-number {
  text-align: center;
}
.proclia-page .big-number .num {
  font-size: 80px;
  font-weight: 900;
  color: var(--accent);
  line-height: 1;
  letter-spacing: -2px;
}
.proclia-page .big-number .unit {
  font-size: 24px;
  font-weight: 700;
  color: var(--navy);
  margin-left: 4px;
}
.proclia-page .big-number .label {
  font-size: 14px;
  color: var(--text-sub);
  margin-top: 8px;
}
.proclia-page .content-block {
  margin-bottom: 48px;
}
.proclia-page .content-block h2 {
  font-size: 20px;
  font-weight: 900;
  color: var(--navy);
  margin: 0 0 16px 0;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--navy-pale);
}
.proclia-page .content-block h3 {
  font-size: 17px;
  font-weight: 700;
  color: var(--navy);
  margin: 32px 0 12px 0;
}
.proclia-page .content-block p {
  font-size: 15px;
  line-height: 2;
  margin: 0 0 16px 0;
}
.proclia-page .compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin: 32px 0;
}
.proclia-page .compare-card {
  border-radius: 10px;
  padding: 28px 24px;
  text-align: center;
}
.proclia-page .compare-card.problem {
  background: #fdf5f5;
  border: 1px solid #f0d5d5;
}
.proclia-page .compare-card.solution {
  background: #f0f7fb;
  border: 1px solid var(--accent);
}
.proclia-page .compare-card .card-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.proclia-page .compare-card.problem .card-label { color: #c0392b; }
.proclia-page .compare-card.solution .card-label { color: var(--accent-dark); }
.proclia-page .compare-card h4 {
  font-size: 18px;
  font-weight: 900;
  margin: 0 0 12px 0;
}
.proclia-page .compare-card.problem h4 { color: #c0392b; }
.proclia-page .compare-card.solution h4 { color: var(--accent-dark); }
.proclia-page .compare-card p {
  font-size: 13px;
  line-height: 1.8;
  color: var(--text-sub);
  margin: 0;
}
.proclia-page .steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 32px 0;
}
.proclia-page .step-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 24px 20px;
  text-align: center;
}
.proclia-page .step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--navy);
  color: var(--white);
  border-radius: 50%;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 12px;
}
.proclia-page .step-card h4 {
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px 0;
}
.proclia-page .step-card p {
  font-size: 13px;
  color: var(--text-sub);
  line-height: 1.7;
  margin: 0;
}
.proclia-page .callout {
  background: var(--cool-bg);
  border-left-width: 4px;
  padding: 20px 24px;
  margin: 24px 0;
}
.proclia-page .cta { padding: 64px 24px; }
.proclia-page .cta .btn {
  display: inline-block;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  padding: 13px 28px;
  border-radius: 6px;
  background: var(--white);
  color: var(--navy);
  transition: all 0.2s;
}
.proclia-page .cta .btn:hover {
  background: var(--navy-pale);
}
.proclia-page .disclaimer {
  background: var(--warm-bg);
  padding: 40px 24px;
}
.proclia-page .disclaimer p {
  max-width: var(--max-w);
  margin: 0 auto;
  font-size: 11px;
  color: var(--text-light);
  line-height: 1.8;
}
@media (max-width: 768px) {
  .proclia-page .page-header { padding: 40px 16px 36px; }
  .proclia-page .page-header h1 { font-size: 22px; }
  .proclia-page .sec-title { font-size: 19px; }
  .proclia-page .big-number .num { font-size: 56px; }
  .proclia-page .big-number .unit { font-size: 18px; }
  .proclia-page .compare-grid { grid-template-columns: 1fr; }
  .proclia-page .steps { grid-template-columns: 1fr; }
  .proclia-page .content-block h2 { font-size: 18px; }
}

/* ── FAQ Page ── */
.proclia-page .page-title .subtitle { margin-bottom: 24px; }
.proclia-page .page-title .intro {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 2;
  max-width: 640px;
  margin: 0 auto;
}
.proclia-page .faq-section { padding: 56px 24px; }
.proclia-page .faq-section:nth-child(even) { background: var(--cool-bg); }
.proclia-page .faq-container { max-width: 720px; margin: 0 auto; }
.proclia-page .faq-category {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--text-light);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.proclia-page .faq-category-title {
  font-size: 20px;
  font-weight: 900;
  color: var(--navy);
  margin: 0 0 28px 0;
  line-height: 1.5;
}
.proclia-page .faq-list { display: flex; flex-direction: column; gap: 10px; }
.proclia-page .faq-item { overflow: hidden; }
.proclia-page .faq-q {
  cursor: pointer;
  user-select: none;
  transition: background 0.15s;
}
.proclia-page .faq-q:hover { background: var(--navy-pale); }
.proclia-page .faq-q .ql {
  flex: 0 0 26px; height: 26px;
  border-radius: 5px;
  font-size: 12px;
}
.proclia-page .faq-q .q-text { flex: 1; padding-top: 2px; }
.proclia-page .faq-q .toggle {
  flex: 0 0 20px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--text-light);
  transition: transform 0.25s;
}
.proclia-page .faq-item.open .faq-q .toggle { transform: rotate(45deg); }
.proclia-page .faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  padding: 0;
}
.proclia-page .faq-item.open .faq-a { max-height: 400px; }
.proclia-page .faq-a-inner {
  padding: 0 22px 20px 60px;
  font-size: 13px;
  color: var(--text-sub);
  line-height: 2;
}
@media (max-width: 768px) {
  .proclia-page .faq-container { max-width: 100%; }
  .proclia-page .faq-category-title { font-size: 18px; }
  .proclia-page .faq-section { padding: 40px 20px; }
}

/* ── Company Page ── */
.proclia-page .content {
  max-width: 720px;
  margin: 0 auto;
  padding: 48px 24px 80px;
}
.proclia-page .company-table {
  width: 100%;
  border-collapse: collapse;
  margin: 24px 0;
}
.proclia-page .company-table th,
.proclia-page .company-table td {
  padding: 16px 20px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-size: 14px;
}
.proclia-page .company-table th {
  width: 140px;
  font-weight: 600;
  color: var(--navy);
  background: var(--cool-bg);
  white-space: nowrap;
}
.proclia-page .company-table td {
  color: var(--text-sub);
}
.proclia-page .company-table a {
  color: var(--accent);
  text-decoration: none;
}
.proclia-page .company-table a:hover {
  text-decoration: underline;
}
@media (max-width: 768px) {
  .proclia-page .company-table th { width: 100px; }
}

/* ── Contact Page ── */
.proclia-page .page-header h1 { margin-bottom: 8px; }
.proclia-page .info-box {
  background: var(--cool-bg);
  border-radius: 10px;
  padding: 24px 28px;
  margin-bottom: 32px;
}
.proclia-page .info-box h3 { font-size: 14px; font-weight: 700; color: var(--navy); margin: 0 0 8px 0; }
.proclia-page .info-box p, .proclia-page .info-box li { font-size: 13px; color: var(--text-sub); line-height: 1.8; }
.proclia-page .info-box ul { margin: 8px 0 0 0; padding-left: 18px; }
.proclia-page .info-box a { color: var(--accent); text-decoration: none; }
.proclia-page .form-group { margin-bottom: 24px; }
.proclia-page .form-group label { display: block; font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 6px; }
.proclia-page .form-group .required { color: #c55; font-size: 11px; margin-left: 4px; }
.proclia-page .form-group input,
.proclia-page .form-group textarea,
.proclia-page .form-group select {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 14px;
  font-family: inherit;
  color: var(--text);
  background: var(--white);
  transition: border 0.2s;
}
.proclia-page .form-group input:focus,
.proclia-page .form-group textarea:focus { outline: none; border-color: var(--accent); }
.proclia-page .form-group textarea { min-height: 160px; resize: vertical; }
.proclia-page .btn-submit {
  display: inline-block;
  background: var(--navy);
  color: var(--white);
  font-size: 14px;
  font-weight: 600;
  padding: 14px 40px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.2s;
}
.proclia-page .btn-submit:hover { background: var(--navy-mid); }

/* ── QR Support Page ── */
.proclia-page .qr-hero {
  background: linear-gradient(170deg, var(--navy-pale) 0%, var(--white) 100%);
  padding: 48px 24px 40px;
  text-align: center;
}
.proclia-page .qr-hero-inner {
  max-width: 640px;
  margin: 0 auto;
}
.proclia-page .qr-hero h1 {
  font-size: 24px;
  font-weight: 900;
  color: var(--navy);
  margin: 0 0 10px 0;
}
.proclia-page .qr-hero p {
  font-size: 14px;
  color: var(--text-sub);
  line-height: 1.8;
  margin: 0 0 28px 0;
}
.proclia-page .qr-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}
.proclia-page .qr-action-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  padding: 14px 28px;
  border-radius: 6px;
  transition: all 0.2s;
}
.proclia-page .qr-action-btn.primary {
  background: var(--navy);
  color: var(--white);
}
.proclia-page .qr-action-btn.primary:hover { background: var(--navy-mid); }
.proclia-page .qr-action-btn.secondary {
  background: var(--white);
  color: var(--navy);
  border: 1.5px solid var(--navy);
}
.proclia-page .qr-action-btn.secondary:hover { background: var(--navy-pale); }
.proclia-page .qr-action-btn.line {
  background: #06C755;
  color: var(--white);
}
.proclia-page .qr-action-btn.line:hover { background: #05b04c; }
.proclia-page .tips-section { max-width: 640px; margin: 0 auto; }
.proclia-page .tip {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px 24px;
  margin-bottom: 12px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
}
.proclia-page .tip-num {
  flex: 0 0 32px; height: 32px;
  background: var(--navy);
  color: var(--white);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800;
}
.proclia-page .tip-body h3 {
  font-size: 14px; font-weight: 700; color: var(--navy); margin: 0 0 4px 0;
}
.proclia-page .tip-body p {
  font-size: 13px; color: var(--text-sub); line-height: 1.8; margin: 0;
}
.proclia-page .tip-body .hl {
  display: inline;
  background: #fef3c7;
  padding: 0 3px;
  border-radius: 2px;
  font-weight: 600;
  color: var(--text);
}
.proclia-page .tip-note {
  font-size: 11px; color: var(--text-light); margin-top: 4px;
}
.proclia-page .safety-section { background: #f0f7f4; }
.proclia-page .safety-inner { max-width: 640px; margin: 0 auto; }
.proclia-page .safety-section .safety-card {
  background: var(--white);
  border: 1px solid #c6e0d2;
  border-radius: 8px;
  padding: 16px 20px;
  margin-bottom: 10px;
}
.proclia-page .safety-section .safety-card .q { font-size: 13px; font-weight: 700; color: #4a8a6a; margin: 0 0 6px 0; }
.proclia-page .safety-section .safety-card .a { font-size: 13px; color: var(--text-sub); line-height: 1.8; margin: 0; }
.proclia-page .safety-badges {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px; justify-content: center;
}
.proclia-page .s-badge {
  font-size: 11px; font-weight: 600; color: #4a8a6a;
  background: var(--white); border: 1px solid #c6e0d2;
  padding: 5px 10px; border-radius: 4px;
}
.proclia-page .contact-section { background: var(--cool-bg); }
.proclia-page .contact-inner { max-width: 640px; margin: 0 auto; }
.proclia-page .guarantee-box {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px 20px;
  margin-bottom: 24px;
  text-align: center;
}
.proclia-page .guarantee-box h3 { font-size: 14px; font-weight: 700; color: var(--navy); margin: 0 0 6px 0; }
.proclia-page .guarantee-box p { font-size: 13px; color: var(--text-sub); line-height: 1.8; margin: 0; }
.proclia-page .line-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 14px;
  background: #06C755;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  padding: 10px 24px;
  border-radius: 6px;
  text-decoration: none;
  transition: background 0.2s;
}
.proclia-page .line-btn:hover { background: #05b04c; }
.proclia-page .form-group .req { color: #c55; font-size: 11px; margin-left: 4px; }
.proclia-page .qr-kaigo .form-group input,
.proclia-page .qr-kaigo .form-group textarea,
.proclia-page .qr-kaigo .form-group select {
  padding: 11px 14px;
}
.proclia-page .qr-kaigo .form-group textarea { min-height: 100px; }
.proclia-page .qr-kaigo .btn-submit {
  display: block; width: 100%;
}
@media (max-width: 768px) {
  .proclia-page .qr-hero { padding: 36px 20px 32px; }
  .proclia-page .qr-hero h1 { font-size: 20px; }
  .proclia-page .qr-actions { flex-direction: column; gap: 10px; }
  .proclia-page .qr-action-btn { justify-content: center; }
}
