/* ==========================================================
   DPEWTH TRUCK SERVICE — demo site
   Green / flat / stylish corporate design
   ========================================================== */

:root{
  --green-900:#173d2a;
  --green-700:#1f7a4c;
  --green-600:#2b8f5c;
  --green-500:#3aa96e;
  --green-100:#e7f4ec;
  --ink:#1c2420;
  --ink-soft:#4a544e;
  --paper:#ffffff;
  --paper-soft:#f5f8f6;
  --line:#dce6e0;
  --shadow: 0 12px 30px rgba(23,61,42,.10);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  font-family:"Hiragino Sans","Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo",sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}
h1,h2,h3,p{margin:0;}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px;}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;
  height:76px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:19px;color:var(--green-900);}
.brand svg{width:34px;height:34px;flex:none;}
.brand small{display:block;font-weight:500;font-size:11px;letter-spacing:.14em;color:var(--green-600);}
.main-nav ul{display:flex;gap:36px;}
.main-nav a{
  font-size:14px;font-weight:600;color:var(--ink-soft);
  position:relative;padding:4px 0;
}
.main-nav a.active,.main-nav a:hover{color:var(--green-700);}
.main-nav a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--green-600);
}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0;}

/* ---------- Hero ---------- */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(120deg,var(--green-900) 0%,var(--green-700) 55%,var(--green-500) 100%);
  color:#fff;
}
.hero .wrap{
  position:relative;z-index:2;
  padding:96px 24px 120px;
}
.hero-tag{
  display:inline-block;font-size:12px;letter-spacing:.2em;font-weight:700;
  background:rgba(255,255,255,.14);padding:6px 14px;border-radius:100px;margin-bottom:22px;
}
.hero h1{
  font-size:clamp(28px,4.2vw,46px);font-weight:800;line-height:1.5;margin-bottom:20px;
}
.hero h1 em{font-style:normal;color:#bdf0d2;}
.hero p{font-size:15px;max-width:560px;color:rgba(255,255,255,.86);margin-bottom:34px;}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 28px;border-radius:6px;font-weight:700;font-size:14px;
  border:2px solid transparent;transition:transform .15s ease, box-shadow .15s ease;
}
.btn-primary{background:#fff;color:var(--green-800,var(--green-700));}
.btn-primary{color:var(--green-700);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.btn-outline{border-color:rgba(255,255,255,.55);color:#fff;}
.btn-outline:hover{background:rgba(255,255,255,.12);}

.hero-truck{
  position:absolute;right:-4%;bottom:-6%;width:640px;max-width:52vw;opacity:.9;z-index:1;
}

.hero-stats{
  position:relative;z-index:2;
  background:var(--paper);
  margin:0 24px;border-radius:14px;
  box-shadow:var(--shadow);
  transform:translateY(-56px);
  display:grid;grid-template-columns:repeat(4,1fr);
}
.hero-stats li{
  padding:26px 18px;text-align:center;border-right:1px solid var(--line);
}
.hero-stats li:last-child{border-right:none;}
.hero-stats b{display:block;font-size:30px;color:var(--green-700);font-weight:800;}
.hero-stats span{font-size:12px;color:var(--ink-soft);letter-spacing:.03em;}

/* ---------- Section shell ---------- */
section{padding:64px 0;}
.section-head{text-align:center;max-width:640px;margin:0 auto 46px;}
.eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.2em;color:var(--green-600);text-transform:uppercase;
}
.section-head h2{font-size:clamp(22px,3vw,32px);font-weight:800;margin-top:10px;color:var(--green-900);}
.section-head p{margin-top:14px;color:var(--ink-soft);font-size:14px;}

/* diagonal banner used on inner pages */
.page-banner{
  position:relative;overflow:hidden;
  background:var(--green-700);color:#fff;padding:56px 0;
}
.page-banner::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(100deg,var(--green-900) 0 30%, transparent 30.5%),
             linear-gradient(100deg, transparent 0 68%, var(--green-500) 68.5% 100%);
  opacity:.55;
}
.page-banner .wrap{position:relative;z-index:1;}
.page-banner .eyebrow{color:#c9f2d9;}
.page-banner h1{font-size:clamp(26px,4vw,40px);font-weight:800;margin-top:8px;}
.crumb{margin-top:14px;font-size:13px;color:#d8f3e3;}
.crumb a{text-decoration:underline;}

/* ---------- Services ---------- */
.services-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.service-card{
  background:var(--paper-soft);border:1px solid var(--line);border-radius:14px;
  padding:34px 28px;transition:box-shadow .15s ease, transform .15s ease;
}
.service-card:hover{box-shadow:var(--shadow);transform:translateY(-4px);}
.service-icon{
  width:56px;height:56px;border-radius:12px;background:var(--green-100);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
}
.service-icon svg{width:28px;height:28px;color:var(--green-700);}
.service-card h3{font-size:17px;font-weight:800;color:var(--green-900);margin-bottom:10px;}
.service-card p{font-size:13.5px;color:var(--ink-soft);}
.service-card ul{margin-top:16px;display:flex;flex-direction:column;gap:6px;}
.service-card li{font-size:12.5px;color:var(--ink-soft);padding-left:16px;position:relative;}
.service-card li::before{content:"";position:absolute;left:0;top:8px;width:6px;height:6px;background:var(--green-500);border-radius:50%;}

/* ---------- Strength / why us ---------- */
.strength-wrap{background:var(--green-100);}
.strength-list{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.strength-list li{
  background:var(--paper);border-radius:12px;padding:26px 20px;text-align:center;
  border:1px solid var(--line);
}
.strength-num{
  width:38px;height:38px;border-radius:50%;background:var(--green-700);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;
  margin:0 auto 14px;
}
.strength-list h4{font-size:14.5px;font-weight:800;margin-bottom:8px;color:var(--green-900);}
.strength-list p{font-size:12.5px;color:var(--ink-soft);}

/* ---------- Works / body types ---------- */
.works-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.work-card{
  border-radius:12px;overflow:hidden;border:1px solid var(--line);
  background:var(--paper-soft);
}
.work-thumb{
  height:120px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--green-600),var(--green-900));
}
.work-thumb svg{width:46px;height:46px;color:#fff;opacity:.9;}
.work-card span{display:block;padding:12px 14px;font-size:13px;font-weight:700;color:var(--green-900);}

/* ---------- News ---------- */
.news-list{border-top:1px solid var(--line);}
.news-list li{
  display:flex;gap:22px;align-items:baseline;padding:18px 0;border-bottom:1px solid var(--line);
}
.news-date{font-size:12.5px;color:var(--green-600);font-weight:700;width:96px;flex:none;}
.news-tag{
  font-size:11px;background:var(--green-100);color:var(--green-700);padding:3px 10px;border-radius:100px;font-weight:700;flex:none;
}
.news-list p{font-size:13.5px;color:var(--ink-soft);}

/* ---------- CTA band ---------- */
.cta-band{
  background:var(--green-900);color:#fff;text-align:center;padding:64px 0;
}
.cta-band h2{font-size:clamp(20px,3vw,28px);font-weight:800;margin-bottom:16px;}
.cta-band p{color:rgba(255,255,255,.8);font-size:14px;margin-bottom:28px;}

/* ---------- Company page blocks ---------- */
.philosophy{
  display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
}
.philosophy .quote{
  border-left:4px solid var(--green-600);padding-left:22px;font-size:16px;font-weight:700;color:var(--green-900);
  line-height:2;
}
.philosophy-art{
  aspect-ratio:4/3;border-radius:16px;background:linear-gradient(135deg,var(--green-100),var(--paper-soft));
  border:1px solid var(--line);display:flex;align-items:center;justify-content:center;
}
.philosophy-art svg{width:120px;height:120px;color:var(--green-600);}

.profile-table{width:100%;border-collapse:collapse;font-size:14px;}
.profile-table tr{border-bottom:1px solid var(--line);}
.profile-table th{
  text-align:left;width:180px;padding:16px 20px 16px 0;color:var(--green-700);font-weight:700;vertical-align:top;
}
.profile-table td{padding:16px 0;color:var(--ink-soft);vertical-align:top;}

.timeline{border-left:2px solid var(--line);margin-left:8px;}
.timeline li{position:relative;padding:0 0 30px 30px;}
.timeline li::before{
  content:"";position:absolute;left:-7px;top:2px;width:12px;height:12px;border-radius:50%;
  background:var(--green-600);border:3px solid var(--paper);
}
.timeline b{display:block;color:var(--green-700);font-size:13px;margin-bottom:4px;}
.timeline span{font-size:13.5px;color:var(--ink-soft);}

.recruit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.recruit-card{
  border:1px solid var(--line);border-radius:12px;padding:24px;background:var(--paper-soft);
}
.recruit-card b{display:block;color:var(--green-900);font-size:15px;margin-bottom:6px;}
.recruit-card span{font-size:12.5px;color:var(--green-600);font-weight:700;}
.recruit-card p{margin-top:10px;font-size:12.5px;color:var(--ink-soft);}

.map-block{
  border-radius:14px;overflow:hidden;border:1px solid var(--line);
  display:grid;grid-template-columns:1fr 1fr;
}
.map-visual{
  background:
    repeating-linear-gradient(0deg, var(--green-100) 0 1px, transparent 1px 40px),
    repeating-linear-gradient(90deg, var(--green-100) 0 1px, transparent 1px 40px),
    var(--paper-soft);
  min-height:280px;display:flex;align-items:center;justify-content:center;position:relative;
}
.map-pin{width:44px;height:44px;color:var(--green-700);}
.map-info{padding:32px;}
.map-info h3{font-size:16px;font-weight:800;color:var(--green-900);margin-bottom:14px;}
.map-info p{font-size:13.5px;color:var(--ink-soft);margin-bottom:6px;}

/* ---------- Contact ---------- */
.contact-layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;}
.contact-side h3{font-size:17px;font-weight:800;color:var(--green-900);margin-bottom:14px;}
.contact-side p{font-size:13.5px;color:var(--ink-soft);margin-bottom:22px;}
.contact-info-card{
  border:1px solid var(--line);border-radius:12px;padding:22px;background:var(--paper-soft);margin-bottom:16px;
}
.contact-info-card b{display:block;font-size:13px;color:var(--green-700);margin-bottom:4px;}
.contact-info-card span{font-size:14px;color:var(--ink);font-weight:700;}

.field{margin-bottom:20px;}
.field label{display:block;font-size:13px;font-weight:700;color:var(--green-900);margin-bottom:8px;}
.field .req{color:#d24545;font-size:11px;margin-left:6px;font-weight:700;}
.field input,.field textarea{
  width:100%;border:1px solid var(--line);border-radius:8px;padding:12px 14px;font-size:14px;
  font-family:inherit;background:var(--paper);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green-600);}
.field textarea{resize:vertical;min-height:130px;}
.checkline{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--ink-soft);margin-bottom:26px;}
.checkline a{color:var(--green-700);text-decoration:underline;}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-900);color:rgba(255,255,255,.82);padding:56px 0 26px;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:32px;margin-bottom:40px;}
.footer-brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:800;font-size:17px;margin-bottom:14px;}
.footer-brand svg{width:28px;height:28px;}
.site-footer h5{color:#fff;font-size:13px;font-weight:700;margin-bottom:16px;letter-spacing:.05em;}
.site-footer ul li{margin-bottom:10px;font-size:13px;}
.site-footer p{font-size:13px;}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.14);padding-top:22px;
  display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,.55);flex-wrap:wrap;gap:10px;
}

/* ---------- Terms modal ---------- */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(15,30,22,.55);display:none;align-items:center;justify-content:center;z-index:200;padding:24px;
}
.modal-backdrop.open{display:flex;}
.modal-box{
  background:#fff;border-radius:14px;max-width:640px;width:100%;max-height:80vh;overflow:auto;padding:36px;
}
.modal-box h3{font-size:18px;font-weight:800;color:var(--green-900);margin-bottom:16px;}
.modal-box p{font-size:13px;color:var(--ink-soft);margin-bottom:12px;}
.modal-close{
  margin-top:20px;background:var(--green-700);color:#fff;border:0;padding:10px 22px;border-radius:8px;font-weight:700;cursor:pointer;
}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .services-grid,.strength-list,.works-grid{grid-template-columns:repeat(2,1fr);}
  .philosophy,.map-block,.contact-layout{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:repeat(2,1fr);}
  .hero-truck{display:none;}
}
/* ---------- Photo hero (inner service/products pages) ---------- */
.photo-hero{position:relative;height:340px;overflow:hidden;}
.photo-hero img{width:100%;height:100%;object-fit:cover;}
.photo-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(10,30,20,.55),rgba(10,30,20,.15));}

/* ---------- Split block (image + text, alternating) ---------- */
.split-block{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:56px 0;border-bottom:1px solid var(--line);}
.split-block:last-child{border-bottom:none;}
.split-block.reverse .split-img{order:2;}
.split-img{border-radius:14px;overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;}
.split-img img{width:100%;height:100%;object-fit:cover;}
.split-text .step-tag{font-size:12px;font-weight:800;letter-spacing:.15em;color:var(--green-600);text-transform:uppercase;}
.split-text h3{font-size:20px;font-weight:800;color:var(--green-900);margin:10px 0 16px;}
.split-text p{font-size:13.5px;color:var(--ink-soft);margin-bottom:14px;}
.split-text ul{display:flex;flex-direction:column;gap:8px;}
.split-text li{font-size:13px;color:var(--ink-soft);padding-left:18px;position:relative;}
.split-text li::before{content:"●";position:absolute;left:0;top:0;color:var(--green-500);font-size:8px;top:6px;}
.step-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;background:var(--green-700);color:#fff;font-weight:800;font-size:14px;margin-bottom:14px;
}

/* ---------- Photo gallery (body types / options) ---------- */
.photo-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.gallery-item{border-radius:12px;overflow:hidden;border:1px solid var(--line);background:var(--paper-soft);}
.gallery-item .thumb{aspect-ratio:4/3;overflow:hidden;}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .25s ease;}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-item span{display:block;padding:10px 14px;font-size:13px;font-weight:700;color:var(--green-900);}
.gallery-label{
  background:var(--green-700);color:#fff;text-align:center;font-size:13px;font-weight:700;padding:8px 0;
}

/* ---------- Staff interview ---------- */
.interview{display:grid;grid-template-columns:.9fr 1.4fr;gap:40px;padding:48px 0;border-bottom:1px solid var(--line);align-items:start;}
.interview:last-child{border-bottom:none;}
.interview-photo{border-radius:14px;overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow);}
.interview-photo img{width:100%;height:100%;object-fit:cover;}
.interview-role{font-size:12px;color:var(--green-600);font-weight:700;margin-top:16px;}
.interview-name{font-size:19px;font-weight:800;color:var(--green-900);margin-top:4px;}
.interview-quote{font-size:19px;font-weight:800;color:var(--green-900);line-height:1.7;margin-bottom:18px;}
.interview-body p{font-size:13.5px;color:var(--ink-soft);margin-bottom:14px;}

/* ---------- Accordion (recruit guideline) ---------- */
.accordion-item{border:1px solid var(--line);border-radius:10px;margin-bottom:12px;overflow:hidden;}
.accordion-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 24px;background:var(--paper-soft);cursor:pointer;font-weight:700;color:var(--green-900);font-size:14px;
}
.accordion-head span.plus{font-size:20px;color:var(--green-600);transition:transform .2s ease;}
.accordion-item.open .accordion-head span.plus{transform:rotate(45deg);}
.accordion-body{max-height:0;overflow:hidden;transition:max-height .25s ease;padding:0 24px;}
.accordion-item.open .accordion-body{max-height:400px;padding:6px 24px 22px;}
.accordion-body p{font-size:13px;color:var(--ink-soft);margin-bottom:8px;}

/* ---------- Org chart ---------- */
.org-chart{display:flex;flex-direction:column;align-items:center;gap:6px;}
.org-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
.org-box{
  background:var(--green-100);border:1px solid var(--green-500);color:var(--green-900);
  padding:10px 18px;border-radius:8px;font-size:13px;font-weight:700;text-align:center;
}
.org-connector{width:2px;height:22px;background:var(--line);}

@media (max-width:900px){
  .split-block,.interview{grid-template-columns:1fr;}
  .split-block.reverse .split-img{order:0;}
  .photo-gallery{grid-template-columns:repeat(2,1fr);}
}

@media (max-width:720px){
  .main-nav{
    position:fixed;top:76px;left:0;right:0;bottom:0;background:#fff;
    transform:translateX(100%);transition:transform .2s ease;padding:24px;
  }
  .main-nav.open{transform:translateX(0);}
  .main-nav ul{flex-direction:column;gap:6px;}
  .main-nav a{display:block;padding:14px 4px;border-bottom:1px solid var(--line);}
  .nav-toggle{display:block;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero-stats li:nth-child(2){border-right:none;}
  .services-grid,.strength-list,.works-grid,.recruit-grid{grid-template-columns:1fr;}
  .profile-table th{width:120px;padding-right:10px;}
}
