/* CSS Reset & Base Styles */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Hiragino Kaku Gothic ProN',Meiryo,'Noto Sans JP',sans-serif;line-height:1.6;color:#333;background:#fff}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:color .3s ease}
ul,ol{list-style:none}
table{border-collapse:collapse;width:100%}

/* Color Variables */
:root{
--primary-green:#2d8659;
--light-green:#4da373;
--dark-green:#1e5f3f;
--accent-green:#7db894;
--bg-light:#f8fdf9;
--text-dark:#2c3e2d;
--border-light:#e1f0e5;
--white:#ffffff;
--shadow:0 4px 12px rgba(45,134,89,0.1)
}

/* Typography */
.section-title{font-size:2.5rem;font-weight:700;color:var(--primary-green);text-align:center;margin-bottom:3rem;position:relative}
.section-title::after{content:'';position:absolute;bottom:-10px;left:50%;transform:translateX(-50%);width:60px;height:3px;background:linear-gradient(90deg,var(--primary-green),var(--accent-green))}

/* Header & Navigation */
.header{position:fixed;top:0;width:100%;background:rgba(255,255,255,0.95);backdrop-filter:blur(10px);z-index:1000;box-shadow:var(--shadow)}
.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center;height:70px}
.logo{font-size:1.8rem;font-weight:700;color:var(--primary-green);letter-spacing:1px}
.nav-menu{display:flex;gap:2rem}
.nav-menu a{font-weight:500;padding:0.5rem 1rem;border-radius:25px;transition:all .3s ease}
.nav-menu a:hover{background:var(--bg-light);color:var(--primary-green)}
.hamburger{display:none;flex-direction:column;cursor:pointer}
.hamburger span{width:25px;height:3px;background:var(--primary-green);margin:3px 0;transition:.3s}

/* Hero Section */
.hero{background:linear-gradient(135deg,var(--bg-light) 0%,rgba(125,184,148,0.1) 100%);padding:120px 0 80px;min-height:100vh;display:flex;align-items:center}
.hero-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-title{font-size:2.5rem;font-weight:700;color:var(--text-dark);margin-bottom:1.5rem;line-height:1.3}
.hero-description{font-size:1.2rem;color:#666;margin-bottom:2rem;line-height:1.7}
.cta-button{display:inline-block;background:linear-gradient(135deg,var(--primary-green),var(--light-green));color:var(--white);padding:1rem 2.5rem;border-radius:50px;font-weight:600;font-size:1.1rem;box-shadow:var(--shadow);transition:all .3s ease;border:none}
.cta-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px rgba(45,134,89,0.3)}
.store-image{border-radius:15px;box-shadow:var(--shadow)}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeInUp 0.8s ease-out}

/* Container */
.container{max-width:1200px;margin:0 auto;padding:0 2rem}

/* Services Section */
.services{padding:80px 0;background:var(--white)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}
.service-card{background:var(--bg-light);padding:2rem;border-radius:15px;text-align:center;transition:all .3s ease;border:2px solid transparent}
.service-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--accent-green)}
.service-icon{width:80px;height:80px;margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;background:var(--white);border-radius:50%;box-shadow:0 4px 15px rgba(45,134,89,0.1)}
.service-icon img{width:50px;height:50px;object-fit:contain;filter:brightness(1.1) contrast(1.1)}
.service-card h3{font-size:1.3rem;color:var(--primary-green);margin-bottom:1rem;font-weight:600}
.service-card p{color:#666;line-height:1.6}

/* Company Section */
.company{padding:80px 0;background:var(--bg-light)}
.company-table{background:var(--white);border-radius:10px;overflow:hidden;box-shadow:var(--shadow)}
.company-table th,.company-table td{padding:1.2rem;text-align:left;border-bottom:1px solid var(--border-light)}
.company-table th{background:var(--primary-green);color:var(--white);font-weight:600;width:30%}
.company-table tr:last-child th,.company-table tr:last-child td{border-bottom:none}

/* Store Section */
.store{padding:80px 0;background:var(--white)}
.store-card{background:var(--bg-light);padding:3rem;border-radius:20px;box-shadow:var(--shadow)}
.store-name{font-size:2rem;color:var(--primary-green);margin-bottom:2rem;text-align:center;font-weight:700}
.store-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:2rem}
.store-basic p{margin-bottom:0.5rem;font-size:1.1rem}
.store-phone,.store-email{color:var(--primary-green);font-weight:600}
.store-hours h4{color:var(--primary-green);margin-bottom:1rem;font-size:1.2rem;font-weight:600}
.store-hours li{padding:0.3rem 0;border-bottom:1px solid var(--border-light)}
.store-hours li:last-child{border-bottom:none}
.store-description{grid-column:1/-1;margin-top:2rem}
.store-description p{margin-bottom:1rem;line-height:1.7;color:#555}
.store-gallery{grid-column:1/-1;margin-top:3rem}
.store-gallery h4{color:var(--primary-green);margin-bottom:1.5rem;font-size:1.3rem;font-weight:600;text-align:center}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.gallery-item{position:relative;overflow:hidden;border-radius:15px;box-shadow:var(--shadow);background:var(--white)}
.gallery-item img{width:100%;height:250px;object-fit:cover;display:block}
.store-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin:3rem 0}
.detail-section{background:var(--white);padding:1.5rem;border-radius:10px;border-left:4px solid var(--primary-green)}
.detail-section.full-width{grid-column:1/-1}
.detail-section h4{color:var(--primary-green);margin-bottom:1rem;font-weight:600}
.detail-section p,.detail-section ul{line-height:1.6;color:#555}
.detail-section li{padding:0.2rem 0;padding-left:1rem;position:relative}
.detail-section li::before{content:'•';color:var(--primary-green);position:absolute;left:0}
.legal-info{background:var(--white);padding:2rem;border-radius:15px;margin-top:3rem;border:2px solid var(--primary-green)}
.legal-info h4{color:var(--primary-green);margin-bottom:1.5rem;font-size:1.3rem;font-weight:600}
.legal-table table{margin-bottom:2rem}
.legal-table th,.legal-table td{padding:1rem;border:1px solid var(--border-light);text-align:left}
.legal-table th{background:var(--bg-light);color:var(--primary-green);font-weight:600;width:35%}
.pdf-button{background:var(--primary-green);color:var(--white);padding:1rem 2rem;border-radius:30px;font-weight:600;display:inline-block;transition:all .3s ease;box-shadow:var(--shadow)}
.pdf-button:hover{background:var(--dark-green);transform:translateY(-2px)}

/* News Section */
.news{padding:80px 0;background:var(--bg-light)}
.news-item{background:var(--white);padding:2rem;border-radius:10px;margin-bottom:1.5rem;box-shadow:var(--shadow);transition:all .3s ease}
.news-item:hover{transform:translateY(-3px)}
.news-date{color:var(--primary-green);font-weight:600;font-size:0.9rem;margin-bottom:0.5rem}
.news-title{font-size:1.2rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}
.news-content{color:#666;line-height:1.6}

/* Recruitment Section */
.recruitment{padding:80px 0;background:var(--white)}
.recruitment-content{text-align:center;max-width:600px;margin:0 auto}
.recruitment-content p{font-size:1.1rem;margin-bottom:1.5rem;color:#666;line-height:1.7}

/* Contact Section */
.contact{padding:80px 0;background:var(--bg-light)}
.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.contact-item{background:var(--white);padding:2rem;border-radius:15px;box-shadow:var(--shadow)}
.contact-item h3{color:var(--primary-green);margin-bottom:1rem;font-size:1.5rem;font-weight:600}
.contact-item p{margin-bottom:0.5rem;line-height:1.6}
.contact-item a{color:var(--primary-green);font-weight:600}
.contact-item a:hover{color:var(--dark-green)}
.contact-hours{background:var(--white);padding:2rem;border-radius:15px;box-shadow:var(--shadow)}
.contact-hours h4{color:var(--primary-green);margin-bottom:1rem;font-size:1.2rem;font-weight:600}
.contact-hours p{margin-bottom:0.5rem;line-height:1.6}

/* Footer */
.footer{background:var(--text-dark);color:var(--white);padding:3rem 0 1rem}
.footer-content{display:grid;grid-template-columns:1fr 1fr;gap:3rem;margin-bottom:2rem}
.footer-info h3{color:var(--accent-green);margin-bottom:1rem;font-size:1.3rem}
.footer-info p{margin-bottom:0.5rem;opacity:0.9}
.footer-nav ul{display:flex;flex-wrap:wrap;gap:1.5rem}
.footer-nav a{opacity:0.9;transition:opacity .3s ease}
.footer-nav a:hover{opacity:1;color:var(--accent-green)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.2);padding-top:1.5rem;text-align:center;opacity:0.8}

/* Responsive Design */
@media (max-width:768px){
.nav-menu{display:none;position:absolute;top:100%;left:0;width:100%;background:var(--white);flex-direction:column;padding:1rem;box-shadow:var(--shadow)}
.nav-menu.active{display:flex}
.hamburger{display:flex}
.hamburger.active span:nth-child(1){transform:rotate(-45deg) translate(-5px,6px)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:rotate(45deg) translate(-5px,-6px)}
.hero-container{grid-template-columns:1fr;text-align:center}
.hero-title{font-size:2.2rem}
.section-title{font-size:2rem}
.services-grid{grid-template-columns:1fr}
.store-content{grid-template-columns:1fr}
.store-details{grid-template-columns:1fr}
.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
.contact-content{grid-template-columns:1fr}
.footer-content{grid-template-columns:1fr;text-align:center}
.footer-nav ul{justify-content:center}
.legal-table th{width:40%}
.legal-table th,.legal-table td{padding:0.8rem;font-size:0.9rem}
.container{padding:0 1rem}
.nav-container{padding:0 1rem}
}

@media (max-width:480px){
.hero-title{font-size:1.8rem}
.section-title{font-size:1.7rem}
.hero-description{font-size:1rem}
.service-card,.contact-item,.contact-hours{padding:1.5rem}
.store-card{padding:2rem}
.gallery-grid{grid-template-columns:1fr;gap:1rem}
.gallery-item img{height:200px}
.legal-table th,.legal-table td{padding:0.6rem;font-size:0.85rem}
.legal-table th{width:45%}
}

/* Image Error Handling */
img{background:var(--bg-light);border:1px solid var(--border-light);opacity:1 !important}
img[src*="ICON"]{background:linear-gradient(135deg,var(--bg-light),rgba(125,184,148,0.1))}

/* Accessibility */
@media (prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important}
}

/* Focus styles for accessibility */
a:focus,button:focus,.cta-button:focus,.pdf-button:focus{outline:2px solid var(--primary-green);outline-offset:2px}

/* High contrast mode support */
@media (prefers-contrast:high){
:root{--primary-green:#1a5c3a;--light-green:#2d7050;--text-dark:#000000;--border-light:#666666}
}