*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Noto Sans JP,Hiragino Kaku Gothic ProN,Yu Gothic,sans-serif;color:#1a2a3a;background:#fff;line-height:1.7;font-size:16px}img{max-width:100%;height:auto;display:block}a{text-decoration:none;color:inherit}:root{--navy:#0d2240;--navy-mid:#1a3a5c;--navy-light:#2a5080;--blue:#1e6fa8;--blue-light:#3a8fd0;--sky:#e8f4fd;--accent:#f0a500;--accent-light:#ffd166;--green-line:#06c755;--green-line-dark:#05a847;--white:#ffffff;--gray-bg:#f5f7fa;--gray-border:#dde4ed;--text-dark:#1a2a3a;--text-mid:#3a5070;--text-light:#6a8090}.header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(13,34,64,.95);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:10px 20px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 20px rgba(0,0,0,.3)}.header-logo img{height:36px;width:auto;filter:brightness(0) invert(1)}.header-cta{background:var(--green-line);color:white;padding:10px 20px;border-radius:30px;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px;transition:background .2s}.header-cta:hover{background:var(--green-line-dark)}.header-cta .line-icon{width:20px;height:20px;background:white;border-radius:4px;display:flex;align-items:center;justify-content:center}.header-cta .line-icon svg{width:16px;height:16px}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding-top:60px}.hero-bg{background-image:url(/sleep/hero_image.jpg);background-size:cover;background-position:center 30%;filter:brightness(.45)}.hero-bg,.hero-overlay{position:absolute;inset:0}.hero-overlay{background:linear-gradient(135deg,rgba(13,34,64,.85),rgba(26,58,92,.6) 60%,rgba(13,34,64,.3))}.hero-content{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:60px 24px;width:100%}.hero-badge{display:inline-block;background:var(--accent);color:var(--navy);font-size:13px;font-weight:700;padding:6px 16px;border-radius:20px;margin-bottom:20px;letter-spacing:.05em}.hero-main-copy{font-size:clamp(26px,5vw,48px);font-weight:900;color:white;line-height:1.3;margin-bottom:16px;text-shadow:0 2px 12px rgba(0,0,0,.5)}.hero-main-copy .highlight{color:var(--accent-light)}.hero-sub-copy{font-size:clamp(14px,2vw,18px);color:rgba(255,255,255,.9);margin-bottom:32px;max-width:560px;line-height:1.8}.hero-benefits{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}.hero-benefit-item{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:white;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px}.hero-benefit-item .icon{font-size:18px}.hero-cta-btn{display:inline-flex;align-items:center;gap:12px;background:var(--green-line);color:white;padding:18px 40px;border-radius:50px;font-size:clamp(16px,2.5vw,20px);font-weight:900;box-shadow:0 8px 30px rgba(6,199,85,.5);transition:all .3s;text-align:center}.hero-cta-btn:hover{background:var(--green-line-dark);transform:translateY(-2px);box-shadow:0 12px 40px rgba(6,199,85,.6)}.hero-cta-note{color:rgba(255,255,255,.7);font-size:12px;margin-top:10px}section{padding:72px 24px}.container{max-width:1000px;margin:0 auto}.section-title{font-size:clamp(22px,4vw,36px);font-weight:900;color:var(--navy);text-align:center;margin-bottom:12px;line-height:1.4}.section-subtitle{text-align:center;color:var(--text-mid);font-size:15px;margin-bottom:48px}.section-label{display:inline-block;font-size:12px;font-weight:700;padding:4px 14px;border-radius:4px;letter-spacing:.1em;margin-bottom:12px}.section-label,.worry-section{background:var(--navy);color:white}.worry-section .section-title{color:white}.worry-section .section-subtitle{color:rgba(255,255,255,.7)}.worry-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:16px;gap:16px;margin-bottom:48px}.worry-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:20px 24px;display:flex;align-items:flex-start;gap:14px}.worry-card .check{width:28px;height:28px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.worry-card .check svg{width:14px;height:14px}.worry-card p{font-size:15px;line-height:1.6;color:rgba(255,255,255,.9)}.worry-image-wrap{border-radius:16px;overflow:hidden;max-width:700px;margin:0 auto;box-shadow:0 20px 60px rgba(0,0,0,.4)}.solution-section{background:var(--gray-bg)}.solution-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:40px;gap:40px;align-items:center}.solution-text .lead{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:16px;line-height:1.6}.solution-text p{color:var(--text-mid);font-size:15px;line-height:1.9;margin-bottom:16px}.solution-points{list-style:none;display:flex;flex-direction:column;gap:12px}.solution-points li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--text-dark)}.solution-points li:before{content:"";width:8px;height:8px;background:var(--blue);border-radius:50%;flex-shrink:0;margin-top:7px}.solution-image{border-radius:16px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.15)}.medicine-section{background:white}.medicine-cards{display:grid;grid-template-columns:1fr 1fr;grid-gap:28px;gap:28px}.medicine-card{border-radius:20px;overflow:hidden;box-shadow:0 8px 32px rgba(13,34,64,.12);border:2px solid var(--gray-border);transition:transform .3s,box-shadow .3s}.medicine-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(13,34,64,.18)}.medicine-card-header{padding:24px 28px 20px;color:white}.medicine-card-header.blue{background:linear-gradient(135deg,#1a5fa8,#2a8fd0)}.medicine-card-header.indigo{background:linear-gradient(135deg,#2d1b8a,#4a3ab0)}.medicine-card-header .drug-label{font-size:11px;font-weight:700;letter-spacing:.15em;opacity:.8;margin-bottom:6px}.medicine-card-header h3{font-size:24px;font-weight:900;margin-bottom:4px}.medicine-card-header .drug-dose{font-size:13px;opacity:.85}.medicine-card-body{padding:24px 28px;background:white}.medicine-tag{display:inline-block;background:var(--sky);color:var(--blue);font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;margin-bottom:14px}.medicine-feature{font-size:15px;color:var(--text-dark);line-height:1.8;margin-bottom:16px}.medicine-merits{list-style:none;display:flex;flex-direction:column;gap:10px}.medicine-merits li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-mid);line-height:1.6}.merit-icon{width:22px;height:22px;background:var(--sky);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.merit-icon svg{width:12px;height:12px}.medicine-pills-img{border-radius:12px;overflow:hidden;margin-top:16px}.medicine-comparison{margin-top:48px;background:var(--sky);border-radius:16px;padding:32px}.medicine-comparison h3{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:20px;text-align:center}.comparison-table{width:100%;border-collapse:collapse;font-size:14px}.comparison-table th{background:var(--navy);color:white;padding:12px 16px;text-align:center;font-weight:700}.comparison-table th:first-child{border-radius:8px 0 0 0}.comparison-table th:last-child{border-radius:0 8px 0 0}.comparison-table td{padding:12px 16px;border-bottom:1px solid var(--gray-border);text-align:center;color:var(--text-dark);background:white}.comparison-table td:first-child{font-weight:700;color:var(--navy);text-align:left;background:var(--gray-bg)}.comparison-table tr:last-child td{border-bottom:none}.check-circle{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#e8f8ef;border-radius:50%;color:#2ecc71;font-size:14px;font-weight:700}.merit-section{background:var(--navy)}.merit-section .section-title{color:white}.merit-section .section-subtitle{color:rgba(255,255,255,.7)}.merit-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:24px;gap:24px}.merit-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:16px;padding:28px 24px;text-align:center;transition:background .3s}.merit-card:hover{background:rgba(255,255,255,.13)}.merit-card-icon{width:64px;height:64px;background:rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-size:28px}.merit-card h3{font-size:17px;font-weight:700;color:white;margin-bottom:10px}.merit-card p{font-size:14px;color:rgba(255,255,255,.75);line-height:1.7}.price-section{background:var(--gray-bg)}.price-table-wrap{background:white;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(13,34,64,.1)}.price-table{width:100%;border-collapse:collapse;font-size:15px}.price-table thead tr{background:var(--navy);color:white}.price-table thead th{padding:16px 20px;font-weight:700;text-align:center}.price-table thead th:first-child{text-align:left}.price-table tbody tr{border-bottom:1px solid var(--gray-border);transition:background .2s}.price-table tbody tr:hover{background:var(--sky)}.price-table tbody tr:last-child{border-bottom:none}.price-table tbody td{padding:20px;text-align:center;color:var(--text-dark)}.price-table tbody td:first-child{text-align:left}.drug-name-cell{display:flex;flex-direction:column;gap:4px}.drug-name-cell .name{font-weight:700;font-size:16px;color:var(--navy)}.drug-name-cell .type{font-size:12px;color:var(--text-light)}.price-amount{font-size:22px;font-weight:900;color:var(--navy)}.price-amount .yen{font-size:14px;font-weight:400}.price-notes{padding:20px 24px;background:var(--sky);border-top:1px solid var(--gray-border)}.price-notes p{font-size:13px;color:var(--text-light);line-height:1.8}.flow-section{background:white}.flow-steps{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:0;gap:0;position:relative}.flow-steps:before{content:"";position:absolute;top:48px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(90deg,var(--blue-light),var(--navy-light));z-index:0}.flow-step{text-align:center;padding:0 16px;position:relative;z-index:1}.flow-step-number{width:96px;height:96px;background:var(--navy);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 24px rgba(13,34,64,.25)}.flow-step-number .step-label{font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.1em}.flow-step-number .step-num{font-size:28px;font-weight:900;color:white;line-height:1}.flow-step h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px}.flow-step p{font-size:13px;color:var(--text-mid);line-height:1.7}.flow-step-icon{font-size:32px;margin-bottom:12px}.trust-section{background:var(--sky)}.trust-badges{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:20px;gap:20px;margin-bottom:48px}.trust-badge{background:white;border-radius:16px;padding:24px 16px;text-align:center;box-shadow:0 4px 16px rgba(13,34,64,.08)}.trust-badge .badge-num{font-size:13px;font-weight:700;color:var(--blue);letter-spacing:.1em;margin-bottom:8px}.trust-badge .badge-icon{font-size:32px;margin-bottom:10px}.trust-badge h3{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:6px}.trust-badge p{font-size:12px;color:var(--text-light);line-height:1.6}.doctor-section{background:white;border-radius:16px;padding:32px;display:flex;gap:32px;align-items:center;box-shadow:0 4px 16px rgba(13,34,64,.08)}.doctor-image{width:200px;height:200px;border-radius:50%;overflow:hidden;flex-shrink:0;border:4px solid var(--navy)}.doctor-info h3{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:4px}.doctor-info .doctor-title{font-size:13px;color:var(--text-light);margin-bottom:16px}.doctor-info p{font-size:14px;color:var(--text-mid);line-height:1.8}.faq-section{background:white}.faq-list{display:flex;flex-direction:column;gap:12px}.faq-item{border:1px solid var(--gray-border);border-radius:12px;overflow:hidden}.faq-question{padding:20px 24px;background:var(--gray-bg);display:flex;align-items:flex-start;gap:14px;cursor:pointer}.faq-q-mark{width:28px;height:28px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:14px;font-weight:900;flex-shrink:0}.faq-question p{font-size:15px;line-height:1.5;flex:1 1}.faq-question p,.faq-toggle{font-weight:700;color:var(--navy)}.faq-toggle{font-size:20px;flex-shrink:0;transition:transform .3s;line-height:1;margin-top:2px}.faq-item.open .faq-toggle{transform:rotate(45deg)}.faq-answer{display:none;padding:20px 24px 20px 66px;background:white;border-top:1px solid var(--gray-border)}.faq-item.open .faq-answer{display:block}.faq-a-mark{display:inline-block;width:28px;height:28px;background:var(--blue);border-radius:50%;color:white;font-size:14px;font-weight:900;text-align:center;line-height:28px;margin-right:10px;float:left;margin-left:-42px}.faq-answer p{font-size:14px;color:var(--text-mid);line-height:1.8}.cta-section{background:linear-gradient(135deg,var(--navy) 0,var(--navy-mid) 100%);text-align:center;padding:80px 24px}.cta-section .section-title{color:white;margin-bottom:16px}.cta-section .section-subtitle{color:rgba(255,255,255,.75);margin-bottom:40px}.cta-btn-large{display:inline-flex;align-items:center;gap:14px;background:var(--green-line);color:white;padding:22px 52px;border-radius:60px;font-size:clamp(18px,3vw,24px);font-weight:900;box-shadow:0 12px 40px rgba(6,199,85,.5);transition:all .3s}.cta-btn-large:hover{background:var(--green-line-dark);transform:translateY(-3px);box-shadow:0 18px 50px rgba(6,199,85,.6)}.cta-note{margin-top:20px;font-size:13px;color:rgba(255,255,255,.6)}.disclaimer-section{background:var(--gray-bg);padding:48px 24px}.disclaimer-box{background:white;border:1px solid var(--gray-border);border-radius:12px;padding:28px 32px}.disclaimer-box h3{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--gray-border)}.disclaimer-box li,.disclaimer-box p{font-size:13px;color:var(--text-light);line-height:1.9}.disclaimer-box ul{padding-left:20px}.disclaimer-box ul li{margin-bottom:4px}.footer{background:var(--navy);padding:32px 24px}.footer-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}.footer-logo img{height:32px;filter:brightness(0) invert(1)}.footer-links{display:flex;flex-wrap:wrap;gap:4px 0;align-items:center}.footer-links a{color:rgba(255,255,255,.7);font-size:13px;padding:4px 12px;transition:color .2s;border-right:1px solid rgba(255,255,255,.2)}.footer-links a:last-child{border-right:none}.footer-links a:hover{color:white}.footer-copy{width:100%;text-align:center;color:rgba(255,255,255,.4);font-size:12px;margin-top:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}.floating-line-btn{position:fixed;bottom:24px;right:24px;z-index:999;background:var(--green-line);color:white;padding:14px 24px;border-radius:50px;font-size:15px;font-weight:700;display:flex;align-items:center;gap:10px;box-shadow:0 8px 30px rgba(6,199,85,.5);transition:all .3s;animation:float-pulse 2s ease-in-out infinite}.floating-line-btn:hover{background:var(--green-line-dark);transform:translateY(-3px) scale(1.03);box-shadow:0 14px 40px rgba(6,199,85,.6)}@keyframes float-pulse{0%,to{box-shadow:0 8px 30px rgba(6,199,85,.5)}50%{box-shadow:0 8px 40px rgba(6,199,85,.7)}}.line-logo-svg{width:24px;height:24px;background:white;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.fade-in{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}@media (max-width:768px){section{padding:52px 16px}.solution-grid{grid-template-columns:1fr}.solution-image{order:-1}.medicine-cards,.merit-grid{grid-template-columns:1fr}.flow-steps{grid-template-columns:1fr 1fr}.flow-steps:before{display:none}.trust-badges{grid-template-columns:1fr 1fr}.doctor-section{flex-direction:column;text-align:center}.doctor-image{width:140px;height:140px}.footer-inner,.footer-links{flex-direction:column;align-items:flex-start}.footer-links a{border-right:none;padding:4px 0}.price-table{font-size:13px}.price-table tbody td,.price-table thead th{padding:12px 10px}.floating-line-btn{bottom:16px;right:16px;padding:12px 18px;font-size:14px}}@media (max-width:480px){.hero-benefits{flex-direction:column}.flow-steps,.trust-badges{grid-template-columns:1fr}.comparison-table{font-size:12px}.comparison-table td,.comparison-table th{padding:10px 8px}}