@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 1. 全体共通・初期設定
************************************/
body {
    background: #fff;
    font-family: 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN', 'Hiragino Sans', Meiryo, sans-serif !important;
    font-weight: 400;
    font-style: normal;
    color: #333;
    line-height: 1.8;
    letter-spacing: 0.05em;
}

/* 管理バーを少し透明に */
div#wpadminbar { opacity: 0.3; }

/* ページ固有の不要な要素を隠す */
.footer-meta,
.date-tags,
.home h1.entry-title,
.home .article-footer,
.home .entry-footer {
    display: none !important;
}

/* ヘッダー・ナビゲーション周り */
div#header-container { background: #0000 !important; z-index: 999999999999; box-shadow: inherit; }
.header-container-in.hlt-top-menu { padding-top: 7px; padding-bottom: 7px; }
nav#navi { background: none; }
.navi-in a { color: #fff; }
.navi-in a:hover { color: #ffffff; background: #8700005e; }
.top-content { width: 100%; position: absolute; margin-bottom: 0; border: none; z-index: -1; margin-top: -51px; }
.fixed-header { background: #ffc3c38a !important; }

/* スクロールアニメーション用共通クラス */
.fade-in {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 1s ease-out, transform 1s ease-out;
}
.fade-in.is-visible {
    opacity: 1;
    transform: translateY(0);
}


/************************************
** 2. トップページ専用スコープ（干渉防止）
************************************/
.akali-top-wrapper {
    overflow: hidden;
    margin-top: -30px;
}
.akali-top-wrapper section { padding: 100px 0; background: #fff; }
.akali-top-wrapper section.bg-light { background: #faf8f5; }
.akali-container { max-width: 1000px; margin: 0 auto; padding: 0 20px; }

/* 見出しデザイン */
.akali-heading {
    font-size: clamp(24px, 4vw, 34px) !important;
    color: #4a3b32 !important;
    font-weight: bold !important;
    line-height: 1.4 !important;
    margin: 0 0 1em 0 !important;
    padding: 0 !important;
    border: none !important;
    background: none !important;
    position: relative;
}
.akali-heading.center { text-align: center; display: block; }
.akali-heading.white { color: #fff !important; }
.akali-heading::after {
    content: ""; display: block; width: 40px; height: 3px;
    background: #e58b90; border-radius: 3px; margin-top: 15px;
}
.akali-heading.center::after { margin: 15px auto 0; }
.akali-heading.white::after { background: #fff; }

.akali-sub-heading { font-size: 18px; color: #d47076; font-weight: bold; margin-bottom: 2em; }
.akali-sub-heading.white { color: #fff; }
.akali-text { font-size: 16px; line-height: 2; color: #444; margin-bottom: 1.5em; }
.akali-text strong { background: linear-gradient(transparent 60%, #ffe0e2 60%); padding: 0 4px; }
.center { text-align: center; }
.highlight { color: #d47076; }

/* 画像デザイン */
.flex-container { display: flex; align-items: center; justify-content: space-between; gap: 60px; }
.akali-feature.reverse .flex-container { flex-direction: row-reverse; }
.akali-img-box { width: 45%; }
.akali-text-box { width: 55%; }
.akali-img-box img {
    width: 100%; height: auto; border-radius: 15px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08); vertical-align: bottom;
}
.message-img img { max-width: 320px; margin: 0 auto; display: block; }

/* ==================
   ヒーローセクション
================== */
.akali-hero {
    position: relative; width: 100%; height: 85vh; min-height: 600px;
    display: flex; align-items: flex-end; justify-content: center;
    text-align: center; overflow: hidden; padding: 0 20px 80px 20px !important; 
    margin-top: -30px;
}
.akali-hero-bg { position: absolute; top: 0; left: 0; width: 100%; height: 100%; z-index: 1; }
.akali-hero-bg .bg-img {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background-size: cover; background-position: center;
    opacity: 0; animation: akaliSlideFade 15s infinite;
}
.akali-hero-bg .img1 { background-image: url('https://akali-nail.com/wp-content/uploads/2025/10/IMG_0044.jpeg.webp'); animation-delay: 0s; }
.akali-hero-bg .img2 { background-image: url('https://akali-nail.com/wp-content/uploads/2025/10/IMG_2742.jpeg.webp'); animation-delay: 5s; }
.akali-hero-bg .img3 { background-image: url('https://akali-nail.com/wp-content/uploads/2025/10/IMG_9606.jpeg.webp'); animation-delay: 10s; }

@keyframes akaliSlideFade {
    0% { opacity: 0; transform: scale(1); }
    10% { opacity: 1; }
    33% { opacity: 1; }
    43% { opacity: 0; transform: scale(1.05); }
    100% { opacity: 0; transform: scale(1); }
}
.akali-hero-gradient {
    position: absolute; top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(to bottom, rgba(0,0,0,0) 40%, rgba(0,0,0,0.8) 100%); z-index: 2;
}
.akali-hero-content { position: relative; z-index: 3; max-width: 900px; width: 100%; }
.akali-hero-title {
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important;
    font-size: clamp(26px, 5vw, 44px) !important; font-weight: normal !important;
    color: #ffffff !important; line-height: 1.5 !important;
    margin: 0 0 15px 0 !important; text-shadow: 0 2px 10px rgba(0,0,0,0.6); letter-spacing: 0.05em;
}
.akali-hero-lead {
    font-size: clamp(14px, 2.5vw, 16px); color: #f8f8f8; 
    margin-bottom: 40px; letter-spacing: 0.05em; text-shadow: 0 2px 6px rgba(0,0,0,0.8);
}

/* ボタン群 */
.akali-cta-group { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.akali-btn {
    display: inline-flex; align-items: center; justify-content: center;
    padding: 14px 40px; border-radius: 50px; font-size: 15px; letter-spacing: 0.05em;
    text-decoration: none; transition: all 0.4s ease; min-width: 260px;
}
.btn-elegant-line {
    background: rgba(6, 199, 85, 0.85); color: #fff !important;
    border: 1px solid rgba(255,255,255,0.4); backdrop-filter: blur(5px);
}
.btn-elegant-line:hover { background: rgba(6, 199, 85, 1); transform: translateY(-3px); }
.btn-elegant-white {
    background: rgba(255, 255, 255, 0.15); color: #fff !important;
    border: 1px solid #fff; backdrop-filter: blur(5px);
}
.btn-elegant-white:hover { background: #fff; color: #333 !important; transform: translateY(-3px); }

.btn-pink { background: #e58b90; color: #fff !important; font-weight: bold; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.btn-pink:hover { background: #d47076; transform: translateY(-3px); box-shadow: 0 6px 15px rgba(229, 139, 144, 0.4); }
.btn-line { background: #06C755; color: #fff !important; font-weight: bold; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.btn-line:hover { background: #05a044; transform: translateY(-3px); box-shadow: 0 6px 15px rgba(6, 199, 85, 0.4); }
.btn-white { background: #fff; color: #4a3b32 !important; font-weight: bold; box-shadow: 0 4px 10px rgba(0,0,0,0.1); }
.btn-white:hover { background: #f9f9f9; transform: translateY(-3px); box-shadow: 0 6px 15px rgba(0,0,0,0.2); }

/* ==================
   コンセプト＆パララックス
================== */
.akali-concept { padding: 60px 0; }
.concept-inner { text-align: center; position: relative; padding: 40px 20px; }
.concept-en {
    font-family: 'Times New Roman', serif; font-size: clamp(40px, 8vw, 100px);
    color: rgba(229, 139, 144, 0.1); font-weight: bold; letter-spacing: 0.1em;
    position: absolute; top: -20px; left: 50%; transform: translateX(-50%);
    width: 100%; z-index: 0; pointer-events: none; margin: 0;
}
.concept-inner h2, .concept-inner p { position: relative; z-index: 1; }

.akali-parallax-bg {
    width: 100%; height: 250px; background-attachment: fixed; background-size: cover; background-position: center;
    position: relative; display: flex; align-items: center; justify-content: center;
}
.parallax-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.3); }
.parallax-text { position: relative; z-index: 2; color: #fff; font-size: 22px; font-weight: bold; letter-spacing: 0.1em; text-shadow: 0 2px 4px rgba(0,0,0,0.5); }

/* ==================
   PHP出力カード整形
================== */
.akali-voice { background-size: cover; background-position: center; background-attachment: fixed; position: relative; }
.akali-overlay-dark { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(80, 50, 50, 0.85); z-index: 1; }
.akali-voice .relative { position: relative; z-index: 2; }

.akali-php-wrapper {
    display: grid !important; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)) !important;
    gap: 30px !important; margin: 40px 0 0 0 !important; padding: 0 !important; width: 100% !important;
}
.akali-php-wrapper > a, .akali-php-wrapper article, .akali-php-wrapper .s17-l-i, .akali-php-wrapper .s-20-list, .akali-php-wrapper > div > div {
    display: flex !important; flex-direction: column !important; background: #ffffff !important; border-radius: 15px !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.08) !important; overflow: hidden !important; border: none !important;
    margin: 0 !important; padding: 0 !important; text-decoration: none !important; color: #333 !important;
    transition: transform 0.3s ease !important; float: none !important; width: auto !important;
}
.akali-php-wrapper article:hover, .akali-php-wrapper a:hover { transform: translateY(-5px) !important; }

.akali-php-wrapper img, .akali-php-wrapper figure, .akali-php-wrapper .s17-list-item-img, .akali-php-wrapper .s-20-img-area {
    width: 100% !important; height: 180px !important; object-fit: cover !important; order: -1 !important;
    border-radius: 15px 15px 0 0 !important; margin: 0 !important; padding: 0 !important; float: none !important; display: block !important;
}
.akali-php-wrapper figure img, .akali-php-wrapper .s17-list-item-img img, .akali-php-wrapper .s-20-img-area img { border-radius: 0 !important; }

.akali-php-wrapper h3, .akali-php-wrapper .s17-list-title, .akali-php-wrapper .title {
    font-size: 15px !important; font-weight: bold !important; color: #4a3b32 !important; line-height: 1.5 !important;
    margin: 20px 20px 10px 20px !important; padding: 0 !important; border: none !important;
}
.akali-php-wrapper p, .akali-php-wrapper .excerpt {
    font-size: 13px !important; color: #666 !important; line-height: 1.6 !important; margin: 0 20px 20px 20px !important;
    padding: 0 !important; display: -webkit-box !important; -webkit-line-clamp: 3 !important; -webkit-box-orient: vertical !important; overflow: hidden !important;
}
.akali-php-wrapper hr { display: none !important; }

.akali-cta-section { text-align: center; margin-top: 50px; padding-top: 50px; border-top: 1px dashed #ddd; }
.akali-cta-lead { font-size: 18px; font-weight: bold; color: #4a3b32; margin-bottom: 20px; }


/************************************
** 3. ブログ・固定ページ・全体デザイン（ブランド統一）
************************************/
/* 記事本文の見出し */
.article h2 {
    background: #faf8f5 !important; color: #4a3b32 !important; border: none !important;
    border-left: 6px solid #e58b90 !important; border-radius: 0 8px 8px 0 !important;
    padding: 18px 25px !important; margin: 2.5em 0 1.5em 0 !important;
    font-size: 22px !important; box-shadow: 0 2px 8px rgba(0,0,0,0.03) !important;
}
.article h3 {
    background: none !important; color: #4a3b32 !important; border: none !important;
    border-bottom: 2px dashed #e58b90 !important; padding: 0 0 10px 0 !important;
    margin: 2em 0 1em 0 !important; font-size: 20px !important;
}
.article img { border-radius: 12px !important; box-shadow: 0 4px 15px rgba(0,0,0,0.06) !important; }
.single h1.entry-title, .page h1.entry-title, h1#archive-title { 
    background: #e58b90 !important; padding: 14px 15px 15px 15px; color: #fff; border-radius: 8px;
}

/* CTAボックス最適化 */
.cta-box {
    background: #fff !important; border: 3px solid #ffe0e2 !important; border-radius: 15px !important;
    padding: 30px 20px !important; box-shadow: 0 8px 25px rgba(229,139,144,0.15) !important;
    margin: 3em 0 !important; text-align: center !important;
}
.cta-box .cta-title { color: #4a3b32 !important; font-size: 22px !important; font-weight: bold !important; margin-bottom: 15px !important; }
.cta-box .btn-wrap a, .cta-box .cta-btn a, .cta-box a.cta-btn {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    background: #e58b90 !important; color: #fff !important; border-radius: 50px !important;
    padding: 16px 40px !important; font-size: 18px !important; font-weight: bold !important;
    text-decoration: none !important; box-shadow: 0 4px 10px rgba(229, 139, 144, 0.4) !important;
    transition: all 0.3s ease !important; border: none !important; width: auto !important; min-width: 280px !important; margin: 0 auto !important;
}
.cta-box .btn-wrap a:hover, .cta-box .cta-btn a:hover, .cta-box a.cta-btn:hover {
    background: #d47076 !important; transform: translateY(-3px) !important; box-shadow: 0 6px 15px rgba(229, 139, 144, 0.6) !important;
}
.cta-thumb img { width: 50%; margin-top: 12px; margin-bottom: 12px; border-radius: 10px !important; }

/* 既存のボタンデザイン（流用・調整） */
.list-link { text-align: center; margin-top: 20px; }
.list-link a {
    display: inline-block; background-color: #e58b90; color: #fff !important;
    font-size: 1.1rem; padding: 12px 24px; border-radius: 50px; text-decoration: none; font-weight: bold;
    box-shadow: 0 4px 10px rgba(0,0,0,0.08); transition: background-color 0.3s, transform 0.2s;
}
.list-link a:hover { background-color: #d47076; transform: translateY(-2px); }

/* サイドバー・フッター */
aside#nav_menu-2 a, a.new-entry-card-link, a.popular-entry-card-link { color: #333; border-bottom: 1px solid #ddd; }
a.new-entry-card-link:hover, a.popular-entry-card-link:hover { color: #e58b90; background: #faf8f5; }
h2.widget-below-related-entries-title { text-align: center; }
.widget-page-content-bottom-title { text-align: center; background: #faf8f5; margin-bottom: 10px; padding: 10px; border-left: 5px solid #e58b90; }

.footer-widgets.cf h3 { text-align: center; margin-bottom: 25px; color:#fff;}
footer#footer { padding: 0; position: relative; margin-top: 0 !important; background: #4a3b32 !important; color: #fff !important; padding-top: 50px !important; }
footer#footer:before { content: none; }
div#footer-in { position: relative; color: #fff; padding-top: 20px; padding-bottom: 50px; }
img.site-logo-image.footer-site-logo-image { width: 190px; }
#footer a { color: #fcebeb !important; text-decoration: none !important; transition: opacity 0.3s ease !important; }
#footer a:hover { opacity: 0.7 !important; }

/* その他細かな既存設定 */
.menu-item { width: 50%; }
ul#menu-content-bottom, ul#menu-content-bottom-2 { display: flex; flex-direction: row; flex-wrap: wrap; }
#menu-content-bottom .menu-item a, .menu-content-bottom-2-container a { display: block; text-align: center; border: 1px solid #ddd; margin: 0.5%; }
.menu-content-bottom-container li, .menu-content-bottom-2-container li { width: 49.5%; margin: 0!important; }
h2.related-entry-heading, .single h2 { background: #faf8f5; padding: 10px; border-left: 5px solid #e58b90; }
.related-entry-card-content { padding: 5px 10px; }
.item-label, .item-description.sub-caption { text-shadow: 1px 1px 1px black; color: #ffe8e8; }
.caption-wrap { text-shadow: 1px 1px 2px black; }

/* 追従ボタン（既存） */
.foot-link { position: fixed; bottom: 0; left: 0; width: 100%; display: flex; flex-direction: row; z-index: 9999; }
a.left { width: 50%; display: block; text-align: center; color: #fff; text-decoration: none; background: #d53b81; padding: 10px 0; font-weight: bold; }
a.right { width: 100%; display: block; text-align: center; color: #fff; text-decoration: none; background: #15ab30; padding: 10px 0; font-weight: bold; }

/* 右追従アニメーションボタン（既存） */
.foot-right-center a {
    position: fixed; right: 0; top: 29%; width: auto; height: auto;
    background: #ff007f; writing-mode: vertical-rl; text-decoration: none; color: #fff;
    padding: 30px 10px; font-weight: bold; transition: 0.5s; font-size: 20px;
    animation: bg-color 10s infinite; z-index: 9999; border-radius: 10px 0 0 10px;
}
@keyframes bg-color {
  0% { background-color: #e74c3c; } 20% { background-color: #f1c40f; } 40% { background-color: #1abc9c; }
  60% { background-color: #3498db; } 80% { background-color: #9b59b6; } 100% { background-color: #e74c3c; }
}


/************************************
** 4. レスポンシブ（スマホ・タブレット）
************************************/
@media screen and (max-width: 850px) {
    /* トップページ */
    .akali-top-wrapper section { padding: 60px 0; }
    .flex-container, .akali-feature.reverse .flex-container { flex-direction: column; gap: 30px; }
    .akali-img-box, .akali-text-box { width: 100%; }
    .akali-img-box { order: -1; }
    .akali-hero { min-height: 500px; padding: 60px 20px; align-items: center; }
    .akali-cta-group { flex-direction: column; width: 100%; }
    .akali-btn { width: 100%; }
    .concept-en { font-size: 50px; top: 0; }
    .akali-parallax-bg { background-attachment: scroll; height: 150px; }
    
    /* 既存のスマホ用メニュー調整 */
    .mobile-menu-buttons { background: none; box-shadow: none; }
    .logo-menu-button img { max-width: 84%; }
    div#header-container { box-shadow: none; }
    li.search-menu-button.menu-button { display: none; pointer-events: none; }
    li.navi-menu-button.menu-button { background: #ffdeed; width: 57px; }
    .go-to-top { bottom: 100px; }
    div#navi-menu-content { background: rgb(255 195 195 / 81%); }
    .menu-drawer a { color: #fff; font-size: 18px; padding: 21px 0 10px; border-bottom: 1px solid #fff; }
    span.fa.fa-close { color: #fff; }
    a.left:hover { background: #ff4f9f; }
    a.right:hover { background: #1cc53b; }
}

@media screen and (max-width: 480px) {
    /* 既存のモバイルフッター調整 */
    .menu-pc-head-container .menu li, .menu-content-bottom-container li, .menu-content-bottom-2-container li { width: auto; }
    .menu-content-bottom-2-container a, aside#nav_menu-2 a { color: #333 !important; border: none; border-bottom: 1px solid #ddd; }
    h3.widget-footer-mobile-title.footer-title.widget-title { text-align: center; margin-bottom: 25px; background: none; border-bottom:1px solid #fff; }
    aside#categories-5 li a { color: #fff; border-bottom: 1px solid rgba(255,255,255,0.2); text-align: center; }
}
/* =========================================================
   ★★ フッターの完全リニューアル（明るく可愛い＆ゆったりデザイン） ★★
   並びの崩れ（Cocoonの仕様）を解消した修正版
========================================================= */

/* ① フッターの背景を「ふんわり明るい薄ピンク」にして可愛い印象に */
footer#footer {
    background: #fffafa !important; 
    color: #4a3b32 !important; 
    padding: 60px 0 40px 0 !important;
    margin-top: 0 !important;
    position: relative;
    border-top: 5px solid #f8b6c8 !important; 
}
footer#footer::before {
    display: none !important; 
}

/* ② Cocoon特有の枠組みをFlexboxで綺麗に「横並び」に強制する */
div#footer-in {
    padding: 0 20px !important; 
    max-width: 1100px;
    margin: 0 auto;
}
#footer .footer-widgets-in {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: space-between !important;
    align-items: flex-start !important; /* 上端で揃える */
}

/* 3つのエリアをぴったり3等分する（古いfloat設定も解除） */
#footer .footer-left, 
#footer .footer-center, 
#footer .footer-right {
    width: 31% !important; /* 31% × 3列 ＝ 隙間を持たせて綺麗に並ぶ */
    float: none !important; /* 崩れの原因であるCocoonのデフォルト設定を無効化 */
    padding: 0 !important;
    margin: 0 0 30px 0 !important;
    box-sizing: border-box !important;
}

/* ③ フッターの見出し（ウィジェットタイトル）を可愛く装飾 */
#footer .widget-title {
    color: #d47076 !important; 
    font-size: 17px !important;
    font-weight: bold !important;
    text-align: center !important;
    border-bottom: 2px dashed #f8b6c8 !important; 
    padding: 0 0 12px 0 !important;
    margin: 0 0 25px 0 !important;
    background: none !important; 
}

/* ④ 新着記事・人気記事リストの調整（ゆったり＆白い角丸カード） */
#footer .widget-entry-cards .a-wrap {
    background: #fff !important; 
    border: 1px solid #ffe0e2 !important; 
    border-radius: 12px !important;
    padding: 12px !important; 
    margin-bottom: 15px !important; 
    display: flex !important;
    align-items: center !important;
    transition: all 0.3s ease !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.03) !important;
}
#footer .widget-entry-cards .a-wrap:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 15px rgba(229,139,144,0.15) !important;
}

/* サムネイル画像のバランス調整 */
#footer .widget-entry-card-thumb {
    width: 75px !important; 
    margin-right: 15px !important;
    flex-shrink: 0 !important;
}
#footer .widget-entry-card-thumb img {
    border-radius: 8px !important; 
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1 !important; /* 正方形にしてスッキリ見せる */
    object-fit: cover !important;
}

/* 記事タイトルの調整 */
#footer .widget-entry-card-content {
    flex-grow: 1 !important;
}
#footer .widget-entry-card-title {
    color: #4a3b32 !important;
    font-size: 13px !important;
    line-height: 1.5 !important;
    font-weight: bold !important;
}
#footer .widget-entry-card-date {
    color: #999 !important;
    font-size: 11px !important;
    margin-top: 5px !important;
    display: block !important;
}

/* ⑤ カテゴリなどのドロップダウン（窮屈感解消） */
#footer select {
    width: 100% !important;
    padding: 10px !important;
    border-radius: 8px !important;
    border: 1px solid #ddd !important;
    color: #4a3b32 !important;
    font-size: 14px !important;
}

/* ⑥ フッター内のCTAボックス（お問い合わせ）を可愛くスッキリと */
#footer .cta-box {
    background: #fff !important;
    border: 2px solid #ffe0e2 !important;
    border-radius: 15px !important;
    padding: 30px 20px !important; 
    box-shadow: 0 4px 15px rgba(229,139,144,0.1) !important;
    text-align: center !important;
}
#footer .cta-box img {
    max-width: 160px !important;
    margin: 0 auto 15px auto !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}
#footer .cta-title {
    color: #d47076 !important;
    font-size: 18px !important;
    font-weight: bold !important;
    margin-bottom: 15px !important;
    border: none !important;
}
#footer .cta-content {
    font-size: 13px !important;
    line-height: 1.6 !important;
    color: #555 !important;
    margin-bottom: 25px !important;
}

/* ⑦ 憎き「青ボタン」を強制的にピンクの可愛い丸ボタンに上書き */
#footer .cta-btn a,
#footer .btn-wrap a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #e58b90 !important; 
    color: #fff !important;
    border-radius: 50px !important; 
    padding: 14px 30px !important;
    font-size: 15px !important;
    font-weight: bold !important;
    text-decoration: none !important;
    box-shadow: 0 4px 10px rgba(229, 139, 144, 0.4) !important;
    transition: all 0.3s ease !important;
    border: none !important;
    width: 100% !important; 
    box-sizing: border-box !important;
}
#footer .cta-btn a:hover,
#footer .btn-wrap a:hover {
    background: #d47076 !important;
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 15px rgba(229, 139, 144, 0.6) !important;
}

/* =========================================================
   レスポンシブ（スマホ表示時の縦並び補正）
========================================================= */
@media screen and (max-width: 850px) {
    #footer .footer-widgets-in {
        flex-direction: column !important; /* スマホでは縦並びに */
    }
    #footer .footer-left, 
    #footer .footer-center, 
    #footer .footer-right {
        width: 100% !important; /* 横幅いっぱいに広げる */
        margin-bottom: 40px !important;
    }
    div#footer-in {
        padding: 0 15px !important;
    }
    #footer .widget-entry-cards .a-wrap {
        padding: 15px !important;
    }
    #footer .cta-box {
        padding: 30px 20px !important;
    }
}