*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--primary-green:#2d7a4f;--light-green:#4aa871;--dark-green:#1e5a3a;--accent-green:#90d5a8;--bg-white:#ffffff;--bg-light:#f8f9fa;--bg-gray:#e9ecef;--text-dark:#212529;--text-gray:#6c757d;--border-color:#dee2e6;--shadow:0 2px 8px rgba(0,0,0,0.1);--shadow-hover:0 4px 16px rgba(45,122,79,0.2);--transition:all 0.3s ease;--header-height:80px}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Segoe UI',Tahoma,Geneva,Verdana,sans-serif,'Hiragino Sans','Hiragino Kaku Gothic ProN','Noto Sans JP',sans-serif;line-height:1.7;color:var(--text-dark);background-color:var(--bg-white);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary-green);text-decoration:none;transition:var(--transition)}
a:hover,a:focus{color:var(--dark-green);text-decoration:underline}
a:focus{outline:2px solid var(--primary-green);outline-offset:2px}
button{cursor:pointer;border:none;background:none;font-family:inherit;transition:var(--transition)}
button:focus{outline:2px solid var(--primary-green);outline-offset:2px}
ul,ol{list-style:none}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section{padding:80px 0;animation:fadeInUp 0.8s ease-out}
.section-title{font-size:2.5rem;color:var(--primary-green);text-align:center;margin-bottom:50px;position:relative;padding-bottom:15px}
.section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:80px;height:4px;background:linear-gradient(90deg,var(--light-green),var(--accent-green));border-radius:2px}
#header{position:fixed;top:0;left:0;right:0;background:var(--bg-white);box-shadow:var(--shadow);z-index:1000;height:var(--header-height);transition:var(--transition)}
#header.scrolled{box-shadow:0 4px 12px rgba(0,0,0,0.15)}
.header-container{max-width:1200px;margin:0 auto;padding:0 20px;height:100%;display:flex;justify-content:space-between;align-items:center}
.logo-area{display:flex;align-items:center;gap:15px}
.logo-img{height:50px;width:auto;object-fit:contain;transition:var(--transition)}
.logo-img:hover{transform:scale(1.05)}
.company-name{font-size:1.5rem;color:var(--primary-green);font-weight:700}
.main-nav ul{display:flex;gap:30px;align-items:center}
.main-nav a{color:var(--text-dark);font-weight:500;padding:10px 5px;position:relative}
.main-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--primary-green);transition:width 0.3s ease}
.main-nav a:hover::after,.main-nav a:focus::after{width:100%}
.menu-toggle{display:none;flex-direction:column;gap:5px;width:30px;height:30px;justify-content:center;z-index:1001}
.menu-toggle span{display:block;width:100%;height:3px;background:var(--primary-green);border-radius:2px;transition:var(--transition)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(7px,7px)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}
.hero-section{margin-top:var(--header-height);position:relative;min-height:600px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--light-green) 0%,var(--primary-green) 100%);overflow:hidden}
.hero-content{position:relative;width:100%;animation:fadeIn 1s ease-out}
.hero-image{width:100%;height:600px;object-fit:cover;opacity:0.3;filter:brightness(1.1)}
.hero-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--bg-white);width:90%;max-width:800px}
.hero-title{font-size:3rem;font-weight:700;margin-bottom:20px;text-shadow:2px 2px 8px rgba(0,0,0,0.3);animation:slideInDown 0.8s ease-out}
.hero-subtitle{font-size:1.5rem;text-shadow:1px 1px 4px rgba(0,0,0,0.3);animation:slideInUp 0.8s ease-out 0.2s both}
.services-section{background:var(--bg-light)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}
.service-card{background:var(--bg-white);padding:30px;border-radius:12px;box-shadow:var(--shadow);transition:var(--transition);text-align:center;animation:fadeInUp 0.6s ease-out}
.service-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-hover)}
.service-icon{width:80px;height:80px;margin:0 auto 20px;object-fit:contain;transition:var(--transition)}
.service-card:hover .service-icon{transform:scale(1.1) rotate(5deg)}
.service-title{font-size:1.3rem;color:var(--primary-green);margin-bottom:15px;font-weight:600}
.service-description{color:var(--text-gray);line-height:1.8}
.company-section{background:var(--bg-white)}
.company-content{max-width:800px;margin:0 auto}
.info-table{width:100%;border-collapse:collapse;background:var(--bg-white);box-shadow:var(--shadow);border-radius:8px;overflow:hidden}
.info-table tr{border-bottom:1px solid var(--border-color);transition:var(--transition)}
.info-table tr:last-child{border-bottom:none}
.info-table tr:hover{background:var(--bg-light)}
.info-table th{background:var(--primary-green);color:var(--bg-white);padding:15px 20px;text-align:left;font-weight:600;width:200px;vertical-align:top}
.info-table td{padding:15px 20px;color:var(--text-dark)}
.pharmacy-section{background:var(--bg-light)}
.pharmacy-info{background:var(--bg-white);padding:40px;border-radius:12px;box-shadow:var(--shadow)}
.pharmacy-name{font-size:2rem;color:var(--primary-green);margin-bottom:20px;font-weight:700}
.pharmacy-intro{font-size:1.1rem;line-height:1.9;color:var(--text-dark);margin-bottom:40px;padding:20px;background:var(--bg-light);border-left:4px solid var(--primary-green);border-radius:4px}
.pharmacy-image-container{margin-bottom:40px;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);animation:fadeInUp 0.8s ease-out}
.pharmacy-image{width:100%;height:auto;object-fit:cover;max-height:500px}
.pharmacy-details{display:flex;flex-direction:column;gap:30px;margin-bottom:40px}
.pharmacy-details-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}
.detail-group{animation:fadeInUp 0.6s ease-out}
.detail-group-wide{grid-column:1/-1}
.detail-title{font-size:1.2rem;color:var(--primary-green);margin-bottom:15px;font-weight:600;padding-bottom:10px;border-bottom:2px solid var(--accent-green)}
.service-list,.facility-list,.insurance-list{padding-left:20px}
.service-list{column-count:3;column-gap:20px}
.insurance-list{column-count:3;column-gap:20px}
.service-list li,.facility-list li,.insurance-list li{position:relative;padding-left:20px;margin-bottom:10px;color:var(--text-dark);line-height:1.8;break-inside:avoid}
.service-list li::before,.facility-list li::before,.insurance-list li::before{content:'✓';position:absolute;left:0;color:var(--primary-green);font-weight:700}
.legal-info{background:var(--bg-light);padding:30px;border-radius:8px;margin-top:40px;border:2px solid var(--primary-green)}
.legal-title{font-size:1.5rem;color:var(--primary-green);margin-bottom:20px;font-weight:700}
.legal-table{margin-bottom:30px}
.pdf-btn{display:inline-flex;align-items:center;gap:10px;background:var(--primary-green);color:var(--bg-white);padding:15px 30px;border-radius:8px;font-weight:600;text-decoration:none;transition:var(--transition);box-shadow:var(--shadow)}
.pdf-btn:hover,.pdf-btn:focus{background:var(--dark-green);transform:translateY(-2px);box-shadow:var(--shadow-hover);text-decoration:none}
.btn-icon{width:24px;height:24px;object-fit:contain;filter:brightness(0) invert(1)}
.news-section{background:var(--bg-white)}
.news-container{max-width:900px;margin:0 auto}
.news-item{background:var(--bg-white);border:1px solid var(--border-color);border-radius:8px;padding:25px;margin-bottom:20px;transition:var(--transition);animation:fadeInUp 0.5s ease-out;box-shadow:var(--shadow)}
.news-item:hover{transform:translateX(10px);box-shadow:var(--shadow-hover);border-color:var(--primary-green)}
.news-date{display:inline-block;background:var(--primary-green);color:var(--bg-white);padding:5px 15px;border-radius:20px;font-size:0.9rem;margin-bottom:10px;font-weight:600}
.news-title{font-size:1.3rem;color:var(--primary-green);margin-bottom:10px;font-weight:600}
.news-content{color:var(--text-gray);line-height:1.8}
.loading-text{text-align:center;color:var(--text-gray);padding:40px;font-size:1.1rem}
.recruit-section{background:var(--bg-light)}
.recruit-content{max-width:800px;margin:0 auto;text-align:center;padding:60px 40px;background:var(--bg-white);border-radius:12px;box-shadow:var(--shadow)}
.recruit-text{font-size:1.5rem;color:var(--primary-green);margin-bottom:20px;font-weight:600}
.recruit-note{color:var(--text-gray);font-size:1.1rem}
.contact-section{background:var(--bg-white)}
.contact-content{max-width:800px;margin:0 auto}
.contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-bottom:40px}
.contact-item{display:flex;align-items:flex-start;gap:15px;padding:20px;background:var(--bg-light);border-radius:8px;transition:var(--transition)}
.contact-item:hover{background:var(--accent-green);transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.contact-icon{width:50px;height:50px;object-fit:contain;flex-shrink:0}
.contact-detail{flex-grow:1}
.contact-label{font-size:0.9rem;color:var(--text-gray);margin-bottom:5px;font-weight:600}
.contact-value{font-size:1.1rem;color:var(--text-dark);word-break:break-all}
.contact-note{background:var(--bg-light);padding:25px;border-radius:8px;border-left:4px solid var(--primary-green)}
.contact-note p{color:var(--text-gray);margin-bottom:10px;line-height:1.8}
.contact-note p:last-child{margin-bottom:0}
#footer{background:var(--dark-green);color:var(--bg-white);padding:40px 0 20px}
.footer-container{max-width:1200px;margin:0 auto;padding:0 20px}
.footer-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:30px}
.footer-logo{display:flex;align-items:center;gap:15px;background:var(--bg-white);padding:10px 20px;border-radius:8px;box-shadow:var(--shadow)}
.footer-logo-img{height:40px;width:auto;object-fit:contain}
.footer-company{font-size:1.2rem;font-weight:600;color:var(--primary-green)}
.footer-nav-list{display:flex;gap:25px;flex-wrap:wrap}
.footer-nav a{color:var(--bg-white);font-size:0.9rem}
.footer-nav a:hover,.footer-nav a:focus{color:var(--accent-green)}
.copyright{text-align:center;padding-top:20px;border-top:1px solid rgba(255,255,255,0.2);color:rgba(255,255,255,0.8);font-size:0.9rem}
.back-to-top{position:fixed;bottom:30px;right:30px;width:50px;height:50px;background:var(--primary-green);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:var(--transition);box-shadow:var(--shadow);z-index:999}
.back-to-top.visible{opacity:1;visibility:visible}
.back-to-top:hover,.back-to-top:focus{background:var(--dark-green);transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.arrow-up{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:12px solid var(--bg-white)}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInDown{from{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInUp{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:768px){:root{--header-height:70px;font-size:14px}
.section{padding:50px 0}
.section-title{font-size:2rem;margin-bottom:30px}
.header-container{padding:0 15px}
.logo-img{height:40px}
.company-name{font-size:1.2rem}
.menu-toggle{display:flex}
.main-nav{position:fixed;top:var(--header-height);left:0;right:0;background:var(--bg-white);box-shadow:var(--shadow);max-height:0;overflow:hidden;transition:max-height 0.4s ease}
.main-nav.active{max-height:500px}
.main-nav ul{flex-direction:column;gap:0;padding:20px 0}
.main-nav li{width:100%;text-align:center;border-bottom:1px solid var(--border-color)}
.main-nav a{display:block;padding:15px 20px}
.hero-section{min-height:400px}
.hero-image{height:400px}
.hero-title{font-size:2rem;margin-bottom:15px}
.hero-subtitle{font-size:1.2rem}
.services-grid{grid-template-columns:1fr;gap:20px}
.service-card{padding:25px}
.pharmacy-details-row{grid-template-columns:1fr}
.info-table th{width:120px;padding:12px 15px;font-size:0.9rem}
.info-table td{padding:12px 15px}
.pharmacy-info{padding:25px}
.pharmacy-intro{font-size:1rem;padding:15px}
.pharmacy-image{max-height:300px}
.service-list{column-count:2}
.insurance-list{column-count:2}
.detail-group-wide{grid-column:1/-1}
.legal-info{padding:20px}
.pdf-btn{padding:12px 20px;font-size:0.9rem}
.news-item{padding:20px}
.news-item:hover{transform:translateX(5px)}
.news-title{font-size:1.2rem}
.contact-info{grid-template-columns:1fr}
.contact-item{padding:15px}
.footer-content{flex-direction:column;align-items:flex-start;text-align:center}
.footer-logo{flex-direction:column;align-items:center;width:100%}
.footer-nav{width:100%}
.footer-nav-list{justify-content:center;gap:15px;font-size:0.85rem}
.back-to-top{bottom:20px;right:20px;width:45px;height:45px}
}
@media(max-width:480px){.section-title{font-size:1.75rem}
.hero-title{font-size:1.75rem}
.hero-subtitle{font-size:1.1rem}
.company-name{font-size:1.1rem}
.info-table th{width:100px;font-size:0.85rem}
.pharmacy-name{font-size:1.75rem}
.service-list{column-count:1}
.insurance-list{column-count:1}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important}html{scroll-behavior:auto}}
