:root{
  --ink:#161a17;
  --ink-soft:#42463f;
  --paper:#f6f3ec;
  --paper-deep:#ece7d8;
  --line:#cdc7b4;
  --accent:#1f5e3a;
  --accent-hot:#2b7a4a;
  --signal:#d94f1e;
  --radius:2px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic","Noto Sans JP",sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.75;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-weight:700;letter-spacing:.01em;line-height:1.3}
h2{font-size:28px;margin-bottom:18px;border-left:4px solid var(--accent);padding-left:14px}
.muted{color:var(--ink-soft);margin-bottom:28px}

.top-bar{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;gap:20px}
.brand img{height:42px;width:auto}
.main-nav{display:flex;gap:22px;flex-wrap:wrap}
.main-nav a{font-size:14px;color:var(--ink-soft);padding:6px 0;border-bottom:2px solid transparent;transition:.2s}
.main-nav a:hover{color:var(--accent);border-color:var(--accent)}

.hero-block{padding:70px 0 90px;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.kicker{font-size:12px;letter-spacing:.3em;color:var(--signal);text-transform:uppercase;margin-bottom:20px}
.hero-copy h1{font-size:46px;margin-bottom:24px;line-height:1.2}
.lead{font-size:17px;color:var(--ink-soft);margin-bottom:30px;max-width:540px}
.cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:22px}
.btn-filled{
  display:inline-block;background:var(--accent);color:#fff;
  padding:14px 28px;font-weight:600;font-size:15px;
  border:2px solid var(--accent);border-radius:var(--radius);
  cursor:pointer;transition:.2s;
}
.btn-filled:hover{background:var(--accent-hot);border-color:var(--accent-hot)}
.btn-ghost{
  display:inline-block;padding:14px 22px;font-weight:600;font-size:15px;
  border:2px solid var(--ink);color:var(--ink);border-radius:var(--radius);transition:.2s;
}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}
.tiny{font-size:13px;color:var(--ink-soft)}
.hero-img img{width:100%;height:420px;object-fit:cover;border-radius:var(--radius);filter:saturate(.9)}

.story-block{padding:80px 0;background:var(--paper-deep)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.story-text p{margin-bottom:18px;color:var(--ink-soft)}
.story-imgs{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.story-imgs img{height:280px;object-fit:cover;border-radius:var(--radius)}
.story-imgs img:nth-child(2){margin-top:40px}

.price-block{padding:80px 0}
.price-list{border-top:1px solid var(--line)}
.price-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:22px 4px;border-bottom:1px solid var(--line);gap:20px;
  transition:.2s;
}
.price-row:hover{background:var(--paper-deep);padding-left:16px}
.p-name strong{display:block;font-size:17px;margin-bottom:4px}
.p-name span{font-size:13px;color:var(--ink-soft)}
.p-price{font-size:20px;font-weight:700;color:var(--accent);white-space:nowrap}

.people-block{padding:80px 0;background:var(--paper-deep)}
.people-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.person{display:flex;gap:22px;padding:24px;background:var(--paper);border-left:4px solid var(--accent)}
.person img{width:110px;height:110px;object-fit:cover;flex-shrink:0;border-radius:var(--radius)}
.person h3{font-size:19px;margin-bottom:4px}
.role{font-size:13px;color:var(--signal);margin-bottom:10px;font-weight:600}
.person-body p:last-child{font-size:14px;color:var(--ink-soft)}

.rules-block{
  padding:100px 0;
  background:linear-gradient(rgba(22,26,23,.82),rgba(22,26,23,.88)),
    url('../assets-main/cleaning-tools-mop-bucket.webp') center/cover no-repeat;
  color:#f4efe2;
}
.rules-block h2{color:#f4efe2;border-color:var(--signal)}
.rules-list{display:grid;grid-template-columns:1fr 1fr;gap:20px 40px;margin-top:30px}
.rule{display:flex;gap:18px;padding:18px 0;border-bottom:1px solid rgba(244,239,226,.2)}
.rule span{font-size:26px;font-weight:700;color:var(--signal);min-width:40px}
.rule p{font-size:15px}

.voice-block{padding:80px 0}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.voice{padding:24px;background:var(--paper-deep);border-top:3px solid var(--accent)}
.voice p{font-size:15px;margin-bottom:14px;color:var(--ink)}
.voice span{font-size:13px;color:var(--ink-soft);font-weight:600}
.voice:nth-child(4),.voice:nth-child(5){grid-column:span 1}

.faq-block{padding:80px 0;background:var(--paper-deep)}
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.faq{padding:22px;background:var(--paper);border-left:3px solid var(--signal)}
.faq h4{font-size:16px;margin-bottom:10px;color:var(--accent)}
.faq p{font-size:14px;color:var(--ink-soft)}

.contact-block{padding:90px 0;border-top:4px solid var(--ink)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px}
.contact-info p{color:var(--ink-soft);margin-bottom:26px}
.info-list{list-style:none}
.info-list li{padding:14px 0;border-bottom:1px dashed var(--line);font-size:15px}
.info-list strong{display:block;font-size:12px;color:var(--signal);letter-spacing:.15em;margin-bottom:4px}
.contact-form{display:flex;flex-direction:column;gap:16px}
.contact-form label{display:flex;flex-direction:column;font-size:13px;color:var(--ink-soft);font-weight:600}
.contact-form input,.contact-form textarea{
  margin-top:6px;padding:12px 14px;border:1px solid var(--line);
  background:var(--paper);font-family:inherit;font-size:15px;
  border-radius:var(--radius);transition:.2s;
}
.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent)}
.contact-form button{align-self:flex-start;margin-top:6px}

.site-foot{background:var(--ink);color:#cdc7b4;padding:40px 0}
.foot-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-brand img{height:38px;}
.foot-links{display:flex;gap:22px;flex-wrap:wrap}
.foot-links a{font-size:13px;transition:.2s}
.foot-links a:hover{color:var(--signal)}
.foot-copy{font-size:13px;width:100%;text-align:center;padding-top:20px;margin-top:20px;border-top:1px solid #2a2e2b}

@media(max-width:900px){
  .hero-grid,.story-grid,.people-grid,.contact-grid,.rules-list{grid-template-columns:1fr;gap:30px}
  .hero-copy h1{font-size:34px}
  .voice-grid,.faq-grid{grid-template-columns:1fr 1fr}
  .story-imgs img:nth-child(2){margin-top:0}
  .main-nav{display:none}
  .hero-img img{height:300px}
}
@media(max-width:600px){
  .voice-grid,.faq-grid{grid-template-columns:1fr}
  .price-row{flex-direction:column;align-items:flex-start;gap:8px}
  .person{flex-direction:column}
  .person img{width:100%;height:200px}
  .hero-copy h1{font-size:28px}
  h2{font-size:23px}
  .foot-inner{flex-direction:column;text-align:center}
}

.page-head{padding:60px 0 40px;background:var(--paper-deep);border-bottom:1px solid var(--line)}
.crumbs{font-size:13px;color:var(--ink-soft);margin-bottom:14px}
.crumbs a{color:var(--signal)}
.page-head h1{font-size:38px;margin-bottom:10px}
.page-lead{color:var(--ink-soft);max-width:640px}
.page-body{padding:70px 0 90px}
.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:60px}
.col-main h2{font-size:23px;margin:30px 0 14px}
.col-main h2:first-child{margin-top:0}
.col-main p{margin-bottom:16px;color:var(--ink-soft)}
.col-main h3{font-size:17px;margin:22px 0 8px;color:var(--accent)}
.col-main ul{padding-left:20px;margin-bottom:18px;color:var(--ink-soft)}
.col-main ul li{margin-bottom:6px}
.col-side{background:var(--paper-deep);padding:28px;border-top:3px solid var(--accent);align-self:start}
.col-side h3{font-size:16px;margin-bottom:16px;color:var(--signal);letter-spacing:.1em}
.data-list dt{font-size:11px;color:var(--signal);font-weight:700;letter-spacing:.15em;margin-top:12px}
.data-list dt:first-child{margin-top:0}
.data-list dd{font-size:14px;padding:4px 0 10px;border-bottom:1px dashed var(--line)}
.timeline{margin:10px 0 20px}
.tl-row{display:flex;gap:20px;padding:14px 0;border-bottom:1px solid var(--line)}
.tl-row span{font-weight:700;color:var(--accent);min-width:80px;font-size:14px}
.tl-row p{margin:0;font-size:14px}
.job-card{background:var(--paper-deep);padding:26px;margin-bottom:20px;border-left:4px solid var(--accent)}
.job-card h3{font-size:19px;color:var(--ink);margin-bottom:6px}
.job-tag{display:inline-block;background:var(--signal);color:#fff;font-size:11px;padding:3px 10px;margin-bottom:12px;font-weight:700;letter-spacing:.1em}
.job-card dl{display:grid;grid-template-columns:110px 1fr;gap:8px 16px;font-size:14px;margin-top:14px}
.job-card dt{font-weight:700;color:var(--ink)}
.job-card dd{color:var(--ink-soft)}
@media(max-width:900px){.two-col{grid-template-columns:1fr;gap:40px}.page-head h1{font-size:28px}}
