/*
Theme Name: きくのはな鍼灸接骨院
Theme URI: https://www.kikunohana-seitai.com/
Author: きくのはな鍼灸接骨院
Description: あごから整える全身ケア - きくのはな鍼灸接骨院オリジナルテーマ
Version: 2.0
License: GNU General Public License v2 or later
Text Domain: kikunohana
*/
:root{--bg:#FDFAF5;--bg2:#F5EDE0;--bg3:#EFE3D0;--primary:#C07A3A;--primary-light:#E09A5A;--primary-dark:#8A5220;--text:#2C1A0E;--text-mid:#6B4F3A;--text-light:#A08070;--white:#FFFFFF;--line:#06C755;--line-dark:#04A144;--serif:'Noto Serif JP',serif;--sans:'Noto Sans JP',sans-serif;--shadow:0 4px 24px rgba(44,26,14,0.10);--shadow-hover:0 8px 40px rgba(44,26,14,0.18);--radius:16px;--transition:0.3s ease}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.8;font-size:16px}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block;height:auto}
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(253,250,245,0.95);backdrop-filter:blur(10px);border-bottom:1px solid rgba(192,122,58,0.15);transition:box-shadow var(--transition)}
.site-header.scrolled{box-shadow:0 2px 20px rgba(44,26,14,0.12)}
.header-inner{max-width:1200px;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:72px}
.header-logo a{display:flex;align-items:center;gap:10px}
.logo-flower{font-size:28px;color:var(--primary);line-height:1}
.logo-texts{display:flex;flex-direction:column;line-height:1.2}
.logo-main{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--primary);letter-spacing:0.05em}
.logo-sub{font-size:11px;color:var(--text-mid);letter-spacing:0.08em}
.header-nav ul{display:flex;gap:4px}
.header-nav a{font-size:13.5px;font-weight:500;color:var(--text-mid);padding:6px 12px;border-radius:20px;transition:all var(--transition)}
.header-nav a:hover{background:var(--bg2);color:var(--primary)}
.header-cta{display:flex;align-items:center;gap:12px}
.btn-tel{font-size:13px;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:6px}
.btn-line-sm{display:flex;align-items:center;gap:6px;background:var(--line);color:white;font-size:13px;font-weight:700;padding:8px 18px;border-radius:24px;transition:all var(--transition)}
.btn-line-sm:hover{background:var(--line-dark);transform:translateY(-1px)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:4px}
.hero{position:relative;height:100vh;min-height:600px;display:flex;align-items:center;overflow:hidden}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;background-size:cover;background-position:center}
.hero-slide.active{opacity:1}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(20,8,0,0.65) 0%,rgba(20,8,0,0.35) 60%,transparent 100%)}
.hero-content{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 40px;padding-top:72px}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,0.8);font-size:13px;letter-spacing:0.15em;margin-bottom:20px}
.hero-eyebrow::before{content:'';display:block;width:24px;height:1px;background:rgba(255,255,255,0.6)}
.hero-title{font-family:var(--serif);font-size:clamp(42px,6vw,72px);font-weight:700;color:var(--white);line-height:1.3;letter-spacing:0.04em;margin-bottom:20px}
.hero-title em{font-style:normal;color:#F5C87A;display:block}
.hero-sub{font-size:clamp(15px,1.8vw,18px);color:rgba(255,255,255,0.88);margin-bottom:32px;max-width:480px;line-height:1.9}
.hero-badges{display:flex;gap:10px;margin-bottom:36px;flex-wrap:wrap}
.hero-badge{font-size:12px;font-weight:700;color:var(--white);border:1px solid rgba(255,255,255,0.5);padding:4px 14px;border-radius:20px;letter-spacing:0.05em}
.btn-hero{display:inline-flex;align-items:center;gap:10px;background:var(--line);color:white;font-size:16px;font-weight:700;padding:16px 36px;border-radius:36px;box-shadow:0 6px 24px rgba(6,199,85,0.4);transition:all var(--transition)}
.btn-hero:hover{background:var(--line-dark);transform:translateY(-2px)}
.hero-dots{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.4);cursor:pointer;transition:all var(--transition)}
.hero-dot.active{background:white;width:24px;border-radius:4px}
.hero-scroll{position:absolute;bottom:32px;right:48px;z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,0.7);font-size:11px;letter-spacing:0.1em}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,0.7));animation:scrollAnim 1.5s ease-in-out infinite}
@keyframes scrollAnim{0%,100%{opacity:0.3;transform:scaleY(0.8)}50%{opacity:1;transform:scaleY(1)}}
.section{padding:96px 0}
.section-alt{background:var(--bg2)}
.container{max-width:1200px;margin:0 auto;padding:0 40px}
.section-label{font-size:12px;font-weight:700;color:var(--primary);letter-spacing:0.2em;text-transform:uppercase;margin-bottom:12px}
.section-title{font-family:var(--serif);font-size:clamp(28px,4vw,42px);font-weight:700;line-height:1.4;margin-bottom:20px;color:var(--text)}
.section-desc{font-size:16px;color:var(--text-mid);line-height:1.9;max-width:560px}
.section-center{text-align:center}
.section-center .section-desc{margin:0 auto}
.symptoms-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:48px}
.symptom-card{background:white;border-radius:var(--radius);padding:24px 16px;text-align:center;border:1.5px solid transparent;box-shadow:var(--shadow);transition:all var(--transition)}
.symptom-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.symptom-icon{font-size:32px;margin-bottom:10px}
.symptom-name{font-size:13.5px;font-weight:700;color:var(--text)}
.symptom-sub{font-size:11px;color:var(--text-light);margin-top:4px}
.pain-note{text-align:center;margin-bottom:36px;font-size:15px;color:var(--text-mid);background:var(--bg2);padding:20px 32px;border-radius:var(--radius);border-left:4px solid var(--primary)}
.pain-note strong{color:var(--primary)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-image{border-radius:24px;overflow:hidden;aspect-ratio:4/5}
.about-image img{width:100%;height:100%;object-fit:cover}
.about-label{display:inline-block;background:var(--primary);color:white;font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;margin-bottom:16px;letter-spacing:0.1em}
.about-body{font-size:15.5px;color:var(--text-mid);line-height:2;margin-bottom:16px}
.about-body strong{color:var(--primary);font-weight:700}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:32px}
.about-tag{font-size:12px;background:var(--bg2);color:var(--text-mid);padding:5px 14px;border-radius:20px;font-weight:500}
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.feature-card{background:white;border-radius:24px;padding:40px 32px;box-shadow:var(--shadow);position:relative;overflow:hidden;transition:all var(--transition)}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--primary)}
.feature-num{font-family:var(--serif);font-size:52px;font-weight:700;color:var(--bg3);line-height:1;margin-bottom:16px}
.feature-icon{font-size:36px;margin-bottom:16px}
.feature-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--text);margin-bottom:12px;line-height:1.4}
.feature-title em{font-style:normal;display:block;font-size:14px;color:var(--primary);margin-bottom:4px;letter-spacing:0.1em}
.feature-body{font-size:14px;color:var(--text-mid);line-height:1.9}
.voices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.voice-card{background:white;border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);transition:all var(--transition)}
.voice-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.voice-tag{display:inline-block;font-size:11px;background:var(--bg2);color:var(--primary);padding:3px 10px;border-radius:20px;margin-bottom:12px;font-weight:700}
.voice-stars{color:#F5A623;font-size:14px;margin-bottom:12px;letter-spacing:2px}
.voice-text{font-size:14px;color:var(--text-mid);line-height:1.9;margin-bottom:20px}
.voice-author{font-size:13px;color:var(--text-light);font-weight:500;display:flex;align-items:center;gap:8px}
.voice-author::before{content:'—'}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.menu-card{background:white;border-radius:24px;padding:40px;box-shadow:var(--shadow);border:2px solid transparent;transition:all var(--transition);position:relative;overflow:hidden}
.menu-card:hover{border-color:var(--primary);box-shadow:var(--shadow-hover);transform:translateY(-4px)}
.menu-card.featured{border-color:var(--primary)}
.menu-featured-badge{position:absolute;top:0;right:0;background:var(--primary);color:white;font-size:11px;font-weight:700;padding:6px 20px;border-bottom-left-radius:12px;letter-spacing:0.05em}
.menu-duration{font-size:12px;font-weight:700;color:var(--primary);letter-spacing:0.15em;margin-bottom:8px}
.menu-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px;line-height:1.4}
.menu-price{font-family:var(--serif);font-size:32px;font-weight:700;color:var(--primary);margin-bottom:4px}
.menu-price span{font-size:16px;color:var(--text-light)}
.menu-price-first{font-size:14px;color:var(--text-light);margin-bottom:20px}
.menu-divider{height:1px;background:var(--bg2);margin:20px 0}
.menu-desc{font-size:14px;color:var(--text-mid);line-height:1.9}
.menu-includes li{font-size:13.5px;color:var(--text-mid);padding:5px 0;display:flex;align-items:center;gap:8px}
.menu-includes li::before{content:'✓';color:var(--primary);font-weight:700;flex-shrink:0}
.cta-banner{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 60%,var(--primary-light) 100%);padding:80px 40px;text-align:center}
.cta-banner .section-label{color:rgba(255,255,255,0.7)}
.cta-banner .section-title{color:white}
.cta-banner p{color:rgba(255,255,255,0.85);margin-bottom:36px;font-size:16px}
.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn-line-lg{display:inline-flex;align-items:center;gap:10px;background:var(--line);color:white;font-size:17px;font-weight:700;padding:18px 44px;border-radius:40px;box-shadow:0 6px 24px rgba(0,0,0,0.2);transition:all var(--transition)}
.btn-line-lg:hover{background:var(--line-dark);transform:translateY(-2px)}
.cta-notes{display:flex;justify-content:center;gap:24px;margin-top:24px;flex-wrap:wrap}
.cta-note{color:rgba(255,255,255,0.75);font-size:13px;display:flex;align-items:center;gap:6px}
.cta-note::before{content:'✓'}
.profile-grid{display:grid;grid-template-columns:360px 1fr;gap:80px;align-items:start}
.profile-image-wrap{position:sticky;top:100px}
.profile-image{border-radius:24px;overflow:hidden;aspect-ratio:3/4;margin-bottom:20px}
.profile-image img{width:100%;height:100%;object-fit:cover}
.profile-name-card{background:var(--bg2);border-radius:var(--radius);padding:20px 24px}
.profile-name{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--text)}
.profile-name-kana{font-size:13px;color:var(--text-light);margin-bottom:8px}
.profile-certs{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.profile-cert{font-size:12px;background:white;border:1px solid var(--bg3);color:var(--text-mid);padding:4px 10px;border-radius:20px}
.profile-message{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--primary);margin-bottom:28px;line-height:1.6;border-left:4px solid var(--primary);padding-left:20px}
.profile-body{font-size:15px;color:var(--text-mid);line-height:2;margin-bottom:20px}
.faq-list{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--bg3);overflow:hidden}
.faq-question{width:100%;background:none;border:none;cursor:pointer;padding:24px 0;display:flex;align-items:flex-start;gap:16px;text-align:left;transition:all var(--transition)}
.faq-q-mark{flex-shrink:0;width:32px;height:32px;border-radius:50%;background:var(--primary);color:white;font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center}
.faq-q-text{font-size:16px;font-weight:700;color:var(--text);flex:1;padding-top:4px;line-height:1.6}
.faq-arrow{flex-shrink:0;color:var(--primary);transition:transform var(--transition);font-size:20px;padding-top:2px}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer-inner{padding:0 0 24px 48px;font-size:15px;color:var(--text-mid);line-height:2}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.access-map{border-radius:24px;overflow:hidden;height:380px;box-shadow:var(--shadow)}
.access-map iframe{width:100%;height:100%;border:none}
.access-info-group{margin-bottom:28px}
.access-info-label{font-size:11px;font-weight:700;color:var(--primary);letter-spacing:0.15em;margin-bottom:8px}
.access-info-value{font-size:15px;color:var(--text);line-height:1.8}
.access-hours{background:var(--bg2);border-radius:var(--radius);padding:24px}
.hours-row{display:grid;grid-template-columns:auto 1fr;gap:8px 24px;align-items:center}
.hours-day{font-size:13px;font-weight:700;color:var(--text-mid)}
.hours-time{font-size:14px;color:var(--text)}
.site-footer{background:#2C1A0E;color:rgba(255,255,255,0.8);padding:64px 0 0}
.footer-inner{max-width:1200px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:60px;margin-bottom:48px}
.footer-logo-main{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--primary-light);margin-bottom:4px}
.footer-logo-sub{font-size:12px;color:rgba(255,255,255,0.5);margin-bottom:20px}
.footer-info{font-size:13px;line-height:2;color:rgba(255,255,255,0.65)}
.footer-info a{color:var(--primary-light)}
.footer-nav-title{font-size:12px;font-weight:700;color:rgba(255,255,255,0.5);letter-spacing:0.1em;margin-bottom:16px}
.footer-nav-list li{margin-bottom:10px}
.footer-nav-list a{font-size:14px;color:rgba(255,255,255,0.75);transition:color var(--transition)}
.footer-nav-list a:hover{color:var(--primary-light)}
.footer-line-btn{display:flex;align-items:center;gap:8px;justify-content:center;background:var(--line);color:white;font-size:15px;font-weight:700;padding:14px 24px;border-radius:12px;margin-bottom:16px;transition:all var(--transition)}
.footer-line-btn:hover{background:var(--line-dark)}
.footer-social{display:flex;gap:12px;margin-top:16px}
.footer-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition)}
.footer-social a:hover{background:var(--primary);transform:translateY(-2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding:20px 40px;max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.4)}
.floating-cta{position:fixed;bottom:24px;right:24px;z-index:900;opacity:0;transform:translateY(20px);transition:all 0.4s ease;pointer-events:none}
.floating-cta.visible{opacity:1;transform:translateY(0);pointer-events:all}
.floating-line{display:flex;align-items:center;gap:8px;background:var(--line);color:white;font-size:14px;font-weight:700;padding:14px 22px;border-radius:32px;box-shadow:0 6px 20px rgba(6,199,85,0.4);transition:all var(--transition)}
.floating-line:hover{background:var(--line-dark);transform:scale(1.03)}
.fade-up{opacity:0;transform:translateY(30px);transition:opacity 0.7s ease,transform 0.7s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--primary);color:white;font-size:15px;font-weight:700;padding:14px 36px;border-radius:32px;box-shadow:0 4px 16px rgba(192,122,58,0.3);transition:all var(--transition)}
.btn-primary:hover{background:var(--primary-dark);transform:translateY(-2px)}
.btn-outline{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--primary);color:var(--primary);font-size:14px;font-weight:700;padding:12px 28px;border-radius:32px;transition:all var(--transition)}
.btn-outline:hover{background:var(--primary);color:white}
.cta-center{text-align:center}
@media(max-width:1024px){.symptoms-grid{grid-template-columns:repeat(4,1fr)}.about-grid{grid-template-columns:1fr;gap:48px}.about-image{aspect-ratio:16/9}.profile-grid{grid-template-columns:1fr;gap:48px}.profile-image-wrap{position:static}}
@media(max-width:768px){.header-nav,.btn-tel{display:none}.menu-btn{display:block}.hero-content{padding:0 24px;padding-top:72px}.section{padding:64px 0}.container{padding:0 20px}.symptoms-grid{grid-template-columns:repeat(2,1fr)}.features-grid,.voices-grid,.menu-grid,.access-grid{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr;gap:40px}.footer-bottom{flex-direction:column;gap:12px;text-align:center}.cta-buttons{flex-direction:column;align-items:center}.hero-scroll{display:none}}