@charset "UTF-8";

/* =====================================================================
   映心動 Webサイト - レスポンシブスタイル
   Breakpoints: 1160px / 800px / 600px
   (TCD ISSUE のブレイクポイントに準拠)
   ===================================================================== */

/* ----------------------------------------------------------------------
   Tablet (max-width: 1160px)
   ---------------------------------------------------------------------- */
@media screen and (max-width: 1160px) {
  :root {
    --header-height: 60px;
  }

  .content-width,
  .content-narrow {
    padding: 0 30px;
  }

  body.home #container {
    margin-top: calc(-1 * var(--header-height));
  }

  /* PC only elements */
  .pc { display: block; }
  .mobile { display: none; }

  /* Header */
  .header-inner {
    padding: 0 20px;
  }

  /* Hero */
  #header_slider_content {
    left: 50px;
    bottom: 140px;
  }

  #header_slider_content .catch {
    font-size: 50px;
  }

  /* Side Button - hide on tablet */
  #side_button {
    display: none;
  }

  /* Mouse Stalker - hide on tablet */
  .mouse-stalker {
    display: none !important;
  }

  /* Design Button */
  .design-button {
    min-width: 240px;
    height: 60px;
    border-radius: 60px;
  }

  /* Service Grid */
  .service-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
  }

  /* Works Grid */
  .works-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
  }

  /* Blog Grid */
  .blog-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 25px;
  }

  /* DNA Grid */
  .dna-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
  }

  /* Footer */
  #footer {
    flex-direction: column;
    gap: 50px;
    padding: 60px 30px;
  }

  .footer-info {
    max-width: 100%;
  }

  .footer-nav-area {
    max-width: 100%;
  }

  /* Scroll content section catch */
  .scroll-content-section .catch {
    font-size: 34px;
  }

  /* Banner catch */
  .cb-banner .catch {
    font-size: 42px;
  }

  /* Section padding */
  .section {
    padding: 80px 0;
  }

  .section-header {
    margin-bottom: 40px;
  }
}


/* ----------------------------------------------------------------------
   Mobile Landscape / Large Mobile (max-width: 800px)
   ---------------------------------------------------------------------- */
@media screen and (max-width: 800px) {
  :root {
    --section-padding: 60px;
    --font-size-hero: 30px;
  }

  .pc { display: none; }
  .mobile { display: block; }

  .content-width,
  .content-narrow {
    padding: 0 20px;
  }

  /* Header */
  #header_logo img {
    height: 24px;
  }

  /* Hero Slider: モバイルは 100vh フル高さ（元に戻す） */
  #header_slider_container {
    min-height: 560px;
    height: 100vh;
    max-height: 720px;
  }

  /* モバイルではコンテンツを下寄せ + CTA込みで情報量を出す */
  #header_slider_content {
    left: 0;
    right: 0;
    top: auto;
    bottom: 70px;
    transform: none;
    padding: 0 24px;
    max-width: 100%;
  }

  #header_slider_content .content {
    text-align: left;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.6);
  }

  #header_slider_content .catch {
    font-size: 26px;
    letter-spacing: 0;
    line-height: 1.4;
    text-shadow: 0 2px 20px rgba(0, 0, 0, 0.7);
    white-space: nowrap;
  }

  #header_slider_content .desc {
    line-height: 1.9;
    font-size: 14px;
    font-weight: 600;
    margin-top: 12px;
    text-shadow: 0 2px 14px rgba(0, 0, 0, 0.45);
  }

  .hero-sub-desc {
    display: block !important;
    margin-top: 14px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 1.75 !important;
    color: rgba(255, 255, 255, 0.95) !important;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.45);
  }

  /* CTAボタンのモバイル調整 */
  .hero-cta {
    flex-direction: column;
    gap: 10px;
    margin-top: 24px;
  }
  .hero-cta__btn {
    width: 100%;
    min-width: 0;
    padding: 14px 20px;
    font-size: 13px;
  }

  /* モバイルではオーバーレイを少し濃くして読みやすく */
  #header_slider .overlay {
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0.65) 100%) !important;
  }

  /* Page Header */
  .page-header {
    padding: 120px 0 50px;
  }

  .page-header .page-title {
    font-size: 28px;
  }

  /* Section */
  .section {
    padding: 60px 0;
  }

  .section-header .section-title {
    font-size: var(--font-size-2xl);
  }

  /* Service Grid */
  .service-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }

  /* Works Grid */
  .works-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }

  /* Works Tabs */
  .works-tabs {
    flex-wrap: wrap;
    gap: 0;
  }

  .works-tab {
    padding: 10px 15px;
    font-size: var(--font-size-xs);
  }

  /* Blog Grid */
  .blog-grid {
    grid-template-columns: 1fr;
    gap: 25px;
  }

  /* Flow */
  .flow-item {
    flex-direction: column;
    gap: 15px;
    padding: 25px 0;
  }

  .flow-number {
    width: 50px;
    height: 50px;
    font-size: var(--font-size-base);
  }

  .flow-content h3 {
    font-size: var(--font-size-lg);
  }

  /* Company Table */
  .company-table th {
    width: 120px;
    padding: 15px 0;
  }

  .company-table td {
    padding: 15px 0;
  }

  /* Contact Form */
  .form-submit button {
    width: 100%;
    min-width: auto;
  }

  /* Confirm Table */
  .confirm-table th {
    width: auto;
    display: block;
    padding: 10px 0 0;
  }

  .confirm-table td {
    display: block;
    padding: 5px 0 15px;
  }

  /* Scroll Content */
  .scroll-content-section .catch {
    font-size: 26px;
  }

  .scroll-content-section .content {
    padding: 0 20px;
  }

  /* Banner */
  .cb-banner .catch {
    font-size: 30px;
  }

  .cb-banner .content {
    padding: 0 20px;
  }

  /* Design Button */
  .design-button {
    height: 50px;
    line-height: 50px;
    border-radius: 50px;
    font-size: var(--font-size-sm);
  }

  /* Value Items */
  .value-item {
    flex-direction: column;
    gap: 15px;
    padding: 25px 0;
  }

  .value-number {
    width: 50px;
    height: 50px;
    font-size: var(--font-size-lg);
  }

  .value-content h3 {
    font-size: var(--font-size-lg);
  }

  /* Reason */
  .reason-section {
    padding: 50px 0;
  }

  .reason-header {
    flex-direction: column;
    gap: 10px;
  }

  .reason-number {
    font-size: 48px;
  }

  .reason-title {
    font-size: var(--font-size-xl);
  }

  /* DNA Grid */
  .dna-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 15px;
  }

  .dna-item .dna-kanji {
    font-size: 36px;
  }

  /* Footer */
  #footer {
    padding: 50px 20px;
  }

  .footer-nav ul {
    grid-template-columns: 1fr;
    gap: 5px;
  }

  /* Footer Banner */
  .footer-banner-item {
    height: 200px;
  }

  .footer-banner-title {
    font-size: var(--font-size-xl);
  }

  /* Copyright */
  #copyright {
    padding: 15px 20px;
  }

  /* Return Top */
  #return_top {
    right: 15px;
    bottom: 15px;
  }

  /* Blog Detail */
  .blog-detail {
    padding: 0 20px;
  }

  .blog-detail .post-title {
    font-size: var(--font-size-2xl);
  }

  /* Legal Content */
  .legal-content {
    padding: 0 20px;
  }

  /* Text Section */
  .text-section h2 {
    font-size: var(--font-size-2xl);
  }

  .text-section h3 {
    font-size: var(--font-size-lg);
  }

  /* Full Image Section */
  .full-image-section {
    height: 40vh;
    min-height: 300px;
  }

  /* Error Page */
  .error-page {
    padding: 80px 20px;
  }

  .error-page .error-code {
    font-size: 80px;
  }

  /* Mission Page Responsive */
  .mission-hero__title {
    font-size: 36px;
  }
  .mission-hero__catch {
    font-size: 18px;
  }
  .mission-intro__heading {
    font-size: 26px;
  }
  .sp-only { display: inline; }
  .mvv-card,
  .mvv-card--reverse {
    grid-template-columns: 1fr;
    gap: 30px;
    direction: ltr;
  }
  .mvv-card__title {
    font-size: 26px;
  }
  .value-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .dna-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
  .dna-item {
    padding: 25px 10px;
  }
  .dna-item .dna-kanji {
    font-size: 42px;
  }
  .dna-item .dna-label {
    font-size: 11px;
  }
  .dna-detail {
    padding: 40px 20px;
  }
  .dna-detail__inner {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: center;
  }
  .dna-detail__kanji {
    font-size: 72px;
  }
  .dna-detail__label {
    font-size: 20px;
  }
  .dna-detail__desc {
    font-size: 14px;
    text-align: left;
  }

  /* Blog Detail 2-column → 1-column */
  .blog-detail-layout {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  .blog-sidebar {
    position: static;
  }
  .blog-sidebar .sidebar-cta {
    position: static; /* モバイルではsticky解除 */
  }
  /* モバイルでは記事リストを最大3件に絞る（縦長離脱防止） */
  .blog-sidebar .sidebar-post-list li:nth-child(n+4) {
    display: none;
  }

  /* Company Greeting Responsive */
  .greeting-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .greeting-image {
    position: static;
    max-width: 240px;
    margin: 0 auto;
  }
  .greeting-lead {
    font-size: 20px;
    text-align: center;
  }
  .greeting-sign {
    font-size: 13px;
  }

  /* Drawer Menu */
  #drawer_menu_inner {
    width: 100%;
    padding: 60px 26px 18px;
  }
  #drawer_menu li a {
    padding: 11px 0;
    font-size: 14px;
  }
  #drawer_menu ul {
    margin-bottom: 0;
  }
  /* ドロワー内CTA（モバイルでコンパクトに） */
  .drawer-cta {
    margin-top: 20px;
    gap: 10px;
  }
  .drawer-cta__btn {
    padding: 13px 16px;
    font-size: 12px;
  }
  #mobile_sns.sns-list {
    margin-top: 16px;
    padding-top: 14px;
    gap: 8px;
  }
  #mobile_sns.sns-list li a {
    width: 34px;
    height: 34px;
  }

  /* ==========================================================
     サービス詳細ページ モバイル対応
     ========================================================== */

  /* サービス詳細ヒーロー: パディング・フォント調整 */
  .service-page-header {
    padding: 130px 20px 60px;
  }
  .service-page-header__title {
    font-size: 28px !important;
  }
  .service-page-header__catch {
    font-size: 15px;
    line-height: 1.7;
  }
  .service-page-header__category {
    font-size: 10px;
    padding: 4px 12px;
    margin-bottom: 18px;
  }

  /* 課題リスト: 2列 → 1列 */
  .challenge-list {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-top: 40px;
  }
  .challenge-item {
    padding: 18px 20px;
    font-size: 14px;
  }

  /* サービス詳細セクション: パディング削減 */
  .service-challenges,
  .service-detail-main,
  .service-plans,
  .service-targets,
  .service-cases,
  .service-faqs,
  .service-related {
    padding: 60px 0;
  }

  .service-description {
    font-size: 15px;
    line-height: 1.9;
    margin-top: 30px;
    margin-bottom: 40px;
  }

  .subsection-title {
    font-size: 19px;
    margin: 40px 0 20px;
  }

  .deliverables-list li {
    font-size: 14px;
    padding: 12px 14px 12px 32px;
  }

  /* プロセスステップ: 番号円を小さく */
  .process-step {
    gap: 18px;
    padding: 22px 0;
  }
  .process-step__num {
    width: 44px;
    height: 44px;
    font-size: 14px;
  }
  .process-step__title {
    font-size: 16px;
  }
  .process-step__desc {
    font-size: 13px;
  }

  /* 料金プラン: 3列 → 1列 */
  .plan-grid {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-top: 40px;
  }
  .plan-card {
    padding: 36px 24px 30px;
  }
  .plan-card__price {
    font-size: 26px;
  }

  /* ターゲット: 2列 → 1列 */
  .target-grid {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-top: 40px;
  }
  .target-item {
    padding: 20px 22px;
    font-size: 14px;
  }

  /* 参考イメージ: 3列 → 1列 */
  .case-grid {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-top: 40px;
  }

  /* works-tabs: 折り返し→横スクロール */
  .works-tabs {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    margin-bottom: 40px;
    margin-left: -20px;
    margin-right: -20px;
    padding: 0 20px;
  }
  .works-tabs::-webkit-scrollbar {
    display: none;
  }
  .works-tab {
    flex-shrink: 0;
    padding: 14px 18px;
    font-size: 13px;
    white-space: nowrap;
  }

  /* works-grid: 1カラム化は600px以下でOKだが、800px以下でも1カラムの方が画像が大きく見える */
  .works-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  /* FAQ: パディング調整 */
  .faq-list {
    margin-top: 40px;
  }
  .faq-item__q {
    padding: 18px 54px 18px 20px;
    font-size: 14px;
    gap: 12px;
  }
  .faq-item__q::after {
    right: 20px;
  }
  .faq-item__qtext {
    padding-right: 0;
  }
  .faq-item__a {
    padding: 0 20px 20px 20px;
    font-size: 13px;
    gap: 12px;
  }
  .faq-item__mark {
    width: 24px;
    height: 24px;
    font-size: 11px;
  }
}


/* ----------------------------------------------------------------------
   Small Mobile (max-width: 600px)
   ---------------------------------------------------------------------- */
@media screen and (max-width: 600px) {
  /* Service Grid - 1 column */
  .service-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  /* Works Grid - single column for very small screens */
  .works-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  /* DNA Grid */
  .dna-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }

  .dna-item .dna-kanji {
    font-size: 30px;
  }

  /* Hero: 小さい画面用のフォントサイズ調整 */
  #header_slider_content .catch {
    font-size: 23px;
    line-height: 1.4;
    letter-spacing: 0;
    white-space: nowrap;
  }
  #header_slider_content .desc {
    font-size: 13px;
    font-weight: 600;
  }
  .hero-sub-desc {
    font-size: 11px !important;
    font-weight: 500 !important;
  }
  .hero-cta__btn {
    padding: 13px 18px;
    font-size: 12px;
  }

  /* Section Title */
  .section-header .section-title {
    font-size: var(--font-size-xl);
  }

  /* Scroll Content */
  .scroll-content-section .catch {
    font-size: 22px;
  }

  /* Banner */
  .cb-banner .catch {
    font-size: 24px;
  }

  /* Footer Nav - 1 column */
  .footer-nav ul {
    grid-template-columns: 1fr;
  }
}


/* ----------------------------------------------------------------------
   Wide Desktop (min-width: 1440px)
   ---------------------------------------------------------------------- */
@media screen and (min-width: 1440px) {
  #header_slider_content {
    left: 100px;
    bottom: 180px;
  }

  #header_slider_content .catch {
    font-size: 80px;
  }
}
