/* Design Philosophy: Editorial Civic Design for service explanation. Support understanding through clean cards and guided comparison. */
  .wp-block-post-content *, .wp-block-post-content *::before, .wp-block-post-content *::after { box-sizing: border-box; }
  .wp-block-post-content h1,
  .wp-block-post-content h2,
  .wp-block-post-content h3,
  .wp-block-post-content h4,
  .wp-block-post-content h5,
  .wp-block-post-content h6,
  .wp-block-post-content p,
  .wp-block-post-content ul,
  .wp-block-post-content ol { margin: 0; }
  .wp-block-post-content > p:empty { display: none; }
  .wp-block-post-content .menu-cards > p,
  .wp-block-post-content .menu-cards > br,
  .wp-block-post-content .pco-note-head > p,
  .wp-block-post-content .pco-note-head > br,
  .wp-block-post-content .usecase-layout > p,
  .wp-block-post-content .usecase-layout > br,
  .wp-block-post-content section[style*="f8f8f8"] div[style*="grid-template-columns:1fr 80px 1fr"] > p,
  .wp-block-post-content section[style*="f8f8f8"] div[style*="grid-template-columns:1fr 80px 1fr"] > br {
    display: none !important;
  }
  :root { --orange: #E87722; --orange-dark: #c9621a; --orange-light: #fdf0e6; --green: #4a7c59; --green-light: #e8f5e9; --gray-light: #f5f5f5; --gray: #888; --text: #2c2c2c; }
  .mockup-banner { background: #1a1a2e; color: #fff; text-align: center; padding: 12px; font-size: 13px; font-weight: 600; letter-spacing: 0.05em; position: sticky; top: 64px; z-index: 99; }
    .mockup-banner span { color: var(--orange); }
    .page-nav { background: #f0f0f0; padding: 16px 80px; display: flex; gap: 8px; align-items: center; font-size: 12px; color: #888; border-bottom: 1px solid #ddd; }
    .page-nav-links { display: flex; gap: 12px; margin-left: auto; }
    .page-nav-links a { background: var(--orange); color: #fff; padding: 6px 16px; border-radius: 20px; font-size: 12px; font-weight: 700; }
    .page-nav-links a.inactive { background: #ddd; color: #888; }
    .page-hero { margin-top: 0px; background: linear-gradient(135deg, #1a1a2e 0%, #2d2d4e 100%); color: #fff; padding: 80px 0 60px; position: relative; overflow: hidden; }
    .page-hero::before { content: ''; position: absolute; top: -50%; right: -10%; width: 500px; height: 500px; background: var(--orange); opacity: 0.08; border-radius: 50%; }
    .breadcrumb { font-size: 12px; color: rgba(255,255,255,0.5); margin-bottom: 20px; }
    .breadcrumb a { color: rgba(255,255,255,0.7); }
    .page-hero-tag { display: inline-block; background: var(--orange); color: #fff; font-size: 11px; font-weight: 700; letter-spacing: 0.1em; padding: 4px 12px; border-radius: 20px; margin-bottom: 16px; }
    .page-hero h1 { font-size: 36px; font-weight: 900; line-height: 1.3; margin-bottom: 16px; }
    .page-hero p { font-size: 15px; color: rgba(255,255,255,0.75); max-width: 600px; line-height: 1.9; }
    .wp-block-post-content .container { width: min(calc(100% - 160px), var(--container)); margin: 0 auto; }
    .wp-block-post-content section { padding: 80px 0; }
    .section-tag { font-size: 11px; font-weight: 700; letter-spacing: 0.15em; color: var(--orange); text-transform: uppercase; margin-bottom: 12px; }
    .section-title { font-size: 28px; font-weight: 900; color: var(--text); line-height: 1.4; margin-bottom: 16px; }
    .section-desc { font-size: 15px; color: #555; line-height: 1.9; margin-bottom: 48px !important; }
    .btn-primary { background: var(--orange); color: #fff; padding: 14px 32px; border-radius: 30px; font-size: 14px; font-weight: 700; transition: background 0.2s, transform 0.2s; display: inline-flex; align-items: center; gap: 8px; }
    .btn-primary:hover { background: var(--orange-dark); transform: translateY(-2px); }
    .page-hero-summary { margin-top: 28px; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; max-width: 920px; }
    .page-hero-summary-item { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.14); border-radius: 16px; padding: 18px 18px 16px; backdrop-filter: blur(6px); }
    .page-hero-summary-item .label { display: block; font-size: 11px; letter-spacing: 0.08em; color: rgba(255,255,255,0.58); margin-bottom: 8px; font-weight: 700; text-transform: uppercase; }
    .page-hero-summary-item p { font-size: 14px; color: #fff; line-height: 1.75; max-width: none; }
    /* New Phase Banner */
    .new-phase { background: linear-gradient(135deg, var(--orange), var(--orange-dark)); color: #fff; padding: 40px 0; }
    .new-phase-inner { width: min(calc(100% - 160px), var(--container)); margin: 0 auto; }
    .new-phase-tag { font-size: 11px; font-weight: 700; letter-spacing: 0.1em; background: rgba(255,255,255,0.2); padding: 4px 12px; border-radius: 20px; display: inline-block; margin-bottom: 16px; }
    .new-phase h2 { font-size: 24px; font-weight: 900; margin-bottom: 16px; }
    .new-phase p { font-size: 14px; color: rgba(255,255,255,0.9); line-height: 1.8; margin-bottom: 24px; }
    .phase-compare { display: grid; grid-template-columns: 1fr auto 1fr; gap: 16px; align-items: center; background: rgba(255,255,255,0.1); border-radius: 12px; padding: 24px; }
    .phase-box { text-align: center; }
    .phase-box .phase-label { font-size: 11px; opacity: 0.7; margin-bottom: 8px; }
    .phase-box .phase-title { font-size: 16px; font-weight: 800; }
    .phase-box .phase-desc { font-size: 12px; opacity: 0.85; margin-top: 8px; line-height: 1.6; }
    .phase-arrow { font-size: 32px; text-align: center; }
    /* Service Menu */
    .service-menu { background: #fff; }
    .menu-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
    .menu-card { border: 1px solid rgba(0,0,0,0.06); border-radius: 18px; overflow: hidden; transition: box-shadow 0.2s, transform 0.2s; box-shadow: 0 14px 36px rgba(26,26,46,0.06); }
    .menu-card:hover { box-shadow: 0 12px 34px rgba(232,119,34,0.14); transform: translateY(-4px); }
    .menu-card-header { background: linear-gradient(135deg, var(--orange) 0%, #f08b40 100%); color: #fff; padding: 22px 24px; display: flex; align-items: center; gap: 16px; }
    .menu-card-num { width: 42px; height: 42px; background: rgba(255,255,255,0.18); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; font-weight: 900; flex-shrink: 0; }
    .menu-card-header-text h3 { font-size: 18px; font-weight: 800; }
    .menu-card-header-text p { font-size: 13px; opacity: 0.88; margin-top: 4px; }
    .menu-card-body { padding: 26px 24px 24px; }
    .menu-card-body p { font-size: 14px; color: #555; line-height: 1.9; margin-bottom: 18px; }
    .menu-detail-list { list-style: none; }
    .menu-detail-list li { font-size: 14px; color: #666; padding: 9px 0; border-bottom: 1px solid #f2ece7; display: flex; align-items: flex-start; gap: 8px; line-height: 1.8; }
    .menu-detail-list li::before { content: '✓'; color: var(--orange); font-weight: 700; flex-shrink: 0; margin-top: 2px; }
    .pco-note { margin-bottom: 40px; background: linear-gradient(135deg, #fff8f3 0%, #ffffff 100%); border: 1px solid rgba(232,119,34,0.16); border-radius: 24px; padding: 36px; box-shadow: 0 16px 40px rgba(26,26,46,0.05); }
    .pco-note-head { display: grid; grid-template-columns: minmax(0, 1.15fr) minmax(260px, 0.85fr); gap: 32px; align-items: start; }
    .pco-note-copy { font-size: 15px; color: #555; line-height: 1.95; }
    .pco-note-copy strong { color: var(--text); }
    .pco-pattern-box { background: #fff; border-radius: 18px; padding: 22px; border: 1px solid rgba(232,119,34,0.12); }
    .pco-pattern-box h3 { font-size: 16px; font-weight: 800; margin-bottom: 14px; color: var(--text); }
    .pco-pattern-list { list-style: none; display: grid; gap: 10px; }
    .pco-pattern-list li { font-size: 14px; line-height: 1.7; color: #444; padding: 10px 12px; background: #fff8f2; border-radius: 12px; border: 1px solid rgba(232,119,34,0.08); }
    .pco-target { margin-top: 20px; padding-top: 20px; border-top: 1px solid rgba(232,119,34,0.14); font-size: 14px; line-height: 1.85; color: #5a534c; }
    .usecase-section { background: #f8f6f3; }
    .usecase-layout { display: grid; grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr); gap: 32px; align-items: stretch; }
    .usecase-card,
    .inquiry-card { background: #fff; border-radius: 20px; padding: 34px; box-shadow: 0 14px 32px rgba(26,26,46,0.05); border: 1px solid rgba(0,0,0,0.05); }
    .usecase-card h3,
    .inquiry-card h3 { font-size: 22px; font-weight: 800; margin-bottom: 14px; color: var(--text); }
    .usecase-card p,
    .inquiry-card p { font-size: 14px; color: #555; line-height: 1.9; }
    .usecase-link { display: inline-flex; align-items: center; gap: 8px; margin-top: 18px; color: var(--orange); font-size: 14px; font-weight: 800; }
    .inquiry-lead { display: inline-block; font-size: 11px; letter-spacing: 0.12em; font-weight: 700; color: var(--orange); margin-bottom: 14px; text-transform: uppercase; }
    .inquiry-points { margin: 18px 0 24px; padding-left: 18px; color: #555; }
    .inquiry-points li { font-size: 14px; line-height: 1.85; margin-bottom: 8px; }
    @media (max-width: 1100px) {
      .page-hero-summary,
      .usecase-layout,
      .pco-note-head,
      .menu-cards { grid-template-columns: 1fr; }
      .new-phase-inner,
      .wp-block-post-content .container { width: min(calc(100% - 64px), var(--container)); }
      .page-hero { padding: 88px 0 60px; }
    }

    @media (max-width: 767px) {
      .wp-block-post-content { font-size: 12px; }
      .page-nav { display: none; }
      .wp-block-post-content .container,
      .new-phase-inner { width: calc(100% - 40px); }
      .page-hero { margin-top: 0 !important; padding: 72px 0 48px; }
      .page-hero h1 { font-size: 30px; }
      .page-hero p,
      .section-desc,
      .menu-card-body p,
      .menu-detail-list li,
      .usecase-card p,
      .inquiry-card p,
      .inquiry-points li,
      .pco-note-copy,
      .pco-target { font-size: 12px; }
      .section-title { font-size: 24px; }
      .page-hero-summary-item,
      .pco-note,
      .usecase-card,
      .inquiry-card,
      .menu-card-body { padding: 22px; }
      .menu-card-header { padding: 18px 20px; }
      .menu-card-header-text h3 { font-size: 16px; }
      .menu-card-header-text p,
      .page-hero-summary-item .label,
      .inquiry-lead { font-size: 11px; }

      /* Inline-style infographic blocks need explicit mobile overrides. */
      section[style*="f8f8f8"] > .container > div[style*="padding:36px"] {
        padding: 20px !important;
      }
      section[style*="f8f8f8"] div[style*="grid-template-columns:1fr 80px 1fr"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
      }
      section[style*="f8f8f8"] div[style*="width:200px; height:200px"] {
        width: 168px !important;
        height: 168px !important;
      }
      section[style*="f8f8f8"] svg[width="60"][height="40"] {
        transform: rotate(90deg);
      }

      .phase-compare { grid-template-columns: 1fr; }
      .phase-arrow { transform: rotate(90deg); }
    }

/* 矢印の位置の修正（スマホ） */
@media (max-width: 500px) {
	
	/* ↓ */
	.area-support-arrow-01 {
		top: 24px !important;
		left: 45% !important;
	}
	
	/* ↗ */
	.area-support-arrow-02 {
		top: 24% !important;
		left: 62% !important;
	}
	
	/* ↘ */
	.area-support-arrow-03 {
		top: 56% !important;
		left: 62% !important;
	}
	
	/* ↙ */
	.area-support-arrow-04 {
		top: 56% !important;
		left: 28% !important;
	}
}