/*
Theme Name: meddie 2025
Theme URI: https://meddie.jp
Author: ノシクミ株式会社 / RealStandard
Description: meddie（メディ）健診結果データ化サービス 新デザインテーマ
Version: 1.0.3
Text Domain: meddie2025
*/


/* ===== CSS変数・リセット ===== */
:root{--primary:#0B6E4F;--primary-light:#E8F5F0;--primary-pale:#F4FAF7;--accent:#FF8C42;--dark:#2E4050;--gray:#6B7B83;--light-gray:#E8ECEE}
*{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:hidden}
body{font-family:'Noto Sans JP',sans-serif;background:#fff;color:var(--dark);line-height:1.8;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
/* ===== ヘッダー ===== */
.header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);padding:0;height:72px;min-width:0}
.header-inner{max-width:1100px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;height:100%}
.header-logo{text-decoration:none;cursor:pointer;display:flex;align-items:center}.logo-img{height:44px;width:auto;display:block}.logo-img-footer{height:36px;width:auto;display:block}
.header-nav{display:flex;align-items:center;gap:10px;flex-shrink:0}
.header-nav a{font-size:13px;font-weight:400;color:var(--dark);transition:color .2s;white-space:nowrap}
.header-nav a:hover{color:var(--primary)}
.header-nav a.active{color:var(--accent);font-weight:700}
.header-cta{background:var(--primary);color:#fff !important;padding:9px 20px;border-radius:24px;font-size:14px;font-weight:700;transition:opacity .2s}
.header-cta:hover{opacity:.85}
/* ===== ヒーロー ===== */
.hero{position:relative;background:linear-gradient(135deg,var(--primary-pale) 0%,#fff 60%);padding:60px 0;overflow:hidden}
.hero::after{content:'';position:absolute;top:-60px;right:-80px;width:400px;height:400px;border-radius:50%;background:rgba(11,110,79,.03)}
.hero-inner{max-width:1100px;margin:0 auto;padding:0 40px;display:flex;align-items:center;gap:0;position:relative;z-index:1;overflow:hidden}
.hero-text{flex:1}
.hero-label{display:inline-block;background:var(--primary-light);color:var(--primary);font-size:16px;font-weight:700;padding:4px 14px;border-radius:20px;margin-bottom:16px;letter-spacing:.05em}
.hero-title{font-size:36px;font-weight:900;line-height:1.6;margin-bottom:16px}
.hero-title span{color:var(--primary)}
.hero-desc{font-size:16px;color:var(--gray);line-height:2;margin-bottom:28px}
.hero-btns{display:flex;gap:12px}
.btn-primary{background:var(--accent);color:#fff;padding:14px 36px;border-radius:32px;font-size:16px;font-weight:700;box-shadow:0 4px 16px rgba(255,140,66,.3);transition:transform .2s}
.btn-primary:hover{transform:translateY(-1px)}
.btn-secondary{border:1.5px solid var(--primary);color:var(--primary);padding:14px 28px;border-radius:32px;font-size:16px;font-weight:600;transition:background .2s}
.btn-secondary:hover{background:var(--primary-light)}
/* ヒーロー画像：右端に寄せて大きく表示 */
.hero-img{flex-shrink:1;max-width:500px;width:50%;margin-top:-100px;margin-left:-30px}
.hero-img img{width:100%;height:auto;display:block}
.hero-text{flex:1;min-width:360px}
.hero-stats{display:flex;gap:32px;margin-top:32px;padding-top:24px;border-top:1px solid var(--light-gray)}
.hero-stat{text-align:center}
.hero-stat-num{font-family:'Outfit',sans-serif;font-size:28px;font-weight:700;color:var(--primary)}
.hero-stat-label{font-size:16px;color:var(--gray);margin-top:2px}
/* ===== トラストバー ===== */
.trust-bar{background:var(--primary-pale);border-top:1px solid rgba(11,110,79,.06);border-bottom:1px solid rgba(11,110,79,.06);padding:20px 40px}
.trust-bar-inner{max-width:960px;margin:0 auto;display:flex;justify-content:center;gap:40px}
.trust-item{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:500;color:var(--dark);white-space:nowrap}
.trust-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.trust-icon svg{width:20px;height:20px;stroke-width:1.7;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
/* ===== 共通セクション ===== */
.section{padding:64px 40px}
.section-inner{max-width:960px;margin:0 auto}
.section-header{text-align:center;margin-bottom:40px}
.section-eng{font-family:'Outfit',sans-serif;font-size:16px;letter-spacing:.2em;color:var(--primary);opacity:.6}
.section-title{font-size:28px;font-weight:700;margin-top:4px;line-height:1.5}
.section-sub{font-size:16px;color:var(--gray);margin-top:8px}
.bg-pale{background:var(--primary-pale)}
.bg-w{background:#fff}
.link-btn{display:inline-flex;align-items:center;gap:6px;border:1.5px solid var(--primary);color:var(--primary);padding:10px 28px;border-radius:28px;font-size:16px;font-weight:700;transition:background .2s}
.link-btn:hover{background:var(--primary-light)}
.tc{text-align:center}
/* ===== コンセプト ===== */
.concept{display:flex;gap:40px;align-items:center}
.concept-img{width:46%;border-radius:12px;overflow:hidden;flex-shrink:0}
.concept-img img{width:100%;height:100%;object-fit:cover;display:block}
.concept-text{flex:1}
.concept-eng{font-family:'Outfit',sans-serif;font-size:16px;color:var(--primary);letter-spacing:.15em;opacity:.6;margin-bottom:8px}
.concept-title{font-size:26px;font-weight:700;line-height:1.6;margin-bottom:14px}
.concept-desc{font-size:16px;color:var(--gray);line-height:2;margin-bottom:20px}
/* ===== 特徴 ===== */
.features{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.feat-card{background:#fff;border:1px solid rgba(11,110,79,.08);border-radius:16px;padding:32px 24px;text-align:center;transition:box-shadow .2s}
.feat-card:hover{box-shadow:0 4px 20px rgba(11,110,79,.08)}
.feat-num{font-family:'Outfit',sans-serif;font-size:36px;font-weight:700;color:var(--primary);opacity:.12;margin-bottom:4px}
.feat-icon{width:100px;height:100px;border-radius:50%;background:var(--primary-light);margin:0 auto 20px;display:flex;align-items:center;justify-content:center;color:var(--primary);box-shadow:0 2px 8px rgba(11,110,79,.08)}
.feat-icon svg{width:52px;height:52px;stroke-width:1.6;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.feat-title{font-size:18px;font-weight:700;margin-bottom:12px;text-align:center}
.feat-desc{font-size:16px;color:var(--gray);line-height:1.9;text-align:left}
/* ===== ターゲット導線 ===== */
.target-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;margin-top:24px}
.target-card{background:#fff;border:2px solid var(--primary-light);border-radius:16px;padding:36px 28px;text-align:center;transition:all .2s;display:flex;flex-direction:column;gap:16px}
.target-card:hover{border-color:var(--primary);box-shadow:0 4px 20px rgba(11,110,79,.08)}
.target-icon{margin:0 auto 20px;width:100px;height:100px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.target-icon svg{width:52px;height:52px;stroke-width:1.6;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.target-name{font-size:20px;font-weight:700;margin-bottom:12px;text-align:center}
.target-desc{font-size:15px;color:var(--gray);line-height:1.9;margin-bottom:20px;text-align:left;flex:1}
.target-link{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;padding:12px 28px;border-radius:28px;font-size:16px;font-weight:700;transition:opacity .2s;margin-top:auto;align-self:center}
.target-link:hover{opacity:.85}
/* ===== サービス ===== */
.svc-label{font-size:16px;font-weight:700;margin-bottom:14px;padding-left:14px;border-left:3px solid var(--primary)}
.svcs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}
.svc-card{background:#fff;border:1px solid var(--light-gray);border-radius:12px;overflow:hidden;text-align:center;transition:box-shadow .2s}
.svc-card:hover{box-shadow:0 4px 16px rgba(0,0,0,.06)}
.svc-img{height:90px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary)}
.svc-img svg{width:42px;height:42px;stroke-width:1.6;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
.svc-eng{font-family:'Outfit',sans-serif;font-size:16px;color:var(--primary);opacity:.6;letter-spacing:.1em;margin-top:10px}
.svc-name{padding:4px 8px 14px;font-size:16px;font-weight:700}
/* ===== 料金 ===== */
.plans{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}
.plan{border:2px solid var(--light-gray);border-radius:16px;overflow:visible;transition:box-shadow .2s}
.plan:hover{box-shadow:0 4px 20px rgba(0,0,0,.06)}
.plan.rec{border-color:var(--primary)}
.plan{position:relative}
.plan-h{padding:18px 20px;background:var(--primary-pale);text-align:center;border-top-left-radius:14px;border-top-right-radius:14px}
.plan.rec .plan-h{background:var(--primary);color:#fff}
.plan-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--accent);color:#fff;font-size:14px;font-weight:700;padding:4px 16px;border-radius:14px;box-shadow:0 2px 8px rgba(255,140,66,.3);z-index:1;white-space:nowrap}
.plan-name{font-size:20px;font-weight:700}
.plan-sub{font-size:16px;opacity:.7;margin-top:2px}
.plan-b{padding:24px}
.plan-price{text-align:center;margin-bottom:16px}
.plan-price-n{font-family:'Outfit',sans-serif;font-size:36px;font-weight:700;color:var(--primary)}
.plan-price-u{font-size:16px;color:var(--gray)}
.plan-list{list-style:none;font-size:16px;color:var(--gray);line-height:2.4}
.plan-list li::before{content:'\2713';color:var(--primary);font-weight:700;margin-right:8px}
.ptable{width:100%;border-collapse:collapse;font-size:16px;margin-bottom:28px}
.ptable th{background:var(--primary);color:#fff;padding:12px 16px;text-align:left;font-weight:500}
.ptable td{padding:12px 16px;border-bottom:1px solid var(--light-gray)}
.ptable tr:nth-child(even) td{background:var(--primary-pale)}
.ptable .pv{font-family:'Outfit',sans-serif;font-weight:600;color:var(--primary)}
/* ===== データ化手法 ===== */
.mblock{display:flex;gap:36px;align-items:center;margin-bottom:40px;padding-bottom:40px;border-bottom:1px solid var(--light-gray)}
.mblock:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.mblock.rev{flex-direction:row-reverse}
.mimg{width:33%;height:240px;border-radius:12px;overflow:hidden;flex-shrink:0}
.mimg img{width:100%;height:100%;object-fit:cover;display:block}
.mtxt{flex:1}
.mnum{font-family:'Outfit',sans-serif;font-size:40px;font-weight:700;color:var(--primary);opacity:.1;line-height:1;margin-bottom:4px}
.meng{font-family:'Outfit',sans-serif;font-size:16px;color:var(--primary);letter-spacing:.15em;opacity:.6;margin-bottom:6px}
.mt{font-size:22px;font-weight:700;margin-bottom:10px;line-height:1.5}
.md{font-size:16px;color:var(--gray);line-height:2}
/* ===== セキュリティ ===== */
.sec-wrap{display:flex;gap:36px;align-items:center}
.sec-badge{width:140px;height:140px;border-radius:12px;background:#fff;border:2px solid var(--primary-light);display:flex;align-items:center;justify-content:center;padding:14px;flex-shrink:0}
.sec-badge img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.sec-txt{flex:1}
.sec-txt h4{font-size:20px;font-weight:700;margin-bottom:8px}
.sec-txt p{font-size:16px;color:var(--gray);line-height:2}
.sec-items{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}
.sec-item{display:flex;align-items:center;gap:10px;background:var(--primary-pale);border-radius:8px;padding:12px 16px;font-size:16px;font-weight:500}
.sec-item .icon{display:inline-flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.sec-item .icon svg{width:20px;height:20px;stroke-width:1.7;stroke:currentColor;fill:none;stroke-linecap:round;stroke-linejoin:round}
/* ===== フロー ===== */
.flow-tl{display:flex;justify-content:space-between;position:relative;margin-bottom:16px}
.flow-tl::before{content:'';position:absolute;top:22px;left:28px;right:28px;height:2px;background:var(--light-gray);z-index:0}
.flow-step{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;z-index:1;width:90px}
.flow-num{width:44px;height:44px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Outfit',sans-serif;font-size:17px;font-weight:700;box-shadow:0 2px 10px rgba(11,110,79,.2)}
.flow-label{font-size:16px;font-weight:700;text-align:center;line-height:1.4}
.flow-sub{font-size:16px;color:var(--gray);text-align:center;line-height:1.4}
.flow-r2{margin-top:28px}
/* ===== FAQ ===== */
.faq-item{border:1px solid var(--light-gray);border-radius:12px;margin-bottom:12px;overflow:hidden}
.faq-item:hover{box-shadow:0 2px 12px rgba(0,0,0,.04)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;font-size:16px;font-weight:500;cursor:pointer}
.faq-qm{font-family:'Outfit',sans-serif;font-weight:700;color:var(--primary);margin-right:10px;font-size:16px}
.faq-tog{width:30px;height:30px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:16px;font-weight:700;flex-shrink:0}
.faq-a{padding:0 22px 18px 48px;font-size:16px;color:var(--gray);line-height:2;border-top:1px dashed var(--light-gray);padding-top:14px}
/* ===== CTA ===== */
.cta{background:linear-gradient(135deg,var(--primary) 0%,#094D38 100%);color:#fff;text-align:center;padding:72px 40px;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:-50px;right:-50px;width:240px;height:240px;border-radius:50%;border:2px solid rgba(255,255,255,.06)}
.cta::after{content:'';position:absolute;bottom:-40px;left:-40px;width:180px;height:180px;border-radius:50%;border:2px solid rgba(255,255,255,.06)}
.cta-eng{font-family:'Outfit',sans-serif;font-size:16px;letter-spacing:.2em;opacity:.6;margin-bottom:8px}
.cta-title{font-size:30px;font-weight:700;margin-bottom:10px;position:relative;z-index:1}
.cta-desc{font-size:16px;opacity:.75;margin-bottom:32px;line-height:1.8;position:relative;z-index:1}
.cta-btns{display:flex;justify-content:center;gap:16px;position:relative;z-index:1;flex-wrap:wrap}
.cta-pri{background:var(--accent);color:#fff;padding:16px 44px;border-radius:32px;font-size:17px;font-weight:700;box-shadow:0 4px 16px rgba(255,140,66,.4);transition:transform .2s}
.cta-pri:hover{transform:translateY(-1px)}
.cta-sec{background:rgba(255,255,255,.15);border:1.5px solid rgba(255,255,255,.4);color:#fff;padding:16px 36px;border-radius:32px;font-size:16px;font-weight:600;transition:background .2s}
.cta-sec:hover{background:rgba(255,255,255,.25)}
/* ===== フッター ===== */
.footer{background:var(--dark);color:#fff;padding:48px 40px 0}
.footer-inner{max-width:960px;margin:0 auto}
.footer-top{display:flex;justify-content:space-between;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand{max-width:260px}
.footer-logo{font-family:'Outfit',sans-serif;font-size:24px;font-weight:700;margin-bottom:10px}
.footer-co{font-size:16px;opacity:.85;line-height:1.8}
.footer-nav{display:flex;gap:48px}
.footer-nav-col h4{font-size:16px;font-weight:700;margin-bottom:14px;opacity:.9}
.footer-nav-col ul{list-style:none;font-size:16px;line-height:2.6;opacity:.85}
.footer-bot{padding:20px 0;font-size:16px;opacity:.75;text-align:center}
.footer-links{display:flex;gap:20px;font-size:16px}
/* ===== バーガーメニュー ===== */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;flex-shrink:0}
.burger span{display:block;width:24px;height:2px;background:var(--dark);border-radius:2px;transition:transform .3s,opacity .3s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-drawer{position:fixed;top:72px;left:0;right:0;bottom:0;background:rgba(255,255,255,.98);backdrop-filter:blur(12px);z-index:999;display:flex;flex-direction:column;padding:24px 32px;gap:4px;transform:translateX(100%);transition:transform .3s ease;overflow-y:auto}
.nav-drawer.is-open{transform:translateX(0)}
.nav-drawer a{font-size:17px;font-weight:500;color:var(--dark);padding:14px 0;border-bottom:1px solid var(--light-gray);display:block}
.nav-drawer a:hover,.nav-drawer a:active{color:var(--primary)}
.nav-drawer a.active{color:var(--accent);font-weight:700}
.nav-drawer .drawer-cta{margin-top:16px;background:var(--primary);color:#fff !important;padding:14px 24px;border-radius:32px;text-align:center;font-size:17px;font-weight:700;border-bottom:none}

/* ===== レスポンシブ ===== */
@media(max-width:768px){
.header{padding:0;height:60px}
  .header-inner{padding:0 20px}
  .header-nav{display:none}
  .burger{display:flex}
  .nav-drawer{top:60px}
.hero{background-image:none;padding:48px 20px 40px}
.hero-inner{flex-direction:column;gap:24px}
.hero-text{min-width:0;width:100%}
.hero-img{display:none}
.hero-title{font-size:26px}
.hero-stats{gap:12px}
.hero-stat-num{font-size:20px}
.section{padding:48px 20px}
.section-title{font-size:24px}
.concept{flex-direction:column;gap:24px}
.concept-img{width:100%}
.concept-title{font-size:22px}
.features{grid-template-columns:1fr}
.target-grid{grid-template-columns:1fr}
.svcs{grid-template-columns:1fr 1fr}
.plans{grid-template-columns:1fr}
.mblock,.mblock.rev{flex-direction:column;gap:20px}
.mimg{width:100%}
.mt{font-size:19px}
.sec-wrap{flex-direction:column;gap:20px}
.sec-badge{width:100%;height:auto;padding:20px;flex-direction:row;gap:12px}
.sec-items{grid-template-columns:1fr}
.flow-tl{flex-wrap:wrap;justify-content:center;gap:8px}
.flow-tl::before{display:none}
.flow-r2{margin-top:8px}
.cta{padding:48px 20px}
.cta-title{font-size:24px}
.cta-btns{flex-direction:column;align-items:center}
.footer{padding:36px 20px 0}
.footer-top{flex-direction:column;gap:28px}
.footer-nav{gap:24px;flex-wrap:wrap}
.trust-bar{padding:16px 20px}
.trust-bar-inner{flex-wrap:wrap;gap:16px 32px;justify-content:center}
body{font-size:17px}
}

/* ===== Cookieバナー ===== */
#cookie-banner{position:fixed;bottom:0;left:0;right:0;background:#1A2B33;color:#fff;padding:20px 32px;z-index:9999;display:flex;align-items:center;justify-content:space-between;gap:20px;box-shadow:0 -2px 16px rgba(0,0,0,.2)}
#cookie-banner p{margin:0;font-size:14px;line-height:1.7;flex:1}
#cookie-banner a{color:#fff;text-decoration:underline}
.cookie-btns{display:flex;gap:10px;flex-shrink:0}
#cookie-accept{background:var(--accent);color:#fff;border:none;padding:12px 28px;border-radius:30px;font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap}
#cookie-accept:hover{opacity:.85}
#cookie-decline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,0.4);padding:12px 24px;border-radius:30px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}
#cookie-decline:hover{border-color:rgba(255,255,255,0.8)}
@media(max-width:768px){#cookie-banner{flex-direction:column;align-items:stretch;text-align:center}.cookie-btns{flex-direction:column}#cookie-accept,#cookie-decline{width:100%}}



/* page-hero (各ページ汎用ヒーロー) */
.page-hero{background:linear-gradient(135deg,var(--primary-pale) 0%,#fff 60%);padding:56px 40px 48px;text-align:center}
.page-hero-eng{font-family:'Outfit',sans-serif;font-size:14px;letter-spacing:.2em;color:var(--primary);opacity:.6;margin-bottom:8px;text-transform:uppercase}
.page-hero-title{font-size:32px;font-weight:900;margin-bottom:12px}
.page-hero-desc{font-size:16px;color:var(--gray);line-height:2}
@media(max-width:768px){.page-hero{padding:40px 20px 32px}.page-hero-title{font-size:24px}}
