/* ==========================================================================
   Digital Bank - Inner Pages CSS
   ========================================================================== */

.db-page #site_wrap, .db-page #header, .db-page #footer,
.db-page #site_loader_overlay, .db-page #site_loader_spinner,
.db-page #return_top, .db-page #wpadminbar ~ #header { display: none !important; }

.db-page-hero {
  position: relative; height: 340px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; margin-top: 70px;
}
.db-page-hero-bg {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, var(--db-dark) 0%, #141832 50%, var(--db-dark) 100%); z-index: 0;
}
.db-page-hero-bg::after {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 20% 50%, rgba(230, 57, 70, 0.08) 0%, transparent 50%),
    radial-gradient(circle at 80% 30%, rgba(0, 212, 170, 0.06) 0%, transparent 50%);
}

/* --- Page-specific Hero Images --- */
.page-template-page-company-php .db-page-hero-bg {
  background: url(https://db.fujiheights-group.co.jp/wp-content/uploads/2025/09/AdobeStock_1208404801-scaled.jpeg) center/cover no-repeat;
}
.page-template-page-mission-php .db-page-hero-bg {
  background: url(https://db.fujiheights-group.co.jp/wp-content/uploads/2025/09/AdobeStock_1414838627-scaled.jpeg) center/cover no-repeat;
}
.page-template-page-services-php .db-page-hero-bg {
  background: url(https://db.fujiheights-group.co.jp/wp-content/uploads/2025/09/AdobeStock_1170547775-scaled.jpeg) center/cover no-repeat;
}
.page-template-page-recruit-php .db-page-hero-bg {
  background: url(https://db.fujiheights-group.co.jp/wp-content/uploads/2025/09/AdobeStock_827288705-scaled.jpeg) center/cover no-repeat;
}
.page-template-page-contact-php .db-page-hero-bg {
  background: url(https://db.fujiheights-group.co.jp/wp-content/uploads/2025/09/AdobeStock_495079516-scaled.jpeg) center/cover no-repeat;
}
.page-template-page-privacy-policy-php .db-page-hero-bg {
  background: url(https://db.fujiheights-group.co.jp/wp-content/uploads/2025/09/AdobeStock_1208404801-scaled.jpeg) center/cover no-repeat;
}

/* Dark overlay on hero images */
.page-template-page-company-php .db-page-hero-bg::after,
.page-template-page-mission-php .db-page-hero-bg::after,
.page-template-page-services-php .db-page-hero-bg::after,
.page-template-page-recruit-php .db-page-hero-bg::after,
.page-template-page-contact-php .db-page-hero-bg::after,
.page-template-page-privacy-policy-php .db-page-hero-bg::after {
  background: linear-gradient(135deg, rgba(10, 14, 26, 0.55) 0%, rgba(20, 24, 50, 0.45) 50%, rgba(10, 14, 26, 0.55) 100%);
}

.db-page-hero-content { position: relative; z-index: 1; text-align: center; }
.db-page-hero-content h1 {
  font-family: 'Space Grotesk', 'Noto Sans JP', sans-serif;
  font-size: 2.8rem; font-weight: 700; color: #fff;
  letter-spacing: 0.08em; margin: 0 0 16px;
}
.db-breadcrumb { font-size: 0.85rem; color: rgba(255, 255, 255, 0.5); }
.db-breadcrumb a { color: rgba(255, 255, 255, 0.6); text-decoration: none; transition: color 0.3s; }
.db-breadcrumb a:hover { color: var(--db-accent); }
.db-breadcrumb-sep { margin: 0 8px; }

.db-page-content { max-width: 900px; margin: 0 auto; padding: 80px 24px; }
.db-page-content-wide { max-width: 1100px; margin: 0 auto; padding: 80px 24px; }

.db-page-label {
  font-family: 'Space Grotesk', sans-serif; font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--db-primary); margin-bottom: 12px;
}
.db-page-section-title {
  font-family: 'Space Grotesk', 'Noto Sans JP', sans-serif;
  font-size: 1.8rem; font-weight: 700; color: #fff;
  margin-bottom: 20px; position: relative; padding-bottom: 16px;
}
.db-page-section-title::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 50px; height: 3px; background: var(--db-primary); border-radius: 2px;
}
.db-page-section-title.center { text-align: center; }
.db-page-section-title.center::after { left: 50%; transform: translateX(-50%); }

.db-prose { font-family: 'Noto Sans JP', 'Inter', sans-serif; font-size: 1rem; line-height: 2; color: rgba(255, 255, 255, 0.75); margin-bottom: 40px; }
.db-prose p { margin-bottom: 1.5em; }
.db-prose strong { color: #fff; font-weight: 600; }

.db-info-table { width: 100%; border-collapse: collapse; margin: 40px 0; }
.db-info-table tr { border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.db-info-table th { font-family: 'Noto Sans JP', sans-serif; font-weight: 600; color: rgba(255, 255, 255, 0.9); text-align: left; padding: 20px 24px 20px 0; width: 180px; vertical-align: top; font-size: 0.95rem; white-space: nowrap; }
.db-info-table td { color: rgba(255, 255, 255, 0.7); padding: 20px 0; font-size: 0.95rem; line-height: 1.8; }

.db-map-wrap { margin: 40px 0; border-radius: 12px; overflow: hidden; position: relative; padding-top: 45%; background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); }
.db-map-wrap iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; filter: grayscale(0.8) invert(0.92) contrast(0.9); }
.db-map-link { display: inline-block; margin-top: 12px; font-size: 0.85rem; color: var(--db-accent); text-decoration: none; transition: opacity 0.3s; }
.db-map-link:hover { opacity: 0.7; }

.db-glass-card { background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); border-radius: 16px; padding: 40px; margin-bottom: 32px; transition: border-color 0.3s, transform 0.3s; }
.db-glass-card:hover { border-color: rgba(230, 57, 70, 0.2); transform: translateY(-2px); }

.db-mission-statement { font-family: 'Noto Sans JP', sans-serif; font-size: 1.6rem; font-weight: 700; line-height: 1.8; color: #fff; text-align: center; margin: 0 auto 60px; max-width: 800px; position: relative; padding: 40px 0; }
.db-mission-statement::before, .db-mission-statement::after { content: ''; position: absolute; width: 60px; height: 3px; background: linear-gradient(90deg, var(--db-primary), var(--db-accent)); left: 50%; transform: translateX(-50%); border-radius: 2px; }
.db-mission-statement::before { top: 0; }
.db-mission-statement::after { bottom: 0; }

.db-service-detail { display: grid; grid-template-columns: 1fr; gap: 40px; margin-bottom: 60px; }
.db-service-detail-card { background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); border-radius: 16px; padding: 48px; transition: border-color 0.3s; }
.db-service-detail-card:hover { border-color: rgba(230, 57, 70, 0.2); }
.db-service-detail-card h3 { font-family: 'Space Grotesk', sans-serif; font-size: 1.4rem; font-weight: 700; color: #fff; margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.db-service-detail-card h3 .db-service-num { font-size: 0.75rem; font-weight: 600; color: var(--db-primary); border: 1px solid var(--db-primary); border-radius: 50%; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.db-service-detail-card p { color: rgba(255, 255, 255, 0.7); line-height: 1.9; margin-bottom: 20px; }
.db-service-detail-card ul { list-style: none; padding: 0; margin: 24px 0 0; }
.db-service-detail-card ul li { position: relative; padding-left: 20px; color: rgba(255, 255, 255, 0.7); margin-bottom: 12px; line-height: 1.7; }
.db-service-detail-card ul li::before { content: ''; position: absolute; left: 0; top: 10px; width: 8px; height: 8px; border-radius: 50%; background: var(--db-primary); }

.db-advisory-section { background: rgba(255, 255, 255, 0.02); border: 1px solid rgba(255, 255, 255, 0.06); border-radius: 16px; padding: 48px; margin-top: 60px; }
.db-advisory-section h3 { font-family: 'Space Grotesk', sans-serif; font-size: 1.3rem; font-weight: 700; color: #fff; margin-bottom: 20px; }
.db-advisory-list { list-style: none; padding: 0; margin: 24px 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.db-advisory-list li { background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); border-radius: 10px; padding: 20px; transition: border-color 0.3s; }
.db-advisory-list li:hover { border-color: rgba(0, 212, 170, 0.3); }
.db-advisory-list li strong { display: block; color: var(--db-accent); font-size: 0.85rem; font-weight: 600; margin-bottom: 6px; }
.db-advisory-list li span { color: rgba(255, 255, 255, 0.65); font-size: 0.9rem; line-height: 1.6; }

.db-recruit-message { text-align: center; max-width: 700px; margin: 0 auto 60px; }
.db-recruit-message h2 { font-family: 'Noto Sans JP', sans-serif; font-size: 1.5rem; font-weight: 700; color: #fff; margin-bottom: 24px; line-height: 1.7; }
.db-recruit-cta { text-align: center; margin-top: 40px; }

.db-contact-intro { text-align: center; max-width: 600px; margin: 0 auto 48px; color: rgba(255, 255, 255, 0.7); line-height: 1.8; }
.db-contact-note { font-size: 0.8rem; color: rgba(255, 255, 255, 0.4); margin-top: 12px; }
.db-contact-form .wpcf7 {
  max-width: 640px;
  margin: 0 auto;
  background: transparent !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
}
.db-contact-form .wpcf7-form,
.db-contact-form .wpcf7-form p {
  background: transparent !important;
  color: var(--db-text) !important;
}

.db-contact-form .wpcf7-form-control-wrap { display: block; margin-bottom: 24px; }
.db-contact-form input[type='text'], .db-contact-form input[type='email'], .db-contact-form input[type='tel'], .db-contact-form textarea {
  width: 100%; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.25);
  border-radius: 8px; padding: 16px 20px; color: #fff; font-family: 'Noto Sans JP', 'Inter', sans-serif;
  font-size: 0.95rem; transition: border-color 0.3s, box-shadow 0.3s; outline: none;
}
.db-contact-form input[type='text']:focus, .db-contact-form input[type='email']:focus, .db-contact-form input[type='tel']:focus, .db-contact-form textarea:focus { border-color: var(--db-primary); box-shadow: 0 0 0 3px rgba(230, 57, 70, 0.1); }
.db-contact-form input::placeholder, .db-contact-form textarea::placeholder { color: rgba(255, 255, 255, 0.5); }
.db-contact-form textarea { min-height: 180px; resize: vertical; }
.db-contact-form .wpcf7-list-item { margin: 0; }
.db-contact-form .wpcf7-list-item label { color: rgba(255, 255, 255, 0.7); font-size: 0.9rem; display: flex; align-items: center; gap: 8px; cursor: pointer; }
.db-contact-form .wpcf7-list-item input[type='checkbox'] { accent-color: var(--db-primary); width: 18px; height: 18px; }
.db-contact-form .wpcf7-submit {
  display: block;
  width: 225px;
  margin: 32px auto 0;
  padding: 14px 0;
  background: var(--db-accent);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: background 0.3s, transform 0.2s;
}
.db-contact-form .wpcf7-submit:hover { background: var(--db-primary-light); transform: translateY(-2px); }
.db-contact-form .wpcf7-response-output { border-radius: 8px; padding: 16px; text-align: center; margin-top: 24px; }
.db-contact-form .wpcf7 .wpcf7-not-valid-tip { color: var(--db-primary-light); font-size: 0.8rem; margin-top: 4px; }
.db-contact-privacy-link { text-align: center; margin-top: 12px; }
.db-contact-privacy-link a { color: var(--db-primary); font-size: 0.85rem; text-decoration: none; }
.db-contact-privacy-link a:hover { text-decoration: underline; }

.db-privacy-content > h1:first-child { display: none; }
.db-privacy-content h2 { font-family: 'Space Grotesk', 'Noto Sans JP', sans-serif; font-size: 1.3rem; font-weight: 700; color: #fff; margin: 48px 0 16px; padding-bottom: 12px; border-bottom: 1px solid rgba(255, 255, 255, 0.08); }
.db-privacy-content h2:first-child { margin-top: 0; }
.db-privacy-content p, .db-privacy-content li { color: rgba(255, 255, 255, 0.7); line-height: 1.9; font-size: 0.95rem; }
.db-privacy-content ul, .db-privacy-content ol { padding-left: 24px; margin-bottom: 20px; }
.db-privacy-content li { margin-bottom: 8px; }

@media (max-width: 768px) {
  .db-page-hero { height: 260px; margin-top: 60px; }
  .db-page-hero-content h1 { font-size: 2rem; }
  .db-page-content, .db-page-content-wide { padding: 48px 20px; }
  .db-page-section-title { font-size: 1.4rem; }
  .db-info-table th { display: block; width: 100%; padding-bottom: 4px; }
  .db-info-table td { display: block; padding-top: 0; padding-bottom: 16px; }
  .db-mission-statement { font-size: 1.2rem; padding: 24px 0; }
  .db-advisory-list { grid-template-columns: 1fr; }
  .db-service-detail-card { padding: 32px 24px; }
  .db-glass-card { padding: 28px 20px; }
  .db-map-wrap { padding-top: 60%; }
}


/* === CF7 DARK THEME FIX === */
.db-page .wpcf7,
.db-page .wpcf7-form,
.db-page .wpcf7-form p {
  background: transparent !important;
  color: #f1fae4 !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
}
.db-page .wpcf7 input[type="text"],
.db-page .wpcf7 input[type="email"],
.db-page .wpcf7 input[type="tel"],
.db-page .wpcf7 textarea {
  width: 100% !important;
  background: rgba(255,255,255,0.07) !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  border-radius: 8px !important;
  color: #fff !important;
  padding: 14px 16px !important;
  font-size: 0.95rem !important;
  box-sizing: border-box !important;
}
.db-page .wpcf7 input:focus,
.db-page .wpcf7 textarea:focus {
  border-color: #e63946 !important;
  outline: none !important;
}
.db-page .wpcf7 input::placeholder,
.db-page .wpcf7 textarea::placeholder {
  color: rgba(255,255,255,0.45) !important;
}
.db-page .wpcf7 textarea {
  min-height: 180px !important;
  resize: vertical !important;
}
.db-page .wpcf7-submit {
  display: block !important;
  width: 240px !important;
  margin: 24px auto 0 !important;
  padding: 14px 0 !important;
  background: #e63946 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
}
.db-page .wpcf7-submit:hover {
  background: #d32f3f !important;
}
.db-page .wpcf7-list-item-label {
  color: rgba(255,255,255,0.7) !important;
}
.db-page .c-pp-link,
.db-page .c-pp-link a {
  color: rgba(255,255,255,0.5) !important;
}
.db-page .c-pp-link a:hover {
  color: #e63946 !important;
}