:root{
  --primary:#1b2e4b;--primary-light:#e8edf4;--primary-dark:#122038;
  --accent:#2a4a7f;--text:#1a1a2e;--text-light:#4a5568;
  --bg:#fff;--bg-gray:#f0f2f7;--border:#c8d0dc;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:'Noto Sans JP',sans-serif;color:var(--text);line-height:1.8;font-size:15px;background:var(--bg);overflow-x:hidden;width:100%;max-width:100vw}

/* ===== SKIP LINK ===== */
.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;padding:12px 24px;border-radius:0 0 8px 8px;font-size:14px;font-weight:500;z-index:300;text-decoration:none;transition:top .3s}
.skip-link:focus{top:0}

/* ===== FOCUS STYLES ===== */
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}
a:focus-visible,button:focus-visible,.btn-reserve:focus-visible,.btn-more:focus-visible,.cta-btn:focus-visible,.feature-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
nav.main-nav li a:focus-visible{outline-color:#fff;outline-offset:-2px}

/* ===== SCROLL PROGRESS BAR ===== */
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent));z-index:200;width:0;transition:none}

/* ===== ANIMATED BG PARTICLES ===== */
.particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}
.particle{position:absolute;border-radius:50%;background:var(--primary);opacity:0;animation:floatUp linear infinite}
@keyframes floatUp{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:.05}90%{opacity:.05}100%{transform:translateY(-10vh) scale(1);opacity:0}}


/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;right:0;z-index:102;background:rgba(255,255,255,.92);backdrop-filter:blur(16px) saturate(1.4);box-shadow:0 1px 0 rgba(27,46,75,.08);transition:all .4s cubic-bezier(.4,0,.2,1)}
.header.scrolled{box-shadow:0 4px 30px rgba(0,0,0,.08)}
.header-top{display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto;padding:12px 20px}
.logo{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--primary)}
.logo-img{height:46px;width:auto;display:block;transition:transform .3s}
.logo:hover .logo-img{transform:scale(1.03)}
.header-right{display:flex;align-items:center;gap:20px}
.header-tel{font-size:22px;font-weight:700;color:var(--primary);text-decoration:none;letter-spacing:1.5px;font-family:'Noto Sans JP',sans-serif;transition:color .3s;line-height:1.2}
.header-tel:hover{color:var(--primary-dark)}
.header-tel span{font-size:11px;font-weight:400;display:block;text-align:right;color:var(--text-light);font-family:'Noto Sans JP',sans-serif;letter-spacing:0;line-height:.5;margin-bottom:2px}
.btn-reserve{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;padding:14px 28px;border-radius:50px;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s;text-decoration:none;box-shadow:0 4px 14px rgba(27,46,75,.3);position:relative;overflow:hidden}
.btn-reserve::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .6s}
.btn-reserve:hover::before{left:100%}
.btn-reserve:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(27,46,75,.4)}

nav.main-nav{background:linear-gradient(90deg,var(--primary),var(--accent));position:fixed;top:0;left:0;right:0;z-index:99}
nav.main-nav ul{display:flex;justify-content:center;list-style:none;max-width:1100px;margin:0 auto}
nav.main-nav li a{display:block;color:#fff;text-decoration:none;padding:13px 24px;font-size:13px;font-weight:400;letter-spacing:.5px;transition:all .3s;position:relative}
nav.main-nav li a::after{content:'';position:absolute;bottom:8px;left:50%;width:0;height:1.5px;background:#fff;transition:all .3s;transform:translateX(-50%)}
nav.main-nav li a:hover::after{width:60%}
nav.main-nav li a:hover{background:rgba(255,255,255,.1)}

/* ===== HERO ===== */
.hero{margin-top:110px;position:relative;min-height:580px;overflow:hidden;background:linear-gradient(135deg,#e8f0f6,#d4e8f2,#e0f0f8)}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(42,74,127,.08) 0%,transparent 70%);animation:heroShimmer 8s ease-in-out infinite alternate}
@keyframes heroShimmer{0%{opacity:.5}100%{opacity:1}}
.hero-bg-image{position:absolute;inset:0;overflow:hidden}
.hero-img{width:100%;height:100%;object-fit:cover}
.hero-content{position:relative;z-index:2;max-width:1100px;margin:0 auto;padding:240px 20px 130px}
.hero h1{font-family:'Noto Serif JP',serif;font-size:34px;font-weight:500;line-height:1.7;color:var(--text);margin-bottom:8px;opacity:0;animation:slideInUp .8s .3s forwards}
.hero h1 span{color:var(--primary);font-weight:700;position:relative}
.hero h1 span::after{content:'';position:absolute;bottom:2px;left:0;width:100%;height:8px;background:linear-gradient(90deg,rgba(27,46,75,.12),rgba(42,74,127,.12));border-radius:4px;z-index:-1}
.hero p{font-size:15px;color:var(--text-light);margin-top:12px;opacity:0;animation:slideInUp .8s .5s forwards}
@keyframes slideInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

.hero-features{position:absolute;bottom:0;left:50%;transform:translateX(-50%);display:flex;gap:0;z-index:3;max-width:820px;width:90%;box-shadow:0 -4px 30px rgba(0,0,0,.06)}
.hero-feat{flex:1;color:#fff;text-align:center;padding:28px 16px;position:relative;overflow:hidden;transition:all .3s}
.hero-feat:nth-child(1){background:linear-gradient(135deg,#1b2e4b,#162742)}
.hero-feat:nth-child(2){background:linear-gradient(135deg,#2a4a7f,#243f6e)}
.hero-feat:nth-child(3){background:linear-gradient(135deg,#1f3558,#1a2d4a)}
.hero-feat::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.4),rgba(255,255,255,0))}
.hero-feat:hover{filter:brightness(1.08)}
.hero-feat-icon{margin-bottom:10px;display:flex;justify-content:center;filter:drop-shadow(0 2px 4px rgba(0,0,0,.15))}
.hero-feat-icon svg{width:36px;height:36px}
.hero-feat-text{font-size:13px;font-weight:500;line-height:1.5}

/* ===== WAVE DIVIDERS ===== */
.wave-divider{width:100%;overflow:hidden;line-height:0;position:relative;z-index:2}
.wave-divider svg{display:block;width:100%;height:auto}

/* ===== SECTIONS ===== */
.section{padding:90px 20px;position:relative}
.section-gray{background:var(--bg-gray)}
.section-title{text-align:center;margin-bottom:55px;position:relative}
.section-title h2{font-family:'Noto Serif JP',serif;font-size:30px;font-weight:500;color:var(--text);margin-bottom:6px;letter-spacing:1px}
.section-title .en{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--accent);letter-spacing:3px;display:block;font-style:italic}
.section-title::after{content:'';display:block;width:50px;height:2px;background:linear-gradient(90deg,var(--primary),var(--accent));margin:18px auto 0;border-radius:2px}
.container{max-width:1100px;margin:0 auto}

/* ===== NEWS ===== */
.news-list{max-width:800px;margin:0 auto}
.news-item{display:flex;align-items:baseline;gap:16px;padding:18px 16px;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);transition:all .3s;border-radius:4px}
.news-item:hover{color:var(--primary);background:rgba(27,46,75,.03);transform:translateX(4px)}
.news-date{font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--text-light);white-space:nowrap;font-weight:500}
.news-tag{font-size:11px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:3px 14px;border-radius:20px;white-space:nowrap;font-weight:400;letter-spacing:.3px}
.news-tag.tag-info{background:linear-gradient(135deg,var(--accent),#4abcd6)}
.news-text{font-size:14px}

/* ===== COUNTER STATS ===== */
.stats-bar{background:linear-gradient(135deg,var(--primary),var(--accent));padding:50px 20px;position:relative;overflow:hidden;max-width:100vw}
.stats-bar::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.stats-grid{display:flex;justify-content:center;gap:80px;max-width:900px;margin:0 auto;flex-wrap:wrap}
.stat-item{text-align:center;color:#fff}
.stat-num{font-family:'Noto Sans JP',sans-serif;font-size:56px;font-weight:700;line-height:1.1;display:block}
.stat-unit{font-size:16px;font-weight:400;margin-left:4px}
.stat-label{font-size:13px;margin-top:6px;opacity:.85;letter-spacing:.5px}

/* ===== SYMPTOMS ===== */
.symptoms-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;max-width:820px;margin:0 auto}
.symptom-card{background:#fff;border:1.5px solid var(--border);border-radius:50px;padding:16px 20px;text-align:center;font-size:14px;font-weight:500;transition:all .35s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden;font-family:inherit;color:var(--text);line-height:1.8}
.symptom-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary),var(--accent));opacity:0;transition:opacity .35s;border-radius:50px}
.symptom-card span{position:relative;z-index:1;transition:color .35s}
.symptom-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:0 8px 24px rgba(27,46,75,.18)}
.symptom-card:hover::before{opacity:1}
.symptom-card:hover span{color:#fff}

/* ===== FEATURES ===== */
.features-section{padding:90px 0 130px;background:#fff;position:relative;overflow:hidden;max-width:100vw}
.features-section::before{content:'';position:absolute;width:600px;height:600px;border-radius:50%;border:1.5px solid rgba(27,46,75,.06);background:radial-gradient(circle,rgba(27,46,75,.02) 0%,transparent 70%);top:-200px;left:-220px;pointer-events:none}
.features-section::after{content:'';position:absolute;width:450px;height:450px;border-radius:50%;border:1.5px solid rgba(27,46,75,.05);background:radial-gradient(circle,rgba(27,46,75,.015) 0%,transparent 70%);bottom:-120px;right:-120px;pointer-events:none}
.features-section .section-title{margin-bottom:65px}
.features-grid{max-width:960px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:40px}
.feature-card{position:relative;transition:transform .5s cubic-bezier(.4,0,.2,1);box-shadow:0 8px 36px rgba(0,0,0,.18);border-radius:8px;overflow:hidden;background:#fff}
.feature-card:hover{transform:translateY(-5px);box-shadow:0 14px 48px rgba(27,46,75,.28)}
.feature-img-area{position:relative;overflow:visible}
.feature-img{width:100%;height:230px;position:relative;overflow:hidden;z-index:1}
.feature-card:nth-child(odd) .feature-img{clip-path:polygon(0 0,100% 0,100% 85%,0 100%)}
.feature-card:nth-child(even) .feature-img{clip-path:polygon(0 0,100% 0,100% 100%,0 85%)}
img.feature-img-bg{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s}
.feature-card:hover img.feature-img-bg{transform:scale(1.04)}
.feature-number{position:absolute;z-index:5;font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:96px;letter-spacing:3px;color:var(--primary);opacity:.10;white-space:nowrap;writing-mode:vertical-lr;line-height:1;pointer-events:none;transition:opacity .4s}
.feature-card:hover .feature-number{opacity:.18}
.feature-card:nth-child(odd) .feature-number{right:-6px;top:20px}
.feature-card:nth-child(even) .feature-number{left:-6px;top:20px}
.feature-body{position:relative;z-index:2;padding:24px 28px 28px;margin:0}
.feature-body h3{font-size:16px;font-weight:700;line-height:1.65;color:var(--text);margin-bottom:10px}
.feature-body p{font-size:13px;color:var(--text-light);line-height:2;margin-bottom:16px}
.feature-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--primary);text-decoration:none;border:1.5px solid var(--primary);padding:6px 14px;background:#fff;transition:all .35s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;overflow:hidden}
.feature-btn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary),var(--accent));transform:translateX(-101%);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.feature-btn span{position:relative;z-index:1}
.feature-btn::after{content:'';display:inline-block;width:5px;height:5px;border-right:1.5px solid var(--primary);border-bottom:1.5px solid var(--primary);transform:rotate(-45deg);transition:all .35s;position:relative;z-index:1}
.feature-btn:hover{color:#fff;border-color:var(--primary)}
.feature-btn:hover::before{transform:translateX(0)}
.feature-btn:hover::after{border-color:#fff;transform:rotate(-45deg) translateX(2px)}

/* ===== GREETING ===== */
.greeting-wrap{display:flex;gap:50px;align-items:flex-start;max-width:920px;margin:0 auto}
.greeting-photo{flex-shrink:0;width:290px;height:350px;border-radius:14px;background:linear-gradient(135deg,#e0ecf4,#d4dfe8);position:relative;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.08)}
.greeting-photo img{width:100%;height:100%;object-fit:cover}
.greeting-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 60%,rgba(0,0,0,.04))}
.greeting-photo-label{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(135deg,rgba(27,46,75,.9),rgba(42,74,127,.9));color:#fff;padding:14px 16px;font-size:12px;text-align:center;z-index:2;letter-spacing:.3px}
.greeting-text h3{font-family:'Noto Serif JP',serif;font-size:21px;font-weight:500;margin-bottom:22px;line-height:1.65;color:var(--text)}
.greeting-text p{font-size:14px;color:var(--text-light);line-height:2.1;margin-bottom:16px}
.btn-more{display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--primary);color:var(--primary);padding:11px 34px;border-radius:50px;font-size:13px;text-decoration:none;transition:all .35s;position:relative;overflow:hidden}
.btn-more::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:50px;transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.4,0,.2,1)}
.btn-more span{position:relative;z-index:1}
.btn-more:hover::before{transform:scaleX(1)}
.btn-more:hover{color:#fff;border-color:var(--primary)}

/* ===== INFO ===== */
.info-wrap{display:flex;gap:44px;max-width:1020px;margin:0 auto}
.info-left{flex:1}
.info-right{flex:1;border-radius:14px;overflow:hidden;min-height:320px;box-shadow:0 4px 20px rgba(0,0,0,.05)}
.map-wrap{width:100%;height:100%;min-height:320px}
.map-wrap iframe{width:100%;height:100%;min-height:320px;display:block}
.info-name{font-size:12px;color:var(--text-light);margin-bottom:4px;letter-spacing:1px}
.info-clinic{font-size:21px;font-weight:700;margin-bottom:10px}
.info-address{font-size:13px;color:var(--text-light);margin-bottom:18px;line-height:1.7}
.info-tel-big{font-family:'Noto Sans JP',sans-serif;font-size:26px;font-weight:700;color:var(--primary);margin-bottom:22px;letter-spacing:2px}
.schedule-table{width:100%;border-collapse:collapse;font-size:13px;margin-bottom:14px;overflow:hidden;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.04)}
.schedule-table th,.schedule-table td{padding:11px 8px;text-align:center;border:1px solid var(--border)}
.schedule-table thead th{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:500;border-color:rgba(255,255,255,.15)}
.schedule-table tbody th{background:var(--primary-light);font-weight:500;white-space:nowrap}
.schedule-table tbody td{transition:background .2s}
.schedule-table tbody tr:hover td{background:rgba(27,46,75,.04)}
.schedule-note{font-size:12px;color:var(--text-light);line-height:1.9}

/* ===== CTA ===== */
.cta-banner{background:linear-gradient(135deg,var(--primary),var(--accent));padding:60px 20px;text-align:center;position:relative;overflow:hidden;max-width:100vw}
.cta-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='50' cy='50' r='40' fill='none' stroke='%23ffffff' stroke-width='.5' opacity='.06'/%3E%3C/svg%3E")}
.cta-banner h2{color:#fff;font-family:'Noto Serif JP',serif;font-size:26px;font-weight:500;margin-bottom:10px;position:relative}
.cta-banner p{color:rgba(255,255,255,.85);font-size:14px;margin-bottom:28px;position:relative}
.cta-btn{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--primary);font-size:15px;font-weight:700;padding:16px 44px;border-radius:50px;text-decoration:none;transition:all .3s;box-shadow:0 4px 20px rgba(0,0,0,.12);position:relative}
.cta-btn:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(0,0,0,.18)}
.cta-btn svg{width:18px;height:18px;transition:transform .3s}
.cta-btn:hover svg{transform:translateX(3px)}

/* ===== FOOTER ===== */
.site-footer{background:linear-gradient(135deg,#1e2d3d,#2c3e50);color:#99a;padding:50px 20px 30px;position:relative}
.site-footer::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--accent),var(--primary))}
.footer-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;gap:40px}
.footer-links{display:flex;gap:28px;flex-wrap:wrap}
.footer-links a{color:#aab;text-decoration:none;font-size:13px;transition:all .3s;position:relative}
.footer-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width .3s}
.footer-links a:hover{color:#fff}
.footer-links a:hover::after{width:100%}
.footer-copy{text-align:center;margin-top:35px;padding-top:22px;border-top:1px solid rgba(255,255,255,.06);font-size:12px;color:#667;letter-spacing:.5px}

/* ===== SCROLL TOP ===== */
.scroll-top{position:fixed;bottom:30px;right:30px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(27,46,75,.35);opacity:0;transform:translateY(20px);transition:all .4s;z-index:50}
.scroll-top svg{width:20px;height:20px}
.scroll-top.show{opacity:1;transform:translateY(0)}
.scroll-top:hover{transform:translateY(-3px);box-shadow:0 6px 28px rgba(27,46,75,.45)}

/* ===== HAMBURGER MENU ===== */
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:6px;z-index:110;position:relative;width:32px;height:24px}
.hamburger span{display:block;width:100%;height:2px;background:var(--primary);border-radius:1px;position:absolute;left:0;transition:all .3s cubic-bezier(.4,0,.2,1)}
.hamburger.active span{background:var(--primary)}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:50%;transform:translateY(-50%)}
.hamburger span:nth-child(3){bottom:0}
.hamburger.active span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:translateX(-10px)}
.hamburger.active span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:98;opacity:0;transition:opacity .3s}
.nav-overlay.show{opacity:1}

/* ===== ANIMATIONS ===== */
.fade-in{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.4,0,.2,1),transform .8s cubic-bezier(.4,0,.2,1)}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fd1{transition-delay:.18s}
.fade-in-left{opacity:0;transform:translateX(-40px);transition:opacity .8s,transform .8s}
.fade-in-left.visible{opacity:1;transform:translateX(0)}
.fade-in-right{opacity:0;transform:translateX(40px);transition:opacity .8s,transform .8s}
.fade-in-right.visible{opacity:1;transform:translateX(0)}

/* ===== WORDPRESS DEFAULTS ===== */
.alignleft{float:left;margin-right:1.5em;margin-bottom:1em}
.alignright{float:right;margin-left:1.5em;margin-bottom:1em}
.aligncenter{display:block;margin:0 auto 1em}
img{max-width:100%;height:auto}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
.header-top{padding:10px 16px}
.header-tel{font-size:20px}
.hero h1{font-size:30px}
.features-grid{max-width:720px;gap:30px}
.feature-number{font-size:80px}
.greeting-wrap{gap:36px}
.greeting-photo{width:250px;height:310px}
.stats-grid{gap:50px}
.info-wrap{gap:30px}
}

@media(max-width:768px){
.hamburger{display:block}
.header-top{flex-wrap:nowrap;justify-content:space-between;gap:8px}
.header-right{gap:10px}
.header-tel{display:none}
.logo-img{height:34px}
.btn-reserve{padding:8px 16px;font-size:11px;border-radius:40px}
nav.main-nav{position:fixed;top:0;left:0;right:0;bottom:0;z-index:101;background:rgba(255,255,255,.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;transform:translateY(-100%);transition:transform .4s cubic-bezier(.4,0,.2,1);opacity:0;pointer-events:none}
nav.main-nav.open{transform:translateY(0);opacity:1;pointer-events:auto}
nav.main-nav ul{flex-direction:column;align-items:center;gap:0;width:100%}
nav.main-nav li{width:100%;text-align:center;border-bottom:1px solid rgba(27,46,75,.08)}
nav.main-nav li:last-child{border-bottom:none}
nav.main-nav li a{padding:18px 24px;font-size:16px;font-weight:500;letter-spacing:1px;color:var(--primary)}
nav.main-nav li a::after{display:none}
nav.main-nav li a:hover{background:rgba(27,46,75,.05)}
.particles{display:none}
.nav-overlay{display:block}
.hero{height:auto;min-height:auto;margin-top:56px}
.hero-content{padding:60px 20px 20px;height:auto}
.hero h1{font-size:26px}
.hero p{font-size:14px}
.hero-features{flex-direction:row;position:relative;transform:none;left:0;width:100%;max-width:100%;box-shadow:none}
.hero-feat{padding:14px 8px;aspect-ratio:auto;display:flex;flex-direction:column;align-items:center;justify-content:center}
.wave-divider{display:none}
.symptoms-grid{grid-template-columns:1fr 1fr;max-width:400px}
.features-grid{grid-template-columns:1fr;max-width:460px}
.feature-card:nth-child(2){margin-top:0}
.feature-card:nth-child(3){margin-top:0}
.feature-number{font-size:68px}
.feature-img{height:200px}
.greeting-wrap{flex-direction:column;gap:30px}
.greeting-photo{width:100%;height:auto;aspect-ratio:290/350}
.info-wrap{flex-direction:column}
.info-right{min-height:200px}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.stat-num{font-size:42px}
.stat-unit{font-size:14px}
.footer-inner{flex-direction:column;text-align:center}
.footer-links{justify-content:center}
.cta-banner h2{font-size:22px}
.cta-btn{padding:14px 34px;font-size:14px}
.cursor-glow{display:none}
.scroll-top{bottom:20px;right:20px;width:42px;height:42px}
}

@media(max-width:480px){
.header-top{padding:8px 12px}
.logo-img{height:32px}
.btn-reserve{padding:7px 14px;font-size:10px}
.hero{min-height:auto;margin-top:60px}
.hero-feat{aspect-ratio:auto;padding:14px 6px}
.hero-feat-icon svg{width:28px;height:28px}
.hero-feat-text{font-size:11px;line-height:1.4}
.hero h1{font-size:22px;line-height:1.6}
.hero p{font-size:13px}
.section{padding:60px 16px}
.section-title h2{font-size:24px}
.section-title .en{font-size:12px;letter-spacing:2px}
.news-item{flex-wrap:wrap;gap:8px}
.news-date{font-size:14px}
.news-text{font-size:13px;width:100%}
.symptoms-grid{grid-template-columns:1fr 1fr;gap:10px;max-width:100%}
.symptom-card{padding:12px 14px;font-size:13px}
.features-section{padding:60px 0 80px}
.features-grid{padding:0 16px;gap:24px}
.feature-body{padding:20px 20px 24px;margin:0}
.feature-body h3{font-size:15px}
.feature-body p{font-size:12px}
.feature-number{font-size:56px}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.stat-num{font-size:38px}
.greeting-text h3{font-size:18px}
.greeting-text p{font-size:13px}
.greeting-photo{height:auto;aspect-ratio:290/350}
.info-clinic{font-size:18px}
.info-tel-big{font-size:22px}
.schedule-table{font-size:11px}
.schedule-table th,.schedule-table td{padding:8px 4px}
.cta-banner{padding:44px 16px}
.cta-banner h2{font-size:20px}
.cta-banner p{font-size:13px}
.cta-btn{padding:12px 28px;font-size:13px}
.footer-links{gap:18px}
.footer-links a{font-size:12px}
}
