@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&family=Noto+Serif+JP:wght@400;500;700&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#FAFAF5;
  --text:#1A1A2E;
  --accent:#E8793A;
  --accent-light:#FDEBD4;
  --border:#E0E0D8;
  --white:#FFFFFF;
  --shadow:0 2px 8px rgba(26,26,46,0.06);
  --shadow-hover:0 4px 16px rgba(26,26,46,0.10);
  --radius:6px;
  --font-heading:'Noto Serif JP',serif;
  --font-body:'Noto Sans JP',sans-serif;
  --transition:0.3s ease;
}

html{scroll-behavior:smooth;font-size:16px}

body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--text);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}

.container{max-width:1120px;margin:0 auto;padding:0 24px}

.site-header{
  background:var(--white);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:100;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 24px;
  max-width:1120px;
  margin:0 auto;
}

.site-logo{
  font-family:var(--font-heading);
  font-size:1.25rem;
  font-weight:700;
  color:var(--text);
  white-space:nowrap;
}

.site-logo span{color:var(--accent)}

.nav-center{display:flex;align-items:center;gap:28px}

.nav-center a{
  font-size:0.9rem;
  font-weight:500;
  position:relative;
  padding:4px 0;
}

.nav-center a::after{
  content:'';
  position:absolute;
  bottom:0;left:0;
  width:0;height:2px;
  background:var(--accent);
  transition:width var(--transition);
}

.nav-center a:hover::after{width:100%}

.nav-dropdown{position:relative}

.nav-dropdown-menu{
  display:none;
  position:absolute;
  top:100%;
  left:50%;
  transform:translateX(-50%);
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow-hover);
  min-width:280px;
  padding:12px 0;
  z-index:200;
}

.nav-dropdown:hover .nav-dropdown-menu{display:block}

.nav-dropdown-menu a{
  display:block;
  padding:10px 20px;
  font-size:0.85rem;
  font-weight:400;
  white-space:nowrap;
}

.nav-dropdown-menu a::after{display:none}

.nav-dropdown-menu a:hover{background:var(--bg);color:var(--accent)}

.nav-cta{
  background:var(--accent);
  color:var(--white) !important;
  padding:8px 20px !important;
  border-radius:var(--radius);
  font-size:0.85rem !important;
  font-weight:500 !important;
  transition:background var(--transition),transform var(--transition);
}

.nav-cta:hover{background:#D46A2E;transform:translateY(-1px)}
.nav-cta::after{display:none !important}

.hamburger{
  display:none;
  background:none;
  border:none;
  cursor:pointer;
  padding:4px;
}

.hamburger svg{width:28px;height:28px;stroke:var(--text)}

.mobile-nav{
  display:none;
  position:fixed;
  top:0;left:0;
  width:100%;height:100%;
  background:var(--white);
  z-index:300;
  flex-direction:column;
  padding:60px 24px 24px;
  overflow-y:auto;
}

.mobile-nav.active{display:flex}

.mobile-nav-close{
  position:absolute;
  top:16px;right:16px;
  background:none;
  border:none;
  cursor:pointer;
}

.mobile-nav-close svg{width:28px;height:28px;stroke:var(--text)}

.mobile-nav a{
  display:block;
  padding:16px 0;
  font-size:1.1rem;
  font-weight:500;
  border-bottom:1px solid var(--border);
}

.mobile-nav .mobile-sub{padding-left:16px;font-size:0.95rem;font-weight:400}

.hero{
  position:relative;
  min-height:520px;
  display:grid;
  grid-template-columns:1fr 1fr;
  overflow:hidden;
}

.hero-text{
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:60px 48px;
  background:var(--bg);
  position:relative;
  z-index:2;
}

.hero-text h1{
  font-family:var(--font-heading);
  font-size:2.5rem;
  font-weight:700;
  line-height:1.4;
  margin-bottom:20px;
}

.hero-text h1 span{color:var(--accent)}

.hero-text p{
  font-size:1.05rem;
  line-height:1.9;
  color:#444;
  margin-bottom:32px;
  max-width:460px;
}

.hero-image{
  position:relative;
  background:#2A2A3E;
  overflow:hidden;
}

.hero-image img{
  width:100%;height:100%;
  object-fit:cover;
  opacity:0.7;
}

.hero-image::after{
  content:'';
  position:absolute;
  top:0;left:0;
  width:60px;height:100%;
  background:linear-gradient(to right,var(--bg),transparent);
  z-index:1;
}

.btn-primary{
  display:inline-block;
  background:var(--accent);
  color:var(--white);
  padding:14px 32px;
  border-radius:var(--radius);
  font-weight:500;
  font-size:0.95rem;
  transition:background var(--transition),transform var(--transition);
  border:none;
  cursor:pointer;
  text-align:center;
}

.btn-primary:hover{background:#D46A2E;color:var(--white);transform:translateY(-2px)}

.btn-secondary{
  display:inline-block;
  border:1.5px solid var(--accent);
  color:var(--accent);
  padding:12px 28px;
  border-radius:var(--radius);
  font-weight:500;
  font-size:0.95rem;
  transition:all var(--transition);
}

.btn-secondary:hover{background:var(--accent);color:var(--white)}

.section{padding:80px 0}

.section-title{
  font-family:var(--font-heading);
  font-size:2rem;
  font-weight:700;
  text-align:center;
  margin-bottom:12px;
}

.section-subtitle{
  text-align:center;
  color:#666;
  font-size:0.95rem;
  margin-bottom:48px;
}

.editorial-about{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}

.editorial-about-img{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.editorial-about-img img{width:100%;height:360px;object-fit:cover}

.editorial-about-text h2{
  font-family:var(--font-heading);
  font-size:1.75rem;
  margin-bottom:16px;
}

.editorial-about-text p{
  color:#444;
  margin-bottom:16px;
  line-height:1.9;
}

.article-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px;
}

.article-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  transition:box-shadow var(--transition),transform var(--transition);
}

.article-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}

.article-card-img{
  width:100%;
  height:200px;
  object-fit:cover;
}

.article-card-body{padding:20px 24px 24px}

.article-card-date{
  font-size:0.8rem;
  color:#888;
  margin-bottom:8px;
}

.article-card-body h3{
  font-family:var(--font-heading);
  font-size:1.1rem;
  font-weight:700;
  margin-bottom:10px;
  line-height:1.5;
}

.article-card-body p{
  font-size:0.9rem;
  color:#555;
  line-height:1.7;
  margin-bottom:14px;
}

.article-card-link{
  font-size:0.85rem;
  color:var(--accent);
  font-weight:500;
}

.article-card-link:hover{color:#D46A2E}

.mission-section{
  background:var(--white);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}

.mission-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
}

.mission-grid.reverse{direction:rtl}
.mission-grid.reverse > *{direction:ltr}

.mission-text h2{
  font-family:var(--font-heading);
  font-size:1.75rem;
  margin-bottom:16px;
}

.mission-text p{
  color:#444;
  line-height:1.9;
  margin-bottom:12px;
}

.mission-img{
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.mission-img img{width:100%;height:300px;object-fit:cover}

.faq-section{background:var(--bg)}

.faq-list{max-width:720px;margin:0 auto}

.faq-item{
  border:1px solid var(--border);
  border-radius:var(--radius);
  margin-bottom:12px;
  background:var(--white);
  overflow:hidden;
}

.faq-question{
  width:100%;
  background:none;
  border:none;
  padding:18px 24px;
  font-family:var(--font-heading);
  font-size:1rem;
  font-weight:500;
  text-align:left;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  color:var(--text);
}

.faq-question .material-icons{color:var(--accent);transition:transform var(--transition)}

.faq-item.open .faq-question .material-icons{transform:rotate(180deg)}

.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height 0.4s ease;
}

.faq-answer-inner{
  padding:0 24px 18px;
  font-size:0.92rem;
  color:#555;
  line-height:1.8;
}

.advantages-section{background:var(--white)}

.advantages-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}

.advantage-card{
  text-align:center;
  padding:36px 24px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg);
  transition:box-shadow var(--transition);
}

.advantage-card:hover{box-shadow:var(--shadow-hover)}

.advantage-icon{
  width:56px;height:56px;
  margin:0 auto 16px;
  background:var(--accent-light);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
}

.advantage-icon .material-icons{font-size:28px;color:var(--accent)}

.advantage-card h3{
  font-family:var(--font-heading);
  font-size:1.05rem;
  margin-bottom:10px;
}

.advantage-card p{font-size:0.88rem;color:#555;line-height:1.7}

.closing-cta{
  background:var(--text);
  color:var(--white);
  text-align:center;
  padding:64px 24px;
}

.closing-cta h2{
  font-family:var(--font-heading);
  font-size:1.75rem;
  margin-bottom:12px;
}

.closing-cta p{color:rgba(255,255,255,0.7);margin-bottom:28px;font-size:0.95rem}

.closing-cta .btn-primary{background:var(--accent)}
.closing-cta .btn-primary:hover{background:#D46A2E}

.site-footer{
  background:#1A1A2E;
  color:rgba(255,255,255,0.75);
  padding:56px 0 0;
}

.footer-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:40px;
  margin-bottom:40px;
}

.footer-col h4{
  color:var(--white);
  font-family:var(--font-heading);
  font-size:1rem;
  margin-bottom:16px;
}

.footer-col p,.footer-col a{
  font-size:0.88rem;
  line-height:1.8;
  color:rgba(255,255,255,0.65);
}

.footer-col a:hover{color:var(--accent)}

.footer-col .material-icons{
  font-size:18px;
  vertical-align:middle;
  margin-right:6px;
  color:var(--accent);
}

.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.1);
  padding:20px 0;
  text-align:center;
  font-size:0.82rem;
  color:rgba(255,255,255,0.45);
}

.cookie-modal{
  position:fixed;
  bottom:24px;right:24px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 8px 32px rgba(0,0,0,0.15);
  padding:24px;
  max-width:380px;
  z-index:400;
  display:none;
}

.cookie-modal.show{display:block}

.cookie-modal h3{
  font-family:var(--font-heading);
  font-size:1rem;
  margin-bottom:8px;
}

.cookie-modal p{font-size:0.85rem;color:#555;margin-bottom:16px;line-height:1.6}

.cookie-modal p a{color:var(--accent)}

.cookie-buttons{display:flex;gap:10px}

.cookie-buttons button{
  flex:1;
  padding:10px 16px;
  border-radius:var(--radius);
  font-size:0.85rem;
  font-weight:500;
  cursor:pointer;
  transition:all var(--transition);
  border:none;
}

.cookie-accept{background:var(--accent);color:var(--white)}
.cookie-accept:hover{background:#D46A2E}
.cookie-reject{background:var(--bg);color:var(--text);border:1px solid var(--border)}
.cookie-reject:hover{background:#EEEDE8}

.page-header{
  background:var(--white);
  border-bottom:1px solid var(--border);
  padding:48px 0 40px;
  text-align:center;
}

.page-header h1{
  font-family:var(--font-heading);
  font-size:2rem;
  margin-bottom:8px;
}

.page-header p{color:#666;font-size:0.95rem}

.contact-section{padding:64px 0}

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:48px;
  align-items:start;
}

.contact-info-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:24px;
}

.contact-info-item .material-icons{
  color:var(--accent);
  font-size:22px;
  margin-top:2px;
}

.contact-info-item p{font-size:0.92rem;line-height:1.7}

.contact-form-card{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:32px;
  box-shadow:var(--shadow);
}

.form-group{margin-bottom:20px}

.form-group label{
  display:block;
  font-size:0.88rem;
  font-weight:500;
  margin-bottom:6px;
}

.form-group input,.form-group textarea{
  width:100%;
  padding:12px 16px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  font-family:var(--font-body);
  font-size:0.92rem;
  transition:border-color var(--transition);
  background:var(--bg);
}

.form-group input:focus,.form-group textarea:focus{
  outline:none;
  border-color:var(--accent);
}

.form-group textarea{resize:vertical;min-height:120px}

.map-section{padding:0 0 80px}

.map-section iframe{width:100%;height:400px;border:0;border-radius:var(--radius);display:block}

.map-link{
  display:inline-block;
  margin-top:12px;
  font-size:0.88rem;
  color:var(--accent);
  font-weight:500;
}

.article-header{
  padding:48px 0 32px;
  background:var(--white);
  border-bottom:1px solid var(--border);
}

.article-header-inner{max-width:760px;margin:0 auto;padding:0 24px}

.article-header .date{
  font-size:0.82rem;
  color:#888;
  margin-bottom:8px;
}

.article-header h1{
  font-family:var(--font-heading);
  font-size:1.85rem;
  line-height:1.5;
  margin-bottom:16px;
}

.article-header .lead{font-size:0.95rem;color:#555;line-height:1.8}

.article-body{
  max-width:760px;
  margin:0 auto;
  padding:40px 24px 60px;
}

.article-body h2{
  font-family:var(--font-heading);
  font-size:1.4rem;
  margin:40px 0 16px;
  padding-bottom:8px;
  border-bottom:2px solid var(--accent);
}

.article-body h3{
  font-family:var(--font-heading);
  font-size:1.15rem;
  margin:28px 0 12px;
}

.article-body p{
  margin-bottom:16px;
  line-height:1.9;
  color:#333;
}

.article-body .article-img{
  margin:28px 0;
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}

.article-body .article-img img{width:100%;height:auto}

.article-nav{
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:28px 0;
}

.article-nav-inner{
  max-width:760px;
  margin:0 auto;
  padding:0 24px;
  display:flex;
  justify-content:space-between;
  gap:24px;
}

.article-nav a{
  font-size:0.9rem;
  color:var(--accent);
  font-weight:500;
  max-width:45%;
}

.article-nav a:hover{color:#D46A2E}

.list-article-item{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:24px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  margin-bottom:20px;
  box-shadow:var(--shadow);
  transition:box-shadow var(--transition),transform var(--transition);
}

.list-article-item:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}

.list-article-item img{width:100%;height:100%;object-fit:cover;min-height:180px}

.list-article-body{padding:24px 24px 24px 0}

.list-article-body .date{font-size:0.8rem;color:#888;margin-bottom:6px}

.list-article-body h3{
  font-family:var(--font-heading);
  font-size:1.15rem;
  margin-bottom:10px;
  line-height:1.5;
}

.list-article-body p{font-size:0.9rem;color:#555;line-height:1.7;margin-bottom:12px}

.list-article-body a{color:var(--accent);font-size:0.85rem;font-weight:500}

.policy-content{max-width:760px;margin:0 auto;padding:40px 24px 80px}

.policy-content h2{
  font-family:var(--font-heading);
  font-size:1.35rem;
  margin:36px 0 14px;
  padding-bottom:6px;
  border-bottom:2px solid var(--accent);
}

.policy-content h3{
  font-family:var(--font-heading);
  font-size:1.1rem;
  margin:24px 0 10px;
}

.policy-content p{margin-bottom:14px;line-height:1.9;color:#444}

.policy-content ul{margin:12px 0 14px 20px}

.policy-content ul li{
  list-style:disc;
  margin-bottom:6px;
  font-size:0.92rem;
  color:#444;
  line-height:1.7;
}

.fade-in{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}

.form-modal-overlay{
  display:none;
  position:fixed;
  top:0;left:0;
  width:100%;height:100%;
  background:rgba(26,26,46,0.5);
  z-index:500;
  align-items:center;
  justify-content:center;
}

.form-modal-overlay.show{display:flex}

.form-modal{
  background:var(--white);
  border-radius:var(--radius);
  padding:40px;
  max-width:420px;
  text-align:center;
  box-shadow:0 16px 48px rgba(0,0,0,0.2);
}

.form-modal .material-icons{font-size:48px;color:var(--accent);margin-bottom:16px}

.form-modal h3{
  font-family:var(--font-heading);
  font-size:1.2rem;
  margin-bottom:10px;
}

.form-modal p{font-size:0.9rem;color:#555;margin-bottom:20px}

@media(max-width:768px){
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-text{padding:40px 24px}
  .hero-text h1{font-size:1.75rem}
  .hero-image{height:240px}
  .hero-image::after{display:none}
  .nav-center,.nav-cta-btn{display:none !important}
  .hamburger{display:block}
  .editorial-about{grid-template-columns:1fr}
  .article-grid{grid-template-columns:1fr}
  .mission-grid{grid-template-columns:1fr}
  .mission-grid.reverse{direction:ltr}
  .advantages-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .article-nav-inner{flex-direction:column}
  .list-article-item{grid-template-columns:1fr}
  .list-article-item img{height:200px}
  .cookie-modal{left:16px;right:16px;bottom:16px;max-width:none}
}
