*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--primary-blue:#0066CC;--secondary-blue:#0052A3;--light-blue:#E6F2FF;--dark-blue:#003D7A;--accent-blue:#3399FF;--text-dark:#1A1A1A;--text-gray:#666666;--bg-white:#FFFFFF;--bg-light:#F5F9FF;--border-color:#D1E5FF;--shadow:0 2px 10px rgba(0,102,204,0.1);--shadow-lg:0 4px 20px rgba(0,102,204,0.15);--transition:all 0.3s ease;--font-base:'Hiragino Kaku Gothic ProN','Hiragino Sans',Meiryo,sans-serif}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-base);color:var(--text-dark);line-height:1.7;background:var(--bg-white);overflow-x:hidden}
a{color:var(--primary-blue);text-decoration:none;transition:var(--transition)}
a:hover,a:focus{color:var(--secondary-blue);outline:2px solid var(--accent-blue);outline-offset:2px}
img{max-width:100%;height:auto;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.header{position:relative;background:linear-gradient(135deg,rgba(0,102,204,0.95) 0%,rgba(0,82,163,0.95) 100%),url('IMAGE/店舗外観.jpg');background-size:cover;background-position:center;background-attachment:fixed;color:var(--bg-white)}
.nav{background:rgba(255,255,255,0.98);box-shadow:var(--shadow);position:sticky;top:0;z-index:1000;animation:slideDown 0.5s ease}
@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
.nav .container{display:flex;justify-content:space-between;align-items:center;padding:15px 20px}
.nav-brand{display:flex;align-items:center;gap:15px}
.logo{max-height:50px;width:auto;animation:fadeIn 0.8s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.company-name{font-size:1.4rem;font-weight:700;color:var(--primary-blue);white-space:nowrap}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:5px}
.nav-toggle span{width:25px;height:3px;background:var(--primary-blue);border-radius:2px;transition:var(--transition)}
.nav-menu{display:flex;list-style:none;gap:30px;margin:0}
.nav-menu a{color:var(--text-dark);font-weight:500;padding:8px 0;display:block;position:relative}
.nav-menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--primary-blue);transition:width 0.3s ease}
.nav-menu a:hover::after,.nav-menu a:focus::after{width:100%}
.hero{padding:120px 0;text-align:center;position:relative}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at center,transparent 0%,rgba(0,0,0,0.2) 100%);pointer-events:none}
.hero-content{max-width:550px;margin:0 auto;position:relative;z-index:1;animation:fadeInUp 1s ease;background:rgba(255,255,255,0.1);backdrop-filter:blur(10px);padding:50px 40px;border-radius:20px;box-shadow:0 8px 32px rgba(0,0,0,0.3)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.hero-title{font-size:4rem;margin-bottom:25px;color:var(--bg-white);text-shadow:3px 3px 6px rgba(0,0,0,0.4);font-weight:700;letter-spacing:0.05em}
.hero-subtitle{font-size:1.4rem;margin-bottom:35px;color:rgba(255,255,255,0.95);line-height:1.9;text-shadow:2px 2px 4px rgba(0,0,0,0.3);font-weight:500}
.hero-image{max-width:900px;margin:0 auto;border-radius:10px;overflow:hidden;box-shadow:var(--shadow-lg);animation:fadeInUp 1.2s ease}
.hero-image img{width:100%;object-fit:cover}
.btn{display:inline-block;padding:15px 40px;border-radius:50px;font-weight:600;transition:var(--transition);cursor:pointer;border:none;font-size:1rem}
.btn-primary{background:var(--bg-white);color:var(--primary-blue);box-shadow:var(--shadow)}
.btn-primary:hover,.btn-primary:focus{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--light-blue)}
.btn-secondary{background:var(--primary-blue);color:var(--bg-white);margin-top:20px}
.btn-secondary:hover,.btn-secondary:focus{background:var(--secondary-blue);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.section{padding:80px 0}
.section:nth-child(even){background:var(--bg-light)}
.section-title{font-size:2.5rem;text-align:center;margin-bottom:50px;color:var(--primary-blue);position:relative;padding-bottom:20px}
.section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:80px;height:4px;background:linear-gradient(90deg,var(--accent-blue),var(--primary-blue));border-radius:2px}
.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:40px}
.service-card{background:var(--bg-white);padding:40px 30px;border-radius:15px;text-align:center;box-shadow:var(--shadow);transition:var(--transition);animation:fadeInUp 0.6s ease backwards}
.service-card:nth-child(1){animation-delay:0.1s}
.service-card:nth-child(2){animation-delay:0.2s}
.service-card:nth-child(3){animation-delay:0.3s}
.service-card:nth-child(4){animation-delay:0.4s}
.service-card:hover,.service-card:focus-within{transform:translateY(-10px);box-shadow:var(--shadow-lg);border:2px solid var(--accent-blue)}
.service-icon{width:80px;height:80px;margin:0 auto 25px;background:var(--light-blue);border-radius:50%;display:flex;align-items:center;justify-content:center}
.service-icon img{width:50px;height:50px;object-fit:contain}
.service-card-title{font-size:1.5rem;margin-bottom:15px;color:var(--primary-blue)}
.service-card-text{color:var(--text-gray);line-height:1.8}
.company-content{display:grid;grid-template-columns:1fr 2fr;gap:40px;align-items:start}
.company-logo{border-radius:15px;overflow:hidden;box-shadow:var(--shadow);animation:fadeInLeft 0.8s ease;display:flex;align-items:center;justify-content:center;background:var(--bg-white);padding:20px}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}
.company-logo img{width:100%;height:auto;object-fit:contain;max-height:300px}
.info-table{width:100%;border-collapse:collapse;background:var(--bg-white);border-radius:10px;overflow:hidden;box-shadow:var(--shadow);animation:fadeInRight 0.8s ease}
@keyframes fadeInRight{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}
.info-table th,.info-table td{padding:18px 20px;text-align:left;border-bottom:1px solid var(--border-color)}
.info-table th{background:var(--light-blue);color:var(--primary-blue);font-weight:600;width:35%;white-space:nowrap}
.info-table td{color:var(--text-dark)}
.info-table tr:last-child th,.info-table tr:last-child td{border-bottom:none}
.info-table a{font-weight:500}
.hours-list,.insurance-list{list-style:none;margin:0;padding:0}
.hours-list li,.insurance-list li{padding:5px 0;position:relative;padding-left:20px}
.hours-list li::before{content:'•';color:var(--primary-blue);font-weight:700;position:absolute;left:0}
.insurance-list li{padding-left:25px;line-height:1.6}
.insurance-list li::before{content:'✓';color:var(--primary-blue);font-weight:700;position:absolute;left:0}
.pharmacy-card{background:var(--bg-white);border-radius:15px;padding:40px;box-shadow:var(--shadow-lg);animation:fadeInUp 0.8s ease}
.pharmacy-header{margin-bottom:30px;padding-bottom:25px;border-bottom:2px solid var(--border-color)}
.pharmacy-name{font-size:2rem;color:var(--primary-blue);margin-bottom:15px}
.pharmacy-intro{color:var(--text-gray);line-height:1.9;font-size:1.05rem}
.pharmacy-body{display:flex;flex-direction:column;gap:30px}
.pharmacy-body>.pharmacy-image{border-radius:10px;overflow:hidden;box-shadow:var(--shadow);max-width:600px;margin:0 auto}
.pharmacy-body>.pharmacy-image img{width:100%;height:auto;object-fit:cover}
.pharmacy-info .info-table{margin-bottom:20px}
.legal-info{margin:30px 0;padding:25px;background:var(--bg-light);border-radius:10px;border-left:4px solid var(--primary-blue)}
.legal-title{font-size:1.3rem;color:var(--primary-blue);margin-bottom:20px}
.news-list{display:grid;gap:20px}
.news-item{background:var(--bg-white);padding:25px 30px;border-radius:10px;border-left:4px solid var(--primary-blue);box-shadow:var(--shadow);transition:var(--transition);animation:fadeInUp 0.5s ease backwards}
.news-item:nth-child(1){animation-delay:0.1s}
.news-item:nth-child(2){animation-delay:0.2s}
.news-item:nth-child(3){animation-delay:0.3s}
.news-item:nth-child(4){animation-delay:0.4s}
.news-item:nth-child(5){animation-delay:0.5s}
.news-item:hover,.news-item:focus-within{transform:translateX(10px);box-shadow:var(--shadow-lg)}
.news-date{color:var(--primary-blue);font-weight:600;margin-bottom:10px;font-size:0.95rem}
.news-title{font-size:1.3rem;margin-bottom:10px;color:var(--text-dark);font-weight:600}
.news-content{color:var(--text-gray);line-height:1.8}
.recruit-content{text-align:center;padding:60px 0}
.recruit-message{font-size:1.2rem;color:var(--text-gray);padding:40px;background:var(--bg-white);border-radius:15px;box-shadow:var(--shadow)}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px}
.contact-card{background:var(--bg-white);padding:35px;border-radius:15px;box-shadow:var(--shadow);transition:var(--transition);animation:fadeInUp 0.6s ease backwards}
.contact-card:nth-child(1){animation-delay:0.1s}
.contact-card:nth-child(2){animation-delay:0.2s}
.contact-card:hover,.contact-card:focus-within{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.contact-title{font-size:1.5rem;color:var(--primary-blue);margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-color)}
.contact-info{font-style:normal;color:var(--text-gray);line-height:1.9}
.contact-info p{margin-bottom:20px}
.contact-info strong{color:var(--primary-blue);display:block;margin-bottom:5px}
.footer{background:var(--dark-blue);color:var(--bg-white);padding:50px 0 20px}
.footer-content{display:flex;justify-content:space-between;align-items:start;margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,0.2)}
.footer-brand{display:flex;flex-direction:row;gap:15px;align-items:center}
.footer-logo{max-height:60px;height:60px;width:auto;object-fit:contain}
.footer-company{font-size:1.2rem;font-weight:600}
.footer-nav ul{display:flex;flex-wrap:wrap;gap:25px;list-style:none}
.footer-nav a{color:var(--bg-white);transition:var(--transition)}
.footer-nav a:hover,.footer-nav a:focus{color:var(--accent-blue);outline-color:var(--bg-white)}
.footer-copyright{text-align:center;color:rgba(255,255,255,0.8);font-size:0.9rem}
.scroll-top{position:fixed;bottom:30px;right:30px;width:50px;height:50px;background:var(--primary-blue);color:var(--bg-white);border:none;border-radius:50%;cursor:pointer;box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transition:var(--transition);z-index:999}
.scroll-top.visible{opacity:1;visibility:visible}
.scroll-top:hover,.scroll-top:focus{background:var(--secondary-blue);transform:translateY(-5px)}
.scroll-top span{font-size:1.2rem}
@media(max-width:992px){.hero-title{font-size:2.5rem}
.section-title{font-size:2rem}
.company-content{grid-template-columns:1fr}
.service-grid{grid-template-columns:repeat(2,1fr)}
.nav-menu{position:fixed;top:80px;left:0;right:0;background:var(--bg-white);flex-direction:column;gap:0;padding:0;max-height:0;overflow:hidden;transition:max-height 0.3s ease;box-shadow:var(--shadow)}
.nav-menu.active{max-height:400px;border-top:2px solid var(--border-color)}
.nav-menu li{border-bottom:1px solid var(--border-color)}
.nav-menu li:last-child{border-bottom:none}
.nav-menu a{padding:15px 20px}
.nav-toggle{display:flex}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(7px,7px)}
.nav-toggle.active span:nth-child(2){opacity:0}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}}
@media(max-width:768px){.hero{padding:80px 0}
.hero-content{padding:40px 25px}
.hero-title{font-size:2.5rem}
.hero-subtitle{font-size:1.2rem}
.section{padding:50px 0}
.service-grid{grid-template-columns:1fr;gap:20px}
.contact-grid{grid-template-columns:1fr}
.footer-content{flex-direction:column;gap:30px}
.footer-nav ul{flex-direction:column;gap:15px}
.company-name{font-size:1.1rem}
.info-table th,.info-table td{padding:12px 15px;font-size:0.95rem}
.info-table th{width:40%}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}}
@media print{.nav,.hero,.footer,.scroll-top,.btn{display:none}
.section{page-break-inside:avoid}}