@charset "utf-8";

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

#content, div#content, .akali-top-wrapper, .akali-hero, .main { margin-top: 0 !important; padding-top: 0 !important; }
div#wpadminbar { opacity: 0.3; }
.footer-meta, .date-tags, .home h1.entry-title, .home .article-footer, .home .entry-footer { display: none !important; }

.fade-in { opacity: 0; transform: translateY(20px); transition: opacity 1s ease-out, transform 1s ease-out; }
.fade-in.is-visible { opacity: 1; transform: translateY(0); }

/* =========================================================
   2. トップページ専用スコープ（★★ 白飛びを殺す最強リセット ★★）
========================================================= */
.akali-top-wrapper { overflow: hidden; }
.akali-top-wrapper section { padding: 90px 0; background: #fff; }
.akali-top-wrapper section.bg-light { background: #fdfaf8 !important; } 
.akali-container { max-width: 1050px; margin: 0 auto; padding: 0 25px; }

/* ▼▼▼ ココが白背景とピンク線を強制排除する最強のコード ▼▼▼ */
body #main .article .akali-top-wrapper h2,
body #main .article .akali-top-wrapper h3,
body #content .akali-top-wrapper h2,
body #content .akali-top-wrapper h3 {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
}
body #main .article .akali-top-wrapper h2::before,
body #main .article .akali-top-wrapper h3::before,
body #content .akali-top-wrapper h2::before,
body #content .akali-top-wrapper h3::before {
    display: none !important;
}

/* トップ専用見出し（akali-heading）の再構築 */
body #content .akali-top-wrapper h2.akali-heading {
    font-size: clamp(22px, 4vw, 34px) !important; color: #4a3b32 !important; font-weight: bold !important;
    line-height: 1.5 !important; margin: 0 0 1.2em 0 !important;
    position: relative; word-break: keep-all !important; overflow-wrap: break-word !important;
}
body #content .akali-top-wrapper h2.akali-heading.center { display: flex; flex-direction: column; align-items: center; text-align: center; }

/* 見出し下のピンクアクセントライン */
body #content .akali-top-wrapper h2.akali-heading::after {
    content: "" !important; display: block !important; width: 45px !important; height: 3px !important;
    background: #e58b90 !important; border-radius: 3px !important; margin-top: 15px !important;
}
body #content .akali-top-wrapper h2.akali-heading.center::after { margin: 15px auto 0 !important; }

/* 白文字見出し用 */
body #content .akali-top-wrapper h2.akali-heading.white { color: #fff !important; }
body #content .akali-top-wrapper h2.akali-heading.white::after { background: #fff !important; }
/* ▲▲▲ 白飛び対策 ここまで ▲▲▲ */


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

.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: 20px; box-shadow: 0 12px 35px rgba(0,0,0,0.08); vertical-align: bottom; }
.message-img img { max-width: 320px; margin: 0 auto; display: block; }


/* ==================
   3. ヒーローセクション
================== */
.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; }
.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 30%; 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.03); } 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.7) 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.1em; }
.akali-hero-lead { font-size: clamp(14px, 2.5vw, 16px); color: #ffffff; font-weight: bold; margin-bottom: 40px; text-shadow: 0 2px 6px rgba(0,0,0,0.8); }

/* ==================
   4. ボタンデザイン
================== */
.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: 15px 40px; border-radius: 50px; font-size: 16px; font-weight: bold; text-decoration: none; transition: all 0.3s ease; min-width: 280px; box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
.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(4px); }
.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(4px); }
.btn-elegant-white:hover { background: #fff; color: #333 !important; transform: translateY(-3px); }
.btn-pink { background: #e58b90; color: #fff !important; }
.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; }
.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; }
.btn-white:hover { background: #fdfaf8; transform: translateY(-3px); }

/* ==================
   5. コンセプト・パララックス
================== */
.akali-concept { padding: 80px 0; }
.concept-inner { text-align: center; position: relative; padding: 60px 15px 40px; }
.concept-en { font-family: 'Times New Roman', serif; font-size: clamp(35px, 9vw, 100px) !important; color: rgba(229, 139, 144, 0.12) !important; font-weight: bold; letter-spacing: 0.05em !important; position: absolute; top: 0 !important; left: 50%; transform: translateX(-50%); width: 100%; z-index: 0; pointer-events: none; margin: 0; white-space: nowrap !important; }
.concept-inner p.akali-text { 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.15em; text-shadow: 0 2px 5px rgba(0,0,0,0.5); }

/* ==================
   6. 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(90, 50, 50, 0.85); z-index: 1; }
.akali-voice .relative { position: relative; z-index: 2; }

body #content .akali-php-wrapper {
    display: grid !important; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 30px !important; margin: 40px 0 0 0 !important; padding: 0 !important; width: 100% !important;
}
body #content .akali-php-wrapper .a-wrap, 
body #content .akali-php-wrapper article {
    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; width: auto !important; float: none !important; text-decoration: none !important;
}
body #content .akali-php-wrapper .a-wrap:hover, 
body #content .akali-php-wrapper article:hover { transform: translateY(-5px) !important; }

body #content .akali-php-wrapper a, 
body #content .akali-php-wrapper a * { text-decoration: none !important; color: #4a3b32 !important; border: none !important; }
body #content .akali-php-wrapper .entry-card-thumb, 
body #content .akali-php-wrapper figure { width: 100% !important; margin: 0 !important; padding: 0 !important; order: -1 !important; border: none !important; }
body #content .akali-php-wrapper .entry-card-thumb img, 
body #content .akali-php-wrapper figure img { width: 100% !important; height: 190px !important; object-fit: cover !important; border-radius: 15px 15px 0 0 !important; margin: 0 !important; border: none !important; }

body #content .akali-php-wrapper .entry-card-title, 
body #content .akali-php-wrapper h2, 
body #content .akali-php-wrapper h3 {
    font-size: 15px !important; font-weight: bold !important; color: #4a3b32 !important; line-height: 1.5 !important;
    margin: 15px 20px 5px 20px !important; padding: 0 !important; border: none !important; background: transparent !important; box-shadow: none !important;
}
body #content .akali-php-wrapper .entry-card-snippet, 
body #content .akali-php-wrapper p {
    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; border: none !important; background: transparent !important;
}
body #content .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; }


/* =========================================================
   7. ブログ記事用見出しデザイン（トップには絶対影響させない）
========================================================= */
body:not(.home) .entry-content h2,
body:not(.home) .article h2 {
    background: #fdfaf8 !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;
}
body:not(.home) .entry-content h3,
body:not(.home) .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;
}
body:not(.home) .entry-content 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: #d47076 !important; font-size: 20px !important; font-weight: bold !important; margin-bottom: 15px !important; border: none !important; background: transparent !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: 16px !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%; max-width: 180px !important; margin: 0 auto 15px auto !important; border-radius: 10px !important; box-shadow: none !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 dashed #ddd; }
a.new-entry-card-link:hover, a.popular-entry-card-link:hover { color: #e58b90; background: #fdfaf8; }
h2.widget-below-related-entries-title { text-align: center; }
.widget-page-content-bottom-title { text-align: center; background: #fdfaf8; margin-bottom: 10px; padding: 10px; border-left: 5px solid #e58b90; }
h2.related-entry-heading, .single h2 { background: #fdfaf8; padding: 10px; border-left: 5px solid #e58b90; }
.related-entry-card-content { padding: 5px 10px; }


/* =========================================================
   8. フッターリニューアル
========================================================= */
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; }
div#footer-in { padding: 0 20px !important; max-width: 1100px; margin: 0 auto; color: #4a3b32 !important; }
#footer .footer-widgets-in { display: flex !important; flex-wrap: wrap !important; justify-content: space-between !important; align-items: flex-start !important; }
#footer .footer-left, #footer .footer-center, #footer .footer-right { width: 31% !important; float: none !important; 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; border: none !important; background: transparent !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; }
#footer a { color: #4a3b32 !important; text-decoration: none !important; }
#footer a:hover { color: #d47076 !important; }
.footer-bottom-logo img { width: 190px; }


/* =========================================================
   9. メニュー・ボタンの2列化とノイズ除去
========================================================= */
.widget_nav_menu ul, .widget_pages ul { display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; border: none !important; padding: 0 !important; }
.widget_nav_menu ul li, .widget_pages ul li { border: none !important; margin: 0 !important; width: 100% !important; }
.widget_nav_menu ul li:last-child:nth-child(odd), .widget_pages ul li:last-child:nth-child(odd) { grid-column: span 2 !important; }
.widget_nav_menu ul li a, .widget_pages ul li a { display: flex !important; align-items: center !important; justify-content: center !important; background: #fff !important; border: 2px solid #ffe0e2 !important; border-radius: 10px !important; padding: 12px 5px !important; font-size: 13px !important; font-weight: bold !important; color: #4a3b32 !important; text-align: center !important; box-shadow: 0 4px 10px rgba(229,139,144,0.08) !important; transition: all 0.3s ease !important; height: 100% !important; line-height: 1.3 !important; }
.widget_nav_menu ul li a:hover { background: #fdfaf8 !important; border-color: #d47076 !important; color: #d47076 !important; transform: translateY(-2px) !important; }

.widget_categories select, .widget_archive select { width: 100% !important; padding: 14px 15px !important; border: 2px solid #ffe0e2 !important; border-radius: 10px !important; background: #fff !important; color: #4a3b32 !important; font-size: 15px !important; font-weight: bold !important; box-shadow: 0 4px 10px rgba(229,139,144,0.08) !important; appearance: none !important; background-image: url('data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2214%22%20height%3D%228%22%20viewBox%3D%220%200%2014%208%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M1%201L7%207L13%201%22%20stroke%3D%22%23e58b90%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E') !important; background-repeat: no-repeat !important; background-position: right 15px center !important; cursor: pointer; }


/* =========================================================
   10. スマホ専用：上品な追従LINEボタン（スクロール連動版）
========================================================= */
/* PCでは非表示 */
.akali-floating-btn { display: none !important; }
.foot-link, .foot-right-center, .相談問い合せはコチラ { display: none !important; }

@media screen and (max-width: 850px) {
    .akali-floating-btn {
        display: flex !important;
        justify-content: center;
        position: fixed;
        left: 0;
        width: 100%;
        z-index: 99999;
        
        /* 初期状態は画面外に隠しておく */
        bottom: -100px;
        opacity: 0;
        pointer-events: none; /* 透明な時は誤タップを防止 */
        transition: bottom 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.3s ease !important;
    }
    
    /* プログラムによって is-show クラスが付いたら、スッと定位置へ上がる */
    .akali-floating-btn.is-show {
        bottom: 25px !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }
    
    .akali-floating-btn a {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        background: #ffffff !important;
        color: #4a3b32 !important;
        text-decoration: none !important;
        padding: 12px 28px !important;
        border-radius: 50px !important;
        font-weight: bold !important;
        font-size: 14px !important;
        box-shadow: 0 6px 20px rgba(229, 139, 144, 0.25) !important;
        border: 1px solid #ffe0e2 !important;
        letter-spacing: 0.05em;
        transition: transform 0.2s ease !important;
    }

    .akali-floating-btn a:active {
        transform: scale(0.95) !important;
        background: #fdfaf8 !important;
    }

    /* LINEアイコンの設定 */
    .akali-floating-btn a i {
        color: #06C755 !important;
        font-size: 20px !important;
        margin-right: 8px !important;
    }

    /* クレジット被り防止 */
    footer#footer { padding-bottom: 90px !important; }
}
/* =========================================================
   11. レスポンシブ設計（スマホ対応）
========================================================= */
@media screen and (max-width: 850px) {
    .akali-top-wrapper section { padding: 60px 0; }
    .flex-container, .flex-container.reverse { flex-direction: column; gap: 35px; }
    .akali-img-box, .akali-text-box { width: 100%; text-align: center; }
    .akali-img-box { order: -1; }
    
    .akali-hero { height: 60vh !important; min-height: 400px !important; padding-bottom: 50px !important; align-items: center; }
    .akali-hero-gradient { background: linear-gradient(to bottom, rgba(0,0,0,0) 20%, rgba(0,0,0,0.6) 100%) !important; }
    #content .akali-top-wrapper h2.akali-hero-title { font-size: 22px !important; padding: 0 10px !important; margin-bottom: 15px !important; }
    .akali-hero-lead { font-size: 14px !important; margin-bottom: 30px; }
    
    .akali-cta-group { flex-direction: column; width: 100%; align-items: center; }
    .akali-btn { width: 100%; max-width: 320px; box-sizing: border-box; }
    
    .concept-inner { padding: 60px 10px 40px !important; }
    .akali-parallax-bg { background-attachment: scroll; height: 180px; }

    #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; }

    .mobile-menu-buttons { background: none; box-shadow: none; }
    .logo-menu-button img { max-width: 84%; }
    li.search-menu-button.menu-button { display: none; pointer-events: none; }
    li.navi-menu-button.menu-button { background: #fdfaf8; width: 57px; border-radius: 8px; }
    div#navi-menu-content { background: rgba(253, 250, 248, 0.95); }
    .menu-drawer a { color: #4a3b32; font-size: 18px; padding: 21px 0 10px; border-bottom: 1px dashed #e58b90; }
    span.fa.fa-close { color: #4a3b32; }
}

@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; }
    h3.widget-footer-mobile-title.footer-title.widget-title { text-align: center; margin-bottom: 25px; background: none; border-bottom: 2px dashed #f8b6c8; }
    aside#categories-5 li a { color: #4a3b32; border-bottom: 1px dashed rgba(229,139,144,0.3); text-align: center; }
}
/* =========================================================
   12. コース料金ページ（ラグジュアリー・エレガント仕様）
========================================================= */
.akali-premium-course { max-width: 800px; margin: 0 auto; padding: 40px 15px 80px; }

/* セクション見出し */
.p-course-header { text-align: center; margin-bottom: 50px; }
.p-course-en { font-family: 'Times New Roman', serif; color: #e58b90; font-size: 13px; letter-spacing: 0.2em; font-weight: bold; }
body #content .p-course-ja { 
    font-size: 26px !important; color: #4a3b32 !important; border: none !important; 
    background: none !important; margin: 10px 0 15px 0 !important; font-weight: normal !important; 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; letter-spacing: 0.1em !important; box-shadow: none !important; padding: 0 !important;
}
body #content .p-course-ja::after { content: ''; display: block; width: 40px; height: 1px; background: #e58b90; margin: 15px auto 0; }
.p-course-lead { font-size: 14px; color: #666; margin-top: 20px; line-height: 1.8; }

/* リスト全体のレイアウト */
.p-course-list { display: flex; flex-direction: column; gap: 40px; }

/* カード本体のデザイン（線をなくして影と上部のアクセントカラーで魅せる） */
.p-course-card {
    background: #fff; border-radius: 12px;
    box-shadow: 0 15px 40px rgba(0,0,0,0.04);
    padding: 40px; position: relative;
    border-top: 5px solid #ffe0e2; /* 上部だけに上品なピンクのライン */
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.p-course-card:hover { transform: translateY(-3px); box-shadow: 0 20px 50px rgba(229,139,144,0.1); }

/* PC向けレイアウト（左に説明、右に料金） */
@media screen and (min-width: 768px) {
    .p-course-card { display: grid; grid-template-columns: 1fr 300px; gap: 40px; align-items: center; }
    .p-card-bottom { grid-column: 1 / -1; text-align: center; margin-top: 20px; border-top: 1px solid #f9f0f0; padding-top: 30px; }
}
@media screen and (max-width: 767px) {
    .p-course-card { padding: 30px 20px; }
    .p-card-price { margin-top: 25px; }
    .p-card-bottom { text-align: center; margin-top: 30px; }
}

/* 各パーツのデザイン */
body #content .p-card-title { 
    font-size: 20px !important; color: #4a3b32 !important; margin: 0 0 15px 0 !important; 
    border: none !important; background: none !important; box-shadow: none !important; padding: 0 !important; font-weight: bold !important;
}
.p-card-desc { font-size: 14px; color: #555; line-height: 1.8; margin-bottom: 0; }

/* 料金表エリア（透明感のある背景） */
.p-card-price { background: #fdfaf8; padding: 25px; border-radius: 8px; }
.p-price-row { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 15px; border-bottom: 1px dashed #eedddd; padding-bottom: 10px; }
.p-price-row:last-child { margin-bottom: 0; border-bottom: none; padding-bottom: 0; }
.p-price-label { font-size: 13px; color: #4a3b32; font-weight: bold; line-height: 1.4; }

/* 金額のフォントを美しく */
.p-price-num { font-size: 24px; color: #d47076; font-family: 'Times New Roman', serif; font-weight: bold; line-height: 1; letter-spacing: 0.05em; }
.p-price-tax { font-size: 11px; color: #999; margin-left: 5px; font-weight: normal; font-family: sans-serif; letter-spacing: 0; }
.p-price-note { font-size: 11px; color: #888; margin-top: 12px; margin-bottom: 0; text-align: right; }

/* 洗練されたラインボタン */
.p-course-btn {
    display: inline-block; padding: 15px 60px; background: #fff !important; color: #d47076 !important;
    border: 1px solid #d47076 !important; border-radius: 50px !important; font-weight: bold !important; 
    text-decoration: none !important; transition: all 0.3s ease !important; font-size: 14px !important; letter-spacing: 0.05em;
}
.p-course-btn:hover { background: #d47076 !important; color: #fff !important; transform: translateY(-2px); box-shadow: 0 5px 15px rgba(212,112,118,0.2); }

/* =========================================================
   13. お問い合わせページ（ラグジュアリー仕様＆フォーム最適化）
========================================================= */
.akali-premium-contact { max-width: 800px; margin: 0 auto; padding: 40px 15px 80px; }

/* 見出し部分（料金ページと共通のエレガントスタイル） */
.p-contact-header { text-align: center; margin-bottom: 50px; }
.p-contact-en { font-family: 'Times New Roman', serif; color: #e58b90; font-size: 13px; letter-spacing: 0.2em; font-weight: bold; }
body #content .p-contact-ja { 
    font-size: 26px !important; color: #4a3b32 !important; border: none !important; 
    background: none !important; margin: 10px 0 15px 0 !important; font-weight: normal !important; 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; letter-spacing: 0.1em !important; box-shadow: none !important; padding: 0 !important;
}
body #content .p-contact-ja::after { content: ''; display: block; width: 40px; height: 1px; background: #e58b90; margin: 15px auto 0; }
.p-contact-lead { font-size: 15px; color: #666; margin-top: 20px; line-height: 1.8; }

/* 共通の重要事項ボックス（上品な警告） */
.p-contact-notice { background: #fffafb; border: 1px solid #f8b6c8; border-radius: 12px; padding: 30px; margin-bottom: 50px; box-shadow: 0 4px 15px rgba(229,139,144,0.1); }
.notice-title { font-size: 18px !important; color: #d47076 !important; margin: 0 0 20px 0 !important; border: none !important; background: none !important; padding: 0 !important; font-weight: bold !important; box-shadow: none !important; text-align: center; }
.notice-list { list-style: none; padding: 0; margin: 0; }
.notice-list li { display: flex; align-items: flex-start; margin-bottom: 20px; }
.notice-list li:last-child { margin-bottom: 0; }
.notice-label { display: inline-block; background: #4a3b32; color: #fff; font-size: 12px; padding: 4px 12px; border-radius: 4px; font-weight: bold; margin-right: 15px; white-space: nowrap; margin-top: 3px; }
.notice-label.red { background: #d47076; }
.notice-list p { margin: 0; font-size: 14px; line-height: 1.6; color: #444; }
.red-text { color: #d47076; }
.small-text { font-size: 12px; color: #888; display: block; margin-top: 4px; }
@media screen and (max-width: 600px) {
    .notice-list li { flex-direction: column; }
    .notice-label { margin-bottom: 8px; }
}

/* 連絡手段のカード化 */
.p-contact-card { background: #fff; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,0.05); margin-bottom: 40px; overflow: hidden; border: 1px solid #eee; }
.card-title-area { background: #fdfaf8; padding: 20px 30px; border-bottom: 1px solid #eee; display: flex; justify-content: space-between; align-items: center; }
body #content .method-title { font-size: 18px !important; color: #4a3b32 !important; margin: 0 !important; padding: 0 !important; border: none !important; background: none !important; box-shadow: none !important; font-weight: bold !important; }
.line-color { color: #06C755; margin-right: 8px; }
.recommend-badge { background: #ffe0e2; color: #d47076; font-size: 11px; font-weight: bold; padding: 4px 10px; border-radius: 50px; }
.method-body { padding: 40px 30px; }
@media screen and (max-width: 600px) {
    .card-title-area { flex-direction: column; text-align: center; gap: 10px; }
    .method-body { padding: 30px 20px; }
}

/* LINEの手順フロー */
.line-steps { display: flex; justify-content: space-between; align-items: center; margin-bottom: 30px; gap: 10px; }
.step-box { background: #fff; border: 2px solid #06C755; border-radius: 8px; padding: 15px 10px; text-align: center; flex: 1; position: relative; }
.step-num { display: inline-block; background: #06C755; color: #fff; font-size: 11px; font-weight: bold; padding: 2px 10px; border-radius: 50px; position: absolute; top: -12px; left: 50%; transform: translateX(-50%); }
.step-box p { margin: 0; font-size: 13px; font-weight: bold; color: #444; line-height: 1.4; padding-top: 5px; }
.step-arrow { color: #ccc; font-size: 20px; }
@media screen and (max-width: 600px) {
    .line-steps { flex-direction: column; gap: 20px; }
    .step-box { width: 100%; }
    .step-arrow { transform: rotate(90deg); margin: -5px 0; }
}

/* LINE画像 */
.line-image-wrap { text-align: center; margin-bottom: 30px; }
.line-image-wrap img { max-width: 250px; width: 100%; border-radius: 12px; box-shadow: 0 4px 15px rgba(0,0,0,0.1); border: 1px solid #eee; }

/* ボタン中央寄せ */
.btn-wrap-center { text-align: center; }
.btn-line-official {
    display: inline-flex; align-items: center; justify-content: center; background: #06C755; color: #fff !important;
    padding: 16px 40px; border-radius: 50px; font-weight: bold; font-size: 16px; text-decoration: none !important;
    box-shadow: 0 4px 15px rgba(6, 199, 85, 0.3); transition: all 0.3s ease; letter-spacing: 0.05em; width: 100%; max-width: 350px;
}
.btn-line-official:hover { background: #05a044; transform: translateY(-3px); box-shadow: 0 6px 20px rgba(6, 199, 85, 0.4); }
.btn-line-official i { font-size: 22px; margin-right: 10px; }

/* メール注意書きエリア */
.email-warning { background: #fdfdfd; border-left: 4px solid #d47076; padding: 20px 25px; margin-bottom: 30px; border-radius: 0 8px 8px 0; box-shadow: 0 2px 10px rgba(0,0,0,0.02); }
body #content .warning-title { font-size: 16px !important; color: #d47076 !important; margin: 0 0 15px 0 !important; border: none !important; background: none !important; padding: 0 !important; font-weight: bold !important; box-shadow: none !important; }
.email-warning p { font-size: 14px; color: #555; line-height: 1.6; margin-bottom: 10px; }
.warning-alert { color: #d47076; font-weight: bold; background: #ffe0e2; padding: 8px 15px; border-radius: 4px; display: inline-block; }
.warning-notes { margin: 15px 0 0 20px; padding: 0; font-size: 13px; color: #666; line-height: 1.6; }
.warning-notes li { margin-bottom: 8px; }
.warning-notes code { background: #eee; padding: 2px 6px; border-radius: 4px; color: #333; }

/* フォーム入力指示 */
.form-instruction { text-align: center; margin-bottom: 40px; }
.form-instruction p { font-size: 14px; font-weight: bold; color: #4a3b32; margin-bottom: 15px; }
.form-choice { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.form-choice span { background: #fdfaf8; border: 1px solid #eee; padding: 10px 20px; border-radius: 50px; font-size: 13px; color: #555; }
.form-choice i { color: #d47076; margin: 0 8px; }
.form-choice strong { color: #d47076; }

/* =========================================
   Contact Form 7 のデザインをオシャレに
========================================= */
.akali-cf7-wrapper { margin-top: 20px; }
.akali-cf7-wrapper label { font-size: 14px; font-weight: bold; color: #4a3b32; display: block; margin-bottom: 8px; }
.akali-cf7-wrapper .wpcf7-form-control-wrap { display: block; margin-bottom: 25px; }

/* 入力欄のデザイン */
.akali-cf7-wrapper input[type="text"],
.akali-cf7-wrapper input[type="email"],
.akali-cf7-wrapper input[type="tel"],
.akali-cf7-wrapper select,
.akali-cf7-wrapper textarea {
    width: 100%; padding: 14px 15px; border: 1px solid #ddd; border-radius: 8px;
    background: #fafafa; font-size: 15px; color: #333; box-sizing: border-box;
    transition: all 0.3s ease; font-family: inherit;
}
/* 入力中の色（ピンク） */
.akali-cf7-wrapper input:focus, 
.akali-cf7-wrapper select:focus, 
.akali-cf7-wrapper textarea:focus {
    border-color: #e58b90; background: #fff; outline: none; box-shadow: 0 0 0 3px rgba(229, 139, 144, 0.15);
}

/* 送信ボタン（エレガントスタイル） */
.akali-cf7-wrapper input[type="submit"] {
    display: block; width: 100%; max-width: 350px; margin: 40px auto 0;
    background: #e58b90; color: #fff; padding: 18px 30px; border: none; border-radius: 50px;
    font-size: 16px; font-weight: bold; cursor: pointer; letter-spacing: 0.1em;
    transition: all 0.3s ease; box-shadow: 0 4px 15px rgba(229, 139, 144, 0.3);
}
.akali-cf7-wrapper input[type="submit"]:hover {
    background: #d47076; transform: translateY(-3px); box-shadow: 0 6px 20px rgba(229, 139, 144, 0.4);
}

/* =========================================================
   14. 講師紹介ページ（ラグジュアリー仕様・完全版）
========================================================= */
.akali-premium-profile { max-width: 800px; margin: 0 auto; padding: 40px 15px 80px; }

/* プロフィール上部（写真と名前） */
.profile-header { display: flex; align-items: center; gap: 40px; margin-bottom: 50px; }
.profile-img { flex-shrink: 0; width: 200px; }
/* 画像を美しい円形にし、ピンクの影を落とす */
.profile-img img { width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover; border-radius: 50%; box-shadow: 0 10px 25px rgba(229,139,144,0.2); border: 3px solid #fff; }
.profile-info { flex-grow: 1; }
.profile-en { font-family: 'Times New Roman', serif; color: #d47076; font-size: 16px; letter-spacing: 0.15em; font-weight: bold; display: block; margin-bottom: 5px; }

body #content .profile-name { 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; 
    font-size: 32px !important; color: #4a3b32 !important; margin: 0 0 15px 0 !important; 
    border: none !important; background: none !important; padding: 0 !important; 
    font-weight: normal !important; box-shadow: none !important; letter-spacing: 0.1em;
}
.profile-title { display: inline-block; background: #fdfaf8; border: 1px solid #ffe0e2; color: #4a3b32; padding: 8px 15px; border-radius: 50px; font-size: 13px; font-weight: bold; margin: 0; }

@media screen and (max-width: 600px) {
    .profile-header { flex-direction: column; text-align: center; gap: 20px; }
    .profile-img { width: 160px; }
}

/* 資格リスト */
.profile-qualifications { background: #fff; border: 1px solid #eee; border-radius: 12px; padding: 35px 40px; margin-bottom: 50px; box-shadow: 0 5px 20px rgba(0,0,0,0.03); }
body #content .qual-title { 
    font-size: 18px !important; color: #d47076 !important; text-align: center; margin: 0 0 25px 0 !important; 
    border: none !important; background: none !important; font-family: 'Times New Roman', serif !important; 
    letter-spacing: 0.1em; font-weight: bold !important; box-shadow: none !important; padding: 0 !important;
}
.qual-title::after { content: ''; display: block; width: 30px; height: 1px; background: #e58b90; margin: 10px auto 0; }
.qual-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: 15px; }
.qual-list li { display: flex; align-items: flex-start; font-size: 14px; color: #4a3b32; font-weight: bold; line-height: 1.5; }
.qual-list li i { color: #e58b90; margin-top: 3px; margin-right: 12px; font-size: 14px; }

/* メッセージエリア（雑誌のインタビュー風） */
.profile-message { position: relative; padding: 40px; background: #fdfaf8; border-radius: 12px; border: 1px solid #f9f0f0; margin-bottom: 60px; }
.profile-message::before { content: '“'; position: absolute; top: 10px; left: 20px; font-size: 80px; color: #ffe0e2; font-family: serif; line-height: 1; }
body #content .message-title { 
    font-size: 22px !important; color: #4a3b32 !important; text-align: center; margin: 0 0 30px 0 !important; 
    border: none !important; background: none !important; padding: 0 !important; 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; letter-spacing: 0.1em !important; 
    box-shadow: none !important; font-weight: normal !important; position: relative; z-index: 1;
}
.message-body { position: relative; z-index: 1; font-size: 15px; color: #444; line-height: 1.8; text-align: justify; }
.message-body p { margin-bottom: 1.5em; }
.message-body p:last-child { margin-bottom: 0; }

@media screen and (max-width: 600px) {
    .profile-qualifications { padding: 30px 20px; }
    .profile-message { padding: 30px 20px; }
    .profile-message::before { top: 5px; left: 10px; font-size: 60px; }
}

/* 下部リンクエリア */
.profile-more-links { text-align: center; padding-top: 40px; border-top: 1px dashed #eedddd; }
.link-lead { font-size: 16px; font-weight: bold; color: #4a3b32; margin-bottom: 25px; }
/* ボタンはトップページのデザイン（akali-btn）を引き継ぎます */
/* =========================================================
   15. カテゴリページ（PC・スマホ両対応：高級カード化）
========================================================= */

/* カテゴリタイトルの装飾（STUDENT'S VOICE） */
h1#archive-title {
    background: transparent !important;
    color: #4a3b32 !important;
    text-align: center;
    font-size: 26px !important;
    padding: 60px 0 30px 0 !important;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important;
    border: none !important;
    letter-spacing: 0.1em;
}
h1#archive-title::after {
    content: "STUDENT'S VOICE";
    display: block;
    font-family: 'Times New Roman', serif;
    font-size: 13px;
    color: #e58b90;
    letter-spacing: 0.3em;
    margin-top: 12px;
}

/* 記事一覧全体のコンテナ（PCで広がりすぎないように最大幅を制限） */
#main .entry-card-wrap {
    max-width: 1000px !important; /* 広がりすぎ防止 */
    margin: 0 auto !important;
    padding: 20px 20px 80px 20px !important;
    display: grid !important;
    /* PCでは3列、中画面では2列、スマホでは1列に自動調整 */
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 40px 30px !important;
}

/* 記事カード本体（余白と影でリッチに） */
#main .entry-card-wrap .a-wrap {
    background: #fff !important;
    border: none !important; /* 枠線を消して影を主役にする */
    border-top: 4px solid #ffe0e2 !important; /* 上部だけにアクセントライン */
    border-radius: 12px !important;
    box-shadow: 0 15px 35px rgba(0, 0, 0, 0.05) !important;
    overflow: hidden !important;
    transition: all 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    text-decoration: none !important;
}
#main .entry-card-wrap .a-wrap:hover {
    transform: translateY(-8px) !important;
    box-shadow: 0 20px 45px rgba(229, 139, 144, 0.15) !important;
}

/* カード内の画像（高さを抑えてスマートに） */
.entry-card-thumb {
    width: 100% !important;
    margin: 0 !important;
    overflow: hidden;
}
.entry-card-thumb img {
    height: 180px !important; /* 少し高さを抑える */
    object-fit: cover !important;
    transition: transform 0.6s ease !important;
}
#main .entry-card-wrap .a-wrap:hover .entry-card-thumb img {
    transform: scale(1.05); /* ホバー時に少しズーム */
}

/* カード内のテキストエリア */
.entry-card-content {
    padding: 25px 20px !important;
    flex-grow: 1;
}

/* 記事タイトル */
#main .entry-card-title {
    font-size: 16px !important; /* 少し小さくして品よく */
    color: #4a3b32 !important;
    font-weight: bold !important;
    line-height: 1.6 !important;
    margin-bottom: 15px !important;
}

/* 抜粋文 */
.entry-card-snippet {
    font-size: 13px !important;
    color: #666 !important;
    line-height: 1.7 !important;
    margin-bottom: 0 !important;
}

/* 日付などのメタ情報（右寄せで控えめに） */
.entry-card-meta {
    padding: 0 20px 20px !important;
    text-align: right;
    font-size: 10px !important;
    color: #bbb !important;
    border: none !important;
}
.entry-card-meta .post-date, .entry-card-meta .post-update {
    display: inline-block;
}

/* スマホ表示での微調整 */
@media screen and (max-width: 600px) {
    #main .entry-card-wrap {
        grid-template-columns: 1fr !important;
        padding: 20px 15px 60px 15px !important;
    }
}

/* =========================================================
   16. よくある質問（FAQ）アコーディオンデザイン
========================================================= */
.akali-faq-wrapper { max-width: 800px; margin: 0 auto; padding: 40px 15px 80px; }

.faq-header { text-align: center; margin-bottom: 60px; }
.faq-en { font-family: 'Times New Roman', serif; color: #e58b90; font-size: 13px; letter-spacing: 0.2em; font-weight: bold; }
body #content .faq-ja { 
    font-size: 26px !important; color: #4a3b32 !important; border: none !important; 
    background: none !important; margin: 10px 0 !important; font-weight: normal !important; 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; letter-spacing: 0.1em !important; box-shadow: none !important; padding: 0 !important;
}

.faq-category { margin-bottom: 50px; }
.faq-cat-title { 
    font-family: 'Times New Roman', serif; font-size: 24px; color: #f2c9cc; margin-bottom: 20px !important; 
    display: flex; align-items: baseline; gap: 10px; border-bottom: 1px solid #eee; padding-bottom: 10px;
}
.faq-cat-title span { font-size: 14px; color: #4a3b32; font-family: sans-serif; font-weight: bold; }

/* アコーディオン本体 */
.faq-item { background: #fff; border-bottom: 1px solid #f9f0f0; }
.faq-item summary {
    padding: 20px 40px 20px 0; list-style: none; cursor: pointer; position: relative;
    font-weight: bold; color: #4a3b32; font-size: 15px; line-height: 1.5;
}
/* 矢印アイコンをプラス・マイナスに変更 */
.faq-item summary::before {
    content: 'Q.'; color: #e58b90; font-family: 'Times New Roman', serif; font-size: 20px;
    margin-right: 12px;
}
.faq-item summary::after {
    content: '+'; position: absolute; right: 10px; top: 50%; transform: translateY(-50%);
    color: #e58b90; font-size: 24px; font-weight: normal; transition: 0.3s;
}
.faq-item[open] summary::after { content: '−'; transform: translateY(-50%) rotate(180deg); }

/* 回答エリア */
.faq-answer { padding: 0 0 25px 35px; animation: faqFadeIn 0.4s ease; }
.faq-answer p { margin: 0; font-size: 14px; color: #666; line-height: 1.8; }
.faq-answer strong { color: #d47076; }

@keyframes faqFadeIn {
    0% { opacity: 0; transform: translateY(-10px); }
    100% { opacity: 1; transform: translateY(0); }
}

/* 標準の矢印を消す（iPhone対策） */
.faq-item summary::-webkit-details-marker { display: none; }

/* =========================================================
   17. 入学の流れページ（エレガント・タイムラインデザイン）
========================================================= */
.akali-flow-wrapper { max-width: 800px; margin: 0 auto; padding: 40px 15px 80px; }

.flow-intro { text-align: center; margin-bottom: 60px; }
.flow-en { font-family: 'Times New Roman', serif; color: #e58b90; font-size: 13px; letter-spacing: 0.2em; font-weight: bold; }
body #content .flow-ja { 
    font-size: 26px !important; color: #4a3b32 !important; border: none !important; 
    background: none !important; margin: 10px 0 !important; font-weight: normal !important; 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; letter-spacing: 0.1em !important; box-shadow: none !important; padding: 0 !important;
}
.flow-lead { font-size: 14px; color: #666; margin-top: 20px; line-height: 1.8; }

/* セクション区切り */
.flow-section { margin-bottom: 80px; }
.flow-header-box { background: #fdfaf8; padding: 25px; border-radius: 12px; margin-bottom: 40px; text-align: center; border: 1px solid #f9f0f0; }
.flow-section-title { font-size: 18px !important; color: #4a3b32 !important; margin: 0 !important; font-weight: bold !important; line-height: 1.5 !important; border:none !important; background:none !important; padding:0 !important; box-shadow:none !important; }
.flow-section-title .small { display: block; font-size: 13px; color: #d47076; margin-bottom: 5px; font-weight: normal; }

/* タイムライン本体 */
.step-container { position: relative; padding-left: 20px; }
/* 縦のライン */
.step-container::before {
    content: ''; position: absolute; left: 35px; top: 0; bottom: 0;
    width: 1px; background: #ffe0e2; z-index: 1;
}

.step-item { position: relative; padding-left: 60px; margin-bottom: 40px; z-index: 2; }
.step-item:last-child { margin-bottom: 0; }

/* ステップ番号（円） */
.step-num {
    position: absolute; left: -10px; top: -5px; width: 32px; height: 32px;
    background: #fff; border: 2px solid #e58b90; color: #e58b90;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-family: 'Times New Roman', serif; font-weight: bold; font-size: 14px; z-index: 3;
}

.step-head { font-size: 17px; font-weight: bold; color: #4a3b32; margin-bottom: 10px; }
.step-body { font-size: 14px; color: #555; line-height: 1.7; }

/* 中のリンクボタン */
.step-inline-link { display: inline-block; color: #d47076; text-decoration: none; font-weight: bold; margin-top: 10px; border-bottom: 1px solid #ffe0e2; padding-bottom: 2px; transition: 0.3s; }
.step-inline-link:hover { color: #e58b90; border-bottom-color: #e58b90; }

.flow-outro { text-align: center; margin-top: 60px; padding-top: 40px; border-top: 1px dashed #eedddd; }
.flow-outro p { font-size: 15px; color: #444; margin-bottom: 30px; line-height: 1.8; }

/* =========================================================
   18. 選ばれる理由ページ（グラフィカル・セクションデザイン）
========================================================= */
.akali-reasons-wrapper { max-width: 1000px; margin: 0 auto; padding: 40px 15px 80px; }

.reasons-header { text-align: center; margin-bottom: 80px; }
.reasons-en { font-family: 'Times New Roman', serif; color: #e58b90; font-size: 13px; letter-spacing: 0.25em; font-weight: bold; }
body #content .reasons-ja { 
    font-size: 28px !important; color: #4a3b32 !important; border: none !important; 
    background: none !important; margin: 10px 0 !important; font-weight: normal !important; 
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", serif !important; letter-spacing: 0.1em !important; box-shadow: none !important; padding: 0 !important;
}
.reasons-lead { font-size: 15px; color: #666; margin-top: 20px; line-height: 1.8; }

/* 理由の各セクション */
.reason-item { margin-bottom: 100px; position: relative; }
.reason-content { background: #fff; border-radius: 20px; padding: 50px; box-shadow: 0 15px 50px rgba(0,0,0,0.03); border: 1px solid #f9f0f0; }

.reason-tag { 
    display: inline-block; color: #e58b90; font-family: 'Times New Roman', serif; 
    font-weight: bold; border-bottom: 2px solid #e58b90; margin-bottom: 15px; font-size: 14px; letter-spacing: 0.1em;
}
body #content .reason-title { 
    font-size: 24px !important; color: #4a3b32 !important; margin: 0 0 10px 0 !important; 
    border: none !important; background: none !important; padding: 0 !important; font-weight: bold !important; box-shadow: none !important;
}
.reason-sub { color: #d47076; font-size: 15px; font-weight: bold; margin-bottom: 35px; }

/* フレックス配置 */
.reason-flex { display: flex; gap: 40px; align-items: center; }
.reason-img { flex: 1; }
.reason-img img { width: 100%; border-radius: 15px; box-shadow: 0 8px 25px rgba(0,0,0,0.08); }
.reason-text { flex: 1.2; }
.reason-text p { font-size: 15px; color: #444; line-height: 1.8; margin-bottom: 1.5em; }

/* 強調ボックス */
.highlight-box { background: #fdfaf8; padding: 20px; border-radius: 10px; border-left: 4px solid #e58b90; font-size: 14px !important; color: #4a3b32 !important; }
.highlight-box strong { color: #d47076; font-size: 17px; }

.reason-message { font-family: "游明朝", serif; font-size: 18px; color: #4a3b32; font-style: italic; border-top: 1px solid #ffe0e2; padding-top: 15px; }

/* 左右交互レイアウト（PC用） */
@media screen and (min-width: 768px) {
    .reason-item.reverse .reason-flex { flex-direction: row-reverse; }
}

/* スマホ表示 */
@media screen and (max-width: 767px) {
    .reason-content { padding: 35px 20px; }
    .reason-flex { flex-direction: column; gap: 25px; }
    body #content .reason-title { font-size: 20px !important; }
    .reason-img { order: -1; } /* 画像を先に持ってくる */
}

.reasons-outro { text-align: center; margin-top: 60px; padding-top: 50px; border-top: 1px dashed #eedddd; }
.reasons-outro p { font-size: 18px; font-weight: bold; color: #4a3b32; margin-bottom: 30px; line-height: 1.8; }