/* ===== base ===== */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;}
input,textarea{font-family:'Noto Sans JP',sans-serif;}
.page{font-family:'Noto Sans JP',sans-serif;color:#1c1c1a;background:#fff;}
.container{max-width:720px;margin:0 auto;}

/* ===== shared type ===== */
.eyebrow{font:700 13px/1 'Noto Sans JP';color:oklch(0.52 0.2 27);letter-spacing:.08em;margin-bottom:16px;font-size:18px;}
.eyebrow-light{font:700 13px/1 'Noto Sans JP';color:oklch(0.72 0.17 27);letter-spacing:.08em;margin-bottom:18px;font-size:18px;}
.h2{font-family:'M PLUS 1',sans-serif;font-weight:800;font-size:clamp(28px,4.5vw,40px);line-height:1.4;margin:0 0 22px;letter-spacing:-.01em;}
.lead{font-size:17px;line-height:1.9;color:#55554f;margin:0 0 30px;max-width:720px;}
.lead--solution{font-size:18px;margin:0 0 28px;}
.accent{color:oklch(0.5 0.19 27);}
.accent-light{color:oklch(0.66 0.2 27);}

/* ===== section shells ===== */
.section{padding:72px 24px;}
.section-white{background:#fff;}
.section-gray{background:#f4f4f0;}

/* ===== header ===== */
.site-header{background:#fff;border-bottom:1px solid #ececea;padding:16px 24px;}
.header-inner{max-width:720px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.logo{height:30px;width:auto;display:block;}
.header-cta{text-decoration:none;font-weight:800;font-size:13px;color:#fff;background:oklch(0.5 0.19 27);padding:9px 16px;border-radius:8px;}

/* ===== hero ===== */
.hero{background:#1a1a18;color:#fafaf8;padding:64px 24px 72px;}
.hero-inner{max-width:720px;margin:0 auto;text-align:center;}
.hero-badge{display:inline-block;font:700 12px/1 ui-monospace,monospace;letter-spacing:.14em;color:oklch(0.72 0.17 27);border:1px solid oklch(0.46 0.13 27);border-radius:999px;padding:8px 14px;margin-bottom:28px;font-size:18px;}
.hero-title{font-family:'M PLUS 1',sans-serif;font-weight:900;font-size:clamp(40px,7.5vw,68px);line-height:1.16;letter-spacing:-.02em;margin:0 0 28px;}
.strike{color:rgb(138,138,132);text-decoration:line-through 4px;}
.ba-row{display:flex;gap:14px;align-items:stretch;margin-bottom:36px;max-width:560px;margin-left:auto;margin-right:auto;}
.ba-card{flex:1;border-radius:16px;padding:22px 16px;text-align:center;}
.ba-before{background-color:#6f6f64;}
.ba-after{background:oklch(0.5 0.19 27);}
.ba-label{font:700 11px ui-monospace,monospace;color:#fff;letter-spacing:.1em;margin-bottom:10px;font-size:14px;}
.ba-num{font-family:'M PLUS 1';font-weight:900;font-size:clamp(30px,5vw,40px);color:#fff;line-height:1;}
.ba-num span{font-size:.45em;}
.ba-sub{font-size:16px;color:#fff;margin-top:8px;}
.ba-sub--bold{font-weight:800;}
.ba-arrow{flex:none;display:flex;align-items:center;font-size:30px;color:oklch(0.66 0.2 27);font-weight:900;}
.hero-cta{display:inline-block;text-decoration:none;padding:18px 36px;border-radius:12px;background:oklch(0.5 0.19 27);color:#fff;font-weight:900;font-size:18px;box-shadow:0 8px 24px oklch(0.5 0.19 27 / .4);}
.hero-note{font:500 13px/1.5 'Noto Sans JP';color:#d47072;margin:16px 0 0;font-size:24px;}

/* ===== pain ===== */
.pain-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
.pain-item{background:#f4f4f0;border-radius:12px;padding:18px 20px;font-size:24px;font-weight:500;line-height:1.6;}
.x{color:oklch(0.5 0.19 27);font-weight:900;}

/* ===== solution ===== */
.solution-card{background:#fff;border-radius:16px;padding:26px 28px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.solution-card-big{font-family:'M PLUS 1';font-weight:900;font-size:48px;color:oklch(0.5 0.19 27);line-height:1;}
.solution-card-text{font-size:18px;line-height:1.7;color:#55554f;font-weight:500;}

/* ===== value ===== */
.section-value{background:#1a1a18;color:#fafaf8;padding:80px 24px;}
.value-title{font-family:'M PLUS 1',sans-serif;font-weight:800;font-size:clamp(30px,5vw,48px);line-height:1.35;margin:0 0 24px;letter-spacing:-.01em;}
.value-lead{font-size:18px;line-height:1.9;color:#c9c9c4;margin:0;max-width:720px;}

/* ===== hours ===== */
.hours-grid{display:flex;gap:14px;flex-wrap:wrap;}
.hours-card{flex:1;min-width:240px;background:#fff;border-radius:16px;padding:24px 26px;}
.hours-card-label{font:700 12px/1 ui-monospace,monospace;letter-spacing:.1em;color:#77776f;margin-bottom:12px;font-size:16px;}
.hours-time{font-family:'M PLUS 1';font-weight:900;font-size:34px;color:#e41212;line-height:1;}
.hours-time span{font-size:.55em;color:#9a9a93;}
.hours-note{font-size:14px;line-height:1.8;color:#e41212;margin:18px 0 0;}

/* ===== profile ===== */
.profile-inner{max-width:720px;margin:0 auto;display:flex;gap:28px;align-items:center;flex-wrap:wrap;}
.profile-photo{flex:none;width:120px;height:120px;border-radius:50%;object-fit:cover;object-position:center top;background:#f4f4f0;}
.profile-body{flex:1;min-width:260px;}
.profile-name{font-family:'Noto Sans JP';font-weight:500;font-size:24px;line-height:1.2;}
.profile-role{font-size:16px;color:#77776f;margin:7px 0 14px;}
.profile-bio{font-size:18px;line-height:1.85;color:#55554f;margin:0;}

/* ===== cta / form ===== */
.section-cta{background:oklch(0.5 0.19 27);color:#fff;padding:80px 24px;}
.cta-inner{max-width:560px;margin:0 auto;}
.cta-title{font-family:'M PLUS 1',sans-serif;font-weight:800;font-size:clamp(27px,4.5vw,38px);line-height:1.4;margin:0 0 16px;letter-spacing:-.01em;}
.cta-lead{font-size:16px;line-height:1.8;color:#ffe6e6;margin:0 0 32px;opacity:.95;}
.form{background:#fff;border-radius:18px;padding:28px 26px;}
.field{width:100%;padding:14px 16px;border:1.5px solid #dcdcd6;border-radius:10px;font-size:16px;margin-bottom:12px;outline:none;}
.field--area{margin-bottom:18px;resize:none;}
.form-error{display:none;color:#c2403d;background:#fbecec;border-radius:8px;padding:10px 12px;font-size:13.5px;line-height:1.6;margin-bottom:14px;}
.submit{width:100%;padding:18px;border:none;border-radius:12px;background:#1a1a18;color:#fff;font-weight:900;font-size:17px;cursor:pointer;}
.success{display:none;background:#fff;color:#1a1a18;border-radius:18px;padding:40px 28px;text-align:center;}
.success-check{font-size:42px;margin-bottom:10px;color:oklch(0.5 0.19 27);}
.success-title{font-family:'M PLUS 1';font-weight:900;font-size:22px;margin-bottom:10px;}
.success-text{font-size:15px;color:#66665f;line-height:1.7;}

/* ===== footer ===== */
.site-footer{background:#1a1a18;color:#9a9a93;padding:32px 24px;}
.footer-inner{max-width:720px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:14px;text-align:center;}
.footer-logo-wrap{flex:none;background:#fff;border-radius:6px;padding:10px;display:flex;align-items:center;}
.footer-logo{height:56px;width:auto;display:block;}
.footer-text{font-size:14px;line-height:1.6;}

/* ===== responsive ===== */
@media (max-width:600px){.pain-grid{grid-template-columns:1fr;}}
