@charset "UTF-8";
/**
 * BoundFor Theme - Main SCSS (Minimal)
 *
 * @package Boundfor
 */
/**
 * Reset - 最小限のCSSリセット
 *
 * @package Boundfor
 */
/* Box sizing */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Remove default margin/padding */
* {
  margin: 0;
  padding: 0;
}

/* HTML & Body */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  min-height: 100vh;
  line-height: var(--lh-normal);
  font-family: var(--ff-sans);
  font-size: var(--fs-base);
  color: var(--c-text);
  background-color: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-size: inherit;
  font-weight: inherit;
}

/* Links */
a {
  color: inherit;
  text-decoration: inherit;
}

/* Lists */
ol, ul {
  list-style: none;
}

/* Images & Media */
img, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

/* Button */
button {
  font: inherit;
  cursor: pointer;
  background: transparent;
  border: none;
}

/* Hidden attribute */
[hidden] {
  display: none !important;
}

/* Alpine.js cloak */
[x-cloak] {
  display: none !important;
}

/* Selection */
::-moz-selection {
  background-color: var(--c-primary);
  color: var(--c-text-inverse);
}
::selection {
  background-color: var(--c-primary);
  color: var(--c-text-inverse);
}

/* Focus visible */
:focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 2px;
}

:focus:not(:focus-visible) {
  outline: none;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/**
 * CSS Variables - デザイントークン
 *
 * @package Boundfor
 */
:root {
  /* =========================================
     Colors - ブランドカラー
     ========================================= */
  /* Primary - Core Green */
  --c-primary: #12985D;
  --c-primary-dark: #0F7A4A;
  --c-primary-bg: #F0FDF4;
  /* Secondary - Apps Blue */
  --c-secondary: #4C8BF5;
  --c-secondary-bg: #EFF6FF;
  /* Accent - Academy Orange */
  --c-accent: #FF7A59;
  --c-accent-bg: #FFF7ED;
  /* Tertiary - Solutions Purple */
  --c-tertiary: #6F42C1;
  --c-tertiary-bg: #FAF5FF;
  /* =========================================
     Colors - グレースケール
     ========================================= */
  --c-gray-50: #F9FAFB;
  --c-gray-100: #F3F4F6;
  --c-gray-200: #E5E7EB;
  --c-gray-300: #D1D5DB;
  --c-gray-400: #9CA3AF;
  --c-gray-500: #6B7280;
  --c-gray-600: #4B5563;
  --c-gray-700: #374151;
  --c-gray-800: #1F2937;
  --c-gray-900: #0D0D0D;
  /* =========================================
     Colors - セマンティック
     ========================================= */
  /* Text */
  --c-text: var(--c-gray-900);
  --c-text-secondary: var(--c-gray-800);
  --c-text-muted: var(--c-gray-500);
  --c-text-light: var(--c-gray-400);
  --c-text-inverse: #FFFFFF;
  /* Background */
  --c-bg: #FFFFFF;
  --c-bg-secondary: var(--c-gray-50);
  --c-bg-tertiary: var(--c-gray-100);
  --c-bg-dark: #1A1A1A;
  /* Border */
  --c-border: var(--c-gray-200);
  --c-border-light: var(--c-gray-100);
  --c-border-transparent: rgba(0, 0, 0, 0.06);
  /* =========================================
     Layout - レイアウト寸法
     ========================================= */
  --header-height: 80px;
  --header-utility-height: 40px;
  --header-total-height: 120px; /* header + utility */
  --content-max-width: 80rem;
  /* =========================================
     Typography
     ========================================= */
  /* Font Family */
  --ff-sans: "Inter", "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  /* Font Size */
  --fs-2xs: 0.6875rem; /* 11px */
  --fs-xs: 0.75rem; /* 12px */
  --fs-sm: 0.875rem; /* 14px */
  --fs-base: 1rem; /* 16px */
  --fs-lg: 1.125rem; /* 18px */
  --fs-xl: 1.25rem; /* 20px */
  --fs-2xl: 1.5rem; /* 24px */
  --fs-3xl: 1.875rem; /* 30px */
  --fs-4xl: 2.25rem; /* 36px */
  --fs-5xl: 3rem; /* 48px */
  /* Font Weight */
  --fw-normal: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  /* Line Height */
  --lh-tight: 1.25;
  --lh-normal: 1.5;
  --lh-relaxed: 1.625;
  /* Letter Spacing */
  --ls-tight: -0.025em;
  --ls-normal: 0;
  --ls-wide: 0.025em;
  --ls-wider: 0.05em;
  --ls-widest: 0.1em;
  /* =========================================
     Spacing
     ========================================= */
  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;
  /* =========================================
     Border Radius
     ========================================= */
  --radius-sm: 0.25rem;
  --radius-md: 0.375rem;
  --radius-lg: 0.5rem;
  --radius-xl: 0.75rem;
  --radius-full: 9999px;
  /* =========================================
     Shadows
     ========================================= */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.07);
  --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.1);
  /* =========================================
     Transitions
     ========================================= */
  --ease-default: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 500ms;
  --transition-fast: var(--duration-fast) var(--ease-default);
  --transition-normal: var(--duration-normal) var(--ease-default);
  /* =========================================
     Z-Index
     ========================================= */
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-fixed: 300;
  --z-modal: 400;
  --z-tooltip: 500;
}

/**
 * Utilities - 最小限のユーティリティクラス
 *
 * @package Boundfor
 */
/* Display */
.hidden {
  display: none;
}

.visible {
  visibility: visible;
}

/* Screen Reader Only */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/**
 * Header - Double Decker Header (BEM)
 * Guarded with .bf-theme to prevent CSS pollution
 *
 * @package Boundfor
 */
.bf-theme.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: var(--z-fixed);
  background-color: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow-sm);
  transition: background-color var(--transition-normal), box-shadow var(--transition-normal), backdrop-filter var(--transition-normal);
  /* Scrolled state */
}
.bf-theme.site-header.is-scrolled {
  background-color: rgba(255, 255, 255, 0.9);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.bf-theme.site-header {
  /* Mobile menu open - disable transparency */
}
.bf-theme.site-header:has(.mobile-menu.is-open) {
  background-color: var(--c-bg);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.bf-theme.site-header {
  /* -----------------------------------------
     Row 1: Utility Navigation
     ----------------------------------------- */
}
.bf-theme.site-header .header-utility {
  background-color: transparent;
  border-bottom: 1px solid var(--c-border-transparent);
  font-size: var(--fs-sm);
  height: var(--header-utility-height);
}
@media (max-width: 1023px) {
  .bf-theme.site-header .header-utility {
    display: none;
  }
}
.bf-theme.site-header .header-utility__inner {
  max-width: var(--content-max-width);
  margin-inline: auto;
  padding-inline: var(--sp-4);
  height: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-6);
}
@media (min-width: 640px) {
  .bf-theme.site-header .header-utility__inner {
    padding-inline: var(--sp-6);
  }
}
@media (min-width: 1024px) {
  .bf-theme.site-header .header-utility__inner {
    padding-inline: var(--sp-8);
  }
}
.bf-theme.site-header .header-utility__inner strong {
  color: var(--c-text-muted);
  font-weight: var(--fw-normal);
}
.bf-theme.site-header .header-utility__nav {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  font-weight: var(--fw-medium);
  color: var(--c-text-muted);
}
.bf-theme.site-header .header-utility__link {
  color: inherit;
  transition: color var(--transition-fast);
}
.bf-theme.site-header .header-utility__link:hover {
  color: var(--c-primary);
}
.bf-theme.site-header .header-utility__link--search {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-weight: var(--fw-bold);
  color: var(--c-gray-600);
}
.bf-theme.site-header .header-utility__link--search i {
  color: inherit;
}
.bf-theme.site-header .header-utility__link--partner {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  font-weight: var(--fw-bold);
  color: var(--c-primary);
}
.bf-theme.site-header .header-utility__link--partner:hover {
  color: var(--c-primary-dark);
}
.bf-theme.site-header .header-utility__divider {
  width: 1px;
  height: var(--sp-3);
  background-color: var(--c-gray-300);
}
.bf-theme.site-header {
  /* -----------------------------------------
     Row 2: Main Navigation
     ----------------------------------------- */
}
.bf-theme.site-header .header-main {
  background-color: transparent;
  height: var(--header-height);
  border-bottom: 1px solid var(--c-border-transparent);
}
.bf-theme.site-header .header-main__inner {
  max-width: var(--content-max-width);
  margin-inline: auto;
  padding-inline: var(--sp-4);
  height: 100%;
}
@media (min-width: 640px) {
  .bf-theme.site-header .header-main__inner {
    padding-inline: var(--sp-6);
  }
}
@media (min-width: 1024px) {
  .bf-theme.site-header .header-main__inner {
    padding-inline: var(--sp-8);
  }
}
.bf-theme.site-header .header-main__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  gap: var(--sp-4);
}
.bf-theme.site-header {
  /* -----------------------------------------
     Logo
     ----------------------------------------- */
}
.bf-theme.site-header .header-logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.bf-theme.site-header .header-logo__link {
  display: block;
  transition: transform var(--transition-fast);
}
.bf-theme.site-header .header-logo__link:hover {
  transform: scale(1.05);
}
.bf-theme.site-header .header-logo__img {
  height: 2.25rem;
  width: auto;
}
.bf-theme.site-header {
  /* -----------------------------------------
     Primary Navigation
     ----------------------------------------- */
}
.bf-theme.site-header .header-nav {
  display: none;
  align-items: center;
  gap: var(--sp-6);
  flex-grow: 1;
  justify-content: center;
}
@media (min-width: 1024px) {
  .bf-theme.site-header .header-nav {
    display: flex;
  }
}
@media (min-width: 1280px) {
  .bf-theme.site-header .header-nav {
    gap: var(--sp-8);
  }
}
.bf-theme.site-header .header-nav__item {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: var(--header-height);
  padding-inline: 1em;
  transition: all var(--transition-fast);
}
.bf-theme.site-header .header-nav__item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 2px;
  transition: width var(--transition-normal);
}
.bf-theme.site-header .header-nav__item:hover::after {
  width: 100%;
}
.bf-theme.site-header .header-nav__item {
  /* Brand color variants */
}
.bf-theme.site-header .header-nav__item--core:hover .header-nav__subtitle {
  color: var(--c-primary);
}
.bf-theme.site-header .header-nav__item--core:hover::after {
  background-color: var(--c-primary);
}
.bf-theme.site-header .header-nav__item--apps:hover .header-nav__subtitle {
  color: var(--c-secondary);
}
.bf-theme.site-header .header-nav__item--apps:hover::after {
  background-color: var(--c-secondary);
}
.bf-theme.site-header .header-nav__item--academy:hover .header-nav__subtitle {
  color: var(--c-accent);
}
.bf-theme.site-header .header-nav__item--academy:hover::after {
  background-color: var(--c-accent);
}
.bf-theme.site-header .header-nav__item--solutions:hover .header-nav__subtitle {
  color: var(--c-tertiary);
}
.bf-theme.site-header .header-nav__item--solutions:hover::after {
  background-color: var(--c-tertiary);
}
.bf-theme.site-header .header-nav__label {
  display: flex;
  flex-direction: column;
  align-items: baseline;
  gap: 0.2rem;
}
.bf-theme.site-header .header-nav__title {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  color: var(--c-text-secondary);
}
.bf-theme.site-header .header-nav__subtitle {
  font-size: var(--fs-2xs);
  font-weight: var(--fw-medium);
  color: var(--c-text-muted);
  transition: color var(--transition-fast);
}
.bf-theme.site-header {
  /* -----------------------------------------
     CTA Buttons
     ----------------------------------------- */
}
.bf-theme.site-header .header-cta {
  display: none;
  align-items: center;
  gap: var(--sp-3);
  flex-shrink: 0;
}
@media (min-width: 1024px) {
  .bf-theme.site-header .header-cta {
    display: flex;
  }
}
.bf-theme.site-header .header-cta__btn {
  padding: 0.625rem 1.25rem;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
  white-space: nowrap;
}
.bf-theme.site-header .header-cta__btn--secondary {
  color: var(--c-primary);
  border: 1px solid var(--c-primary);
  background-color: var(--c-bg);
  box-shadow: var(--shadow-sm);
}
.bf-theme.site-header .header-cta__btn--secondary:hover {
  background-color: var(--c-primary-bg);
  box-shadow: var(--shadow-md);
}
.bf-theme.site-header .header-cta__btn--primary {
  color: var(--c-text-inverse);
  background-color: var(--c-primary);
  box-shadow: var(--shadow-md);
}
.bf-theme.site-header .header-cta__btn--primary:hover {
  background-color: var(--c-primary-dark);
  box-shadow: var(--shadow-lg);
}
.bf-theme.site-header {
  /* -----------------------------------------
     Mobile Menu Toggle
     ----------------------------------------- */
}
.bf-theme.site-header .header-mobile-toggle {
  display: flex;
  align-items: center;
}
@media (min-width: 1024px) {
  .bf-theme.site-header .header-mobile-toggle {
    display: none;
  }
}
.bf-theme.site-header .header-mobile-toggle__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-2);
  color: var(--c-gray-600);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: color var(--transition-fast);
}
.bf-theme.site-header .header-mobile-toggle__btn:hover {
  color: var(--c-primary);
}
.bf-theme.site-header .header-mobile-toggle__btn.is-active .header-mobile-toggle__icon--open {
  display: none;
}
.bf-theme.site-header .header-mobile-toggle__btn.is-active .header-mobile-toggle__icon--close {
  display: block;
}
.bf-theme.site-header .header-mobile-toggle__icon {
  font-size: var(--fs-2xl);
}
.bf-theme.site-header .header-mobile-toggle__icon--close {
  display: none;
}
.bf-theme.site-header {
  /* -----------------------------------------
     Mobile Menu Overlay
     ----------------------------------------- */
}
.bf-theme.site-header .mobile-menu {
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  height: calc(100vh - var(--header-height));
  height: calc(100dvh - var(--header-height));
  background-color: var(--c-bg);
  border-top: 1px solid var(--c-border-light);
  z-index: var(--z-fixed);
  overflow-y: auto;
  opacity: 0;
  transform: translateY(-0.5rem);
  transition: opacity 200ms var(--ease-out), transform 200ms var(--ease-out);
  pointer-events: none;
}
.bf-theme.site-header .mobile-menu.is-open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
@media (min-width: 1024px) {
  .bf-theme.site-header .mobile-menu {
    display: none !important;
  }
}
.bf-theme.site-header .mobile-menu__inner {
  padding: var(--sp-4) var(--sp-4) var(--sp-8);
}
.bf-theme.site-header .mobile-menu__inner > * + * {
  margin-top: var(--sp-1);
}
.bf-theme.site-header .mobile-menu__heading {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--c-text-light);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  padding: var(--sp-2) var(--sp-3);
}
.bf-theme.site-header .mobile-menu__link {
  display: block;
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--c-gray-700);
  transition: all var(--transition-fast);
}
.bf-theme.site-header .mobile-menu__link:hover {
  color: var(--c-primary);
}
.bf-theme.site-header .mobile-menu__link {
  /* Brand color variants */
}
.bf-theme.site-header .mobile-menu__link--core, .bf-theme.site-header .mobile-menu__link--apps, .bf-theme.site-header .mobile-menu__link--academy, .bf-theme.site-header .mobile-menu__link--solutions {
  padding: var(--sp-3);
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--c-text-secondary);
  border-radius: var(--radius-lg);
  border-left: 4px solid transparent;
}
.bf-theme.site-header .mobile-menu__link--core:hover {
  background-color: var(--c-primary-bg);
  color: var(--c-primary);
  border-left-color: var(--c-primary);
}
.bf-theme.site-header .mobile-menu__link--apps:hover {
  background-color: var(--c-secondary-bg);
  color: var(--c-secondary);
  border-left-color: var(--c-secondary);
}
.bf-theme.site-header .mobile-menu__link--academy:hover {
  background-color: var(--c-accent-bg);
  color: var(--c-accent);
  border-left-color: var(--c-accent);
}
.bf-theme.site-header .mobile-menu__link--solutions:hover {
  background-color: var(--c-tertiary-bg);
  color: var(--c-tertiary);
  border-left-color: var(--c-tertiary);
}
.bf-theme.site-header .mobile-menu__link--partner {
  font-weight: var(--fw-bold);
  color: var(--c-primary);
}
.bf-theme.site-header .mobile-menu__subtitle {
  font-size: var(--fs-xs);
  font-weight: var(--fw-normal);
  color: var(--c-text-muted);
  margin-left: var(--sp-2);
}
.bf-theme.site-header .mobile-menu__divider {
  height: 1px;
  background-color: var(--c-border-light);
  margin-block: var(--sp-4);
}
.bf-theme.site-header .mobile-menu__cta {
  padding-top: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.bf-theme.site-header .mobile-menu__cta-btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}
.bf-theme.site-header .mobile-menu__cta-btn--secondary {
  color: var(--c-primary);
  border: 1px solid var(--c-primary);
  background-color: var(--c-bg);
}
.bf-theme.site-header .mobile-menu__cta-btn--secondary:hover {
  background-color: var(--c-bg-tertiary);
}
.bf-theme.site-header .mobile-menu__cta-btn--primary {
  color: var(--c-text-inverse);
  background-color: var(--c-primary);
}
.bf-theme.site-header .mobile-menu__cta-btn--primary:hover {
  background-color: var(--c-primary-dark);
}

/* =========================================
   WordPress Admin Bar Offset
   ========================================= */
body.admin-bar .bf-theme.site-header {
  top: 32px;
}

@media (max-width: 782px) {
  body.admin-bar .bf-theme.site-header {
    top: 46px;
  }
}
body.admin-bar .bf-theme.site-header .mobile-menu {
  height: calc(100vh - var(--header-height) - 32px);
  height: calc(100dvh - var(--header-height) - 32px);
}

@media (max-width: 782px) {
  body.admin-bar .bf-theme.site-header .mobile-menu {
    height: calc(100vh - var(--header-height) - 46px);
    height: calc(100dvh - var(--header-height) - 46px);
  }
}
/* =========================================
   Main Content Padding
   ========================================= */
.site-main {
  padding-top: var(--header-height);
}
@media (min-width: 1024px) {
  .site-main {
    padding-top: var(--header-total-height);
  }
}

body.admin-bar .site-main {
  padding-top: calc(var(--header-height) + 32px);
}
@media (min-width: 1024px) {
  body.admin-bar .site-main {
    padding-top: calc(var(--header-total-height) + 32px);
  }
}
@media (max-width: 782px) {
  body.admin-bar .site-main {
    padding-top: calc(var(--header-height) + 46px);
  }
}

/**
 * Footer - フッター (BEM)
 * Guarded with .bf-theme to prevent CSS pollution
 *
 * @package Boundfor
 */
.bf-theme.site-footer {
  background-color: var(--c-bg-dark);
  color: var(--c-text-inverse);
  padding-top: var(--sp-16);
  padding-bottom: var(--sp-8);
  font-size: var(--fs-sm);
  border-top: 1px solid var(--c-gray-800);
  /* -----------------------------------------
     Footer Logo - Gray Color Filter
     ----------------------------------------- */
}
.bf-theme.site-footer .footer-logo {
  filter: brightness(0) invert(1) brightness(0.7);
}
.bf-theme.site-footer .site-footer__inner {
  max-width: var(--content-max-width);
  margin-inline: auto;
  padding-inline: var(--sp-4);
}
@media (min-width: 640px) {
  .bf-theme.site-footer .site-footer__inner {
    padding-inline: var(--sp-6);
  }
}
@media (min-width: 1024px) {
  .bf-theme.site-footer .site-footer__inner {
    padding-inline: var(--sp-8);
  }
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Links Grid
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__links {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-8);
  margin-bottom: var(--sp-16);
}
@media (min-width: 768px) {
  .bf-theme.site-footer .footer__links {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Column
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__col-title {
  display: block;
  margin-bottom: var(--sp-4);
}
.bf-theme.site-footer .footer__col-heading {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-weight: var(--fw-bold);
  color: var(--c-text-inverse);
  transition: color var(--transition-fast);
}
.bf-theme.site-footer .footer__col-dot {
  width: var(--sp-2);
  height: var(--sp-2);
  border-radius: var(--radius-full);
}
.bf-theme.site-footer .footer__col-dot--core {
  background-color: var(--c-primary);
}
.bf-theme.site-footer .footer__col-dot--apps {
  background-color: var(--c-secondary);
}
.bf-theme.site-footer .footer__col-dot--academy {
  background-color: var(--c-accent);
}
.bf-theme.site-footer .footer__col-dot--solutions {
  background-color: var(--c-tertiary);
}
.bf-theme.site-footer {
  /* Brand color hover states */
}
.bf-theme.site-footer .footer__col-title:hover .footer__col-heading--core {
  color: var(--c-primary);
}
.bf-theme.site-footer .footer__col-title:hover .footer__col-heading--apps {
  color: var(--c-secondary);
}
.bf-theme.site-footer .footer__col-title:hover .footer__col-heading--academy {
  color: var(--c-accent);
}
.bf-theme.site-footer .footer__col-title:hover .footer__col-heading--solutions {
  color: var(--c-tertiary);
}
.bf-theme.site-footer .footer__list {
  display: flex;
  flex-direction: column;
  color: var(--c-gray-400);
}
.bf-theme.site-footer .footer__link {
  color: inherit;
  transition: color var(--transition-fast);
  padding-block: 0.2rem;
  display: block;
}
.bf-theme.site-footer .footer__link--core:hover {
  color: var(--c-primary);
}
.bf-theme.site-footer .footer__link--apps:hover {
  color: var(--c-secondary);
}
.bf-theme.site-footer .footer__link--academy:hover {
  color: var(--c-accent);
}
.bf-theme.site-footer .footer__link--solutions:hover {
  color: var(--c-tertiary);
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Sitemap
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__sitemap {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2) var(--sp-6);
  padding-top: var(--sp-8);
  margin-bottom: var(--sp-8);
  border-top: 1px solid var(--c-gray-800);
  color: var(--c-gray-400);
  justify-content: center;
}
@media (min-width: 768px) {
  .bf-theme.site-footer .footer__sitemap {
    justify-content: flex-start;
  }
}
.bf-theme.site-footer .footer__sitemap-link {
  color: inherit;
  transition: color var(--transition-fast);
}
.bf-theme.site-footer .footer__sitemap-link:hover {
  color: var(--c-text-inverse);
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Bottom
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__bottom {
  display: flex;
  flex-direction: column;
  gap: var(--sp-8);
  padding-top: var(--sp-8);
  border-top: 1px solid var(--c-gray-800);
  margin-bottom: var(--sp-12);
}
@media (min-width: 768px) {
  .bf-theme.site-footer .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
  }
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Brand
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__brand {
  width: 100%;
  text-align: center;
}
@media (min-width: 768px) {
  .bf-theme.site-footer .footer__brand {
    width: 50%;
    text-align: left;
  }
}
.bf-theme.site-footer .footer__brand-logo {
  display: inline-block;
  margin-bottom: var(--sp-4);
  transition: opacity var(--transition-fast);
}
.bf-theme.site-footer .footer__brand-logo:hover {
  opacity: 0.8;
}
.bf-theme.site-footer .footer__brand-logo img {
  height: 2rem;
  width: auto;
}
.bf-theme.site-footer .footer__brand-desc {
  font-size: var(--fs-sm);
  color: var(--c-text-muted);
  line-height: var(--lh-relaxed);
  margin-bottom: var(--sp-4);
}
.bf-theme.site-footer .footer__copyright {
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.5);
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Partners
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__partners {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}
@media (min-width: 768px) {
  .bf-theme.site-footer .footer__partners {
    align-items: flex-end;
    width: auto;
  }
}
.bf-theme.site-footer .footer__partners-label {
  font-size: 0.625rem;
  color: rgba(255, 255, 255, 0.5);
  font-weight: var(--fw-medium);
  text-transform: uppercase;
  letter-spacing: var(--ls-wider);
  margin-bottom: var(--sp-3);
}
.bf-theme.site-footer .footer__partners-logos {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
}
.bf-theme.site-footer .footer__partner {
  display: inline-block;
  transition: opacity var(--transition-fast);
}
.bf-theme.site-footer .footer__partner:hover {
  opacity: 0.8;
}
.bf-theme.site-footer .footer__partner img {
  height: 32px;
  width: auto;
  -o-object-fit: contain;
     object-fit: contain;
}
.bf-theme.site-footer .footer__partner img.ayatori-logo {
  height: 28px;
}
.bf-theme.site-footer .footer__partner--bordered {
  padding-left: var(--sp-8);
  border-left: 1px solid var(--c-gray-700);
}
.bf-theme.site-footer {
  /* -----------------------------------------
     Footer Organizer (SDW)
     ----------------------------------------- */
}
.bf-theme.site-footer .footer__organizer {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-top: var(--sp-8);
  border-top: 1px solid var(--c-gray-800);
}
.bf-theme.site-footer .footer__organizer-label {
  font-size: 0.625rem;
  font-weight: var(--fw-bold);
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  letter-spacing: var(--ls-widest);
  margin-bottom: var(--sp-2);
}
.bf-theme.site-footer .footer__organizer-logo {
  transition: opacity var(--transition-fast);
}
.bf-theme.site-footer .footer__organizer-logo:hover {
  opacity: 0.8;
}
.bf-theme.site-footer .footer__organizer-logo img {
  height: 2rem;
  width: auto;
}

/**
 * Animations - 最小限のアニメーション
 *
 * @package Boundfor
 */
/* Fade Up (Alpine.js intersect用) */
.fade-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fade-up.is-visible,
.fade-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .fade-up {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
/**
 * Floating CTA - フローティングCTAボタン
 * Guarded with .bf-theme to prevent CSS pollution
 *
 * @package Boundfor
 */
/* =========================================
   Desktop Version - 右下縦並び
   ========================================= */
.bf-theme.floating-cta {
  display: none;
  flex-direction: column;
  gap: var(--sp-3);
  position: fixed;
  bottom: var(--sp-6);
  right: var(--sp-6);
  z-index: var(--z-sticky);
}
@media (min-width: 768px) {
  .bf-theme.floating-cta {
    display: flex;
  }
}
.bf-theme.floating-cta .floating-cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-6) var(--sp-4);
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  transition: all var(--transition-normal);
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
.bf-theme.floating-cta .floating-cta__btn--secondary {
  background-color: var(--c-bg);
  color: var(--c-primary);
  border: 1px solid var(--c-primary);
}
.bf-theme.floating-cta .floating-cta__btn--secondary:hover {
  background-color: var(--c-primary-bg);
}
.bf-theme.floating-cta .floating-cta__btn--primary {
  background-color: var(--c-primary);
  color: var(--c-text-inverse);
}
.bf-theme.floating-cta .floating-cta__btn--primary:hover {
  background-color: var(--c-primary-dark);
}
.bf-theme.floating-cta .floating-cta__btn i {
  writing-mode: horizontal-tb;
  font-size: var(--fs-xl);
}

/* =========================================
   Mobile Version - 画面下部固定バー
   ========================================= */
.bf-theme.floating-cta-mobile {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-sticky);
  background-color: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 -4px 10px rgba(0, 0, 0, 0.05);
  padding: var(--sp-3);
  border-top: 1px solid var(--c-border-light);
  gap: var(--sp-3);
}
@media (min-width: 768px) {
  .bf-theme.floating-cta-mobile {
    display: none;
  }
}
.bf-theme.floating-cta-mobile .floating-cta-mobile__btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-2);
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
  border-radius: var(--radius-md);
  transition: all var(--transition-normal);
  text-align: center;
}
.bf-theme.floating-cta-mobile .floating-cta-mobile__btn--secondary {
  background-color: var(--c-bg);
  color: var(--c-primary);
  border: 1px solid var(--c-primary);
  box-shadow: var(--shadow-sm);
}
.bf-theme.floating-cta-mobile .floating-cta-mobile__btn--secondary:hover {
  background-color: var(--c-primary-bg);
}
.bf-theme.floating-cta-mobile .floating-cta-mobile__btn--primary {
  background-color: var(--c-primary);
  color: var(--c-text-inverse);
  box-shadow: var(--shadow-md);
}
.bf-theme.floating-cta-mobile .floating-cta-mobile__btn--primary:hover {
  background-color: var(--c-primary-dark);
}

/* =========================================
   Alpine.js Transitions
   ========================================= */
.bf-theme.floating-cta[x-cloak],
.bf-theme.floating-cta-mobile[x-cloak] {
  display: none !important;
}

/**
 * CTA Section - Call to Action
 * Guarded with .bf-theme to prevent CSS pollution
 *
 * @package Boundfor
 */
.bf-theme.cta-section {
  position: relative;
  padding-block: var(--sp-24);
  background-color: var(--c-bg-dark);
  color: var(--c-text-inverse);
  overflow: hidden;
  /* -----------------------------------------
     Background Elements
     ----------------------------------------- */
}
.bf-theme.cta-section .cta-section__pattern {
  position: absolute;
  inset: 0;
  background-image: url("https://boundfor.jp/img/bg_pattern_dots.png");
  opacity: 0.2;
}
.bf-theme.cta-section .cta-section__glow {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  height: 16rem;
  background-color: var(--c-primary);
  opacity: 0.2;
  filter: blur(100px);
}
.bf-theme.cta-section {
  /* -----------------------------------------
     Content
     ----------------------------------------- */
}
.bf-theme.cta-section .cta-section__inner {
  position: relative;
  z-index: 10;
  max-width: 56rem;
  margin-inline: auto;
  padding-inline: var(--sp-4);
  text-align: center;
}
.bf-theme.cta-section .cta-section__title {
  font-size: var(--fs-3xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-8);
}
@media (min-width: 768px) {
  .bf-theme.cta-section .cta-section__title {
    font-size: var(--fs-5xl);
  }
}
.bf-theme.cta-section .cta-section__desc {
  font-size: var(--fs-lg);
  color: var(--c-gray-300);
  margin-bottom: var(--sp-12);
  max-width: 42rem;
  margin-inline: auto;
  line-height: var(--lh-relaxed);
}
@media (min-width: 768px) {
  .bf-theme.cta-section .cta-section__desc {
    font-size: var(--fs-xl);
  }
}
.bf-theme.cta-section {
  /* -----------------------------------------
     Buttons
     ----------------------------------------- */
}
.bf-theme.cta-section .cta-section__buttons {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--sp-6);
}
@media (min-width: 640px) {
  .bf-theme.cta-section .cta-section__buttons {
    flex-direction: row;
  }
}
.bf-theme.cta-section .cta-section__btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: var(--sp-4) var(--sp-8);
  font-weight: var(--fw-bold);
  border-radius: var(--radius-lg);
  transition: all var(--transition-normal);
  min-width: 200px;
}
.bf-theme.cta-section .cta-section__btn i {
  margin-right: var(--sp-3);
}
.bf-theme.cta-section .cta-section__btn--secondary {
  background-color: transparent;
  border: 2px solid rgba(255, 255, 255, 0.3);
  color: var(--c-text-inverse);
}
.bf-theme.cta-section .cta-section__btn--secondary:hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: var(--c-text-inverse);
}
.bf-theme.cta-section .cta-section__btn--primary {
  background-color: var(--c-primary);
  color: var(--c-text-inverse);
  box-shadow: 0 0 30px rgba(18, 152, 93, 0.6);
}
.bf-theme.cta-section .cta-section__btn--primary:hover {
  background-color: var(--c-primary-dark);
  box-shadow: 0 0 40px rgba(18, 152, 93, 0.8);
  transform: scale(1.05);
}
/*# sourceMappingURL=bundle.css.map */
