/* ============================================================
   Lower pages (Company / Business / Horticulture / Recruit / News / Contact)
   ============================================================ */

.block { padding: 84px 0; }
.block.tint { background: var(--paper-2); }
.block-head { margin-bottom: 44px; }
.block-head.center { text-align: center; }
.block-head .en { display:block; font-family: var(--serif); color: var(--green-600); font-size: 13px; letter-spacing:.26em; font-weight:600; margin-bottom: 8px; }
.block-head h2 { font-family: var(--serif); font-size: clamp(24px,2.8vw,33px); letter-spacing:.05em; color: var(--ink); }
.block-head h2::after { content:""; display:block; width:44px; height:3px; background: var(--green-600); border-radius:2px; margin-top:16px; }
.block-head.center h2::after { margin-left:auto; margin-right:auto; }

/* philosophy hero */
.philosophy-hero { text-align:center; max-width: 860px; margin: 0 auto; }
.philosophy-hero .quote { font-family: var(--serif); font-size: clamp(26px,3.6vw,42px); color: var(--green-800); letter-spacing:.06em; line-height:1.6; margin-bottom: 28px; }
.philosophy-hero .quote span { color: var(--green-600); }
.philosophy-hero p { color: var(--muted); line-height: 2.1; }

/* guidelines */
.guide-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; }
.guide-item { background:#fff; border:1px solid var(--line); border-radius:10px; padding:26px 22px; transition:.25s; box-shadow: var(--shadow-sm); }
.guide-item:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--green-100); }
.guide-item .no { font-family: var(--serif); color: var(--green-500); font-size:13px; letter-spacing:.16em; font-weight:700; }
.guide-item h3 { font-size:17px; color: var(--green-800); margin-top:8px; letter-spacing:.04em; }

/* greeting */
.greeting { display:grid; grid-template-columns: 0.8fr 1.2fr; gap:48px; align-items:center; }
.greeting image-slot { width:100%; height:420px; border-radius:12px; }
.greeting .body p { color: var(--muted); margin-bottom: 18px; line-height: 2.1; }
.greeting .sign { font-family: var(--serif); font-size:21px; color: var(--green-800); margin-top: 8px; }
.greeting .sign small { display:block; font-family: var(--sans); font-size:12px; color: var(--muted); letter-spacing:.1em; }

/* info table */
.info-table { width:100%; border-collapse: collapse; background:#fff; border:1px solid var(--line); border-radius:10px; overflow:hidden; }
.info-table th, .info-table td { text-align:left; padding:20px 26px; border-bottom:1px solid var(--line); vertical-align:top; font-size:15px; }
.info-table tr:last-child th, .info-table tr:last-child td { border-bottom:none; }
.info-table th { width: 220px; background: var(--green-50); color: var(--green-800); font-weight:700; letter-spacing:.04em; }
.info-table td { color: var(--ink); line-height:1.9; }

/* history timeline */
.timeline { max-width: 720px; margin: 0 auto; position: relative; padding-left: 28px; }
.timeline::before { content:""; position:absolute; left:5px; top:8px; bottom:8px; width:2px; background: var(--green-100); }
.timeline .row { position:relative; padding: 0 0 30px 28px; }
.timeline .row::before { content:""; position:absolute; left:-26px; top:5px; width:12px; height:12px; border-radius:50%; background: var(--green-600); border:3px solid #fff; box-shadow:0 0 0 2px var(--green-100); }
.timeline .yr { font-family: var(--serif); color: var(--green-700); font-weight:700; font-size:16px; letter-spacing:.04em; }
.timeline .txt { color: var(--muted); margin-top:3px; font-size:15px; }

/* map */
.map-slot { width:100%; height: 380px; border-radius:12px; border:1px solid var(--line); }

/* business detail */
.biz-detail { display:grid; grid-template-columns: 1fr 1fr; gap:46px; align-items:center; margin-bottom: 72px; }
.biz-detail:last-child { margin-bottom:0; }
.biz-detail.rev .media { order:2; }
.biz-detail image-slot { width:100%; height: 360px; border-radius:12px; }
.biz-detail .en { font-family: var(--serif); color: var(--green-600); letter-spacing:.2em; font-size:13px; font-weight:600; }
.biz-detail h3 { font-family: var(--serif); font-size: clamp(22px,2.4vw,28px); color: var(--green-800); letter-spacing:.04em; margin:6px 0 16px; }
.biz-detail p { color: var(--muted); line-height: 2.05; margin-bottom: 14px; }
.biz-detail .tasks { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.biz-detail .tasks span { font-size:12.5px; background: var(--green-50); border:1px solid var(--green-100); color: var(--green-800); padding:6px 13px; border-radius:4px; }

/* parks grid */
.parks-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.park-card { background:#fff; border-radius:10px; overflow:hidden; box-shadow:var(--shadow-sm); transition:.25s; }
.park-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.park-card image-slot { width:100%; height:200px; }
.park-card .pc { padding:20px 22px 24px; }
.park-card .pc .en { font-size:11px; letter-spacing:.14em; color: var(--green-600); font-family:var(--serif); }
.park-card .pc h4 { font-size:17px; color: var(--green-800); margin:4px 0 8px; }
.park-card .pc p { font-size:13px; color: var(--muted); line-height:1.85; }

/* product grid (horticulture) */
.prod-grid { display:grid; grid-template-columns: repeat(3,1fr); gap:24px; }
.prod { background:#fff; border-radius:10px; overflow:hidden; box-shadow:var(--shadow-sm); transition:.25s; }
.prod:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.prod image-slot { width:100%; height:230px; }
.prod .pb { padding:18px 20px 22px; }
.prod .pb h4 { font-size:16px; color: var(--green-800); margin-bottom:6px; }
.prod .pb p { font-size:13px; color: var(--muted); line-height:1.8; }

/* recruit */
.recruit-hero-grid { display:grid; grid-template-columns: 1.1fr 0.9fr; gap:48px; align-items:center; }
.recruit-hero-grid image-slot { width:100%; height:380px; border-radius:12px; }
.recruit-hero-grid h2 { font-family: var(--serif); font-size: clamp(24px,3vw,34px); color: var(--green-800); letter-spacing:.05em; line-height:1.6; margin-bottom: 20px; }
.recruit-hero-grid p { color: var(--muted); line-height:2.1; margin-bottom:16px; }
.jobs { display:grid; gap:18px; }
.job { background:#fff; border:1px solid var(--line); border-radius:12px; padding:30px 32px; box-shadow:var(--shadow-sm); }
.job .jt { display:flex; align-items:center; gap:14px; margin-bottom:18px; flex-wrap:wrap; }
.job .jt h3 { font-size:20px; color: var(--green-800); letter-spacing:.04em; }
.job .tag { font-size:12px; font-weight:700; background: var(--green-700); color:#fff; padding:5px 12px; border-radius:4px; }
.job dl { display:grid; grid-template-columns: 120px 1fr; gap:12px 18px; margin:0; }
.job dt { color: var(--green-800); font-weight:700; font-size:14px; }
.job dd { margin:0; color: var(--muted); font-size:14px; line-height:1.9; }

/* news list */
.news-list { max-width: 880px; margin:0 auto; }
.news-list .nrow { display:grid; grid-template-columns:auto auto 1fr auto; gap:18px; align-items:center; padding:22px 6px; border-bottom:1px solid var(--line); transition:.2s; }
.news-list .nrow:hover { background: var(--green-50); }
.news-list .date { font-size:13.5px; color: var(--muted); font-variant-numeric:tabular-nums; white-space:nowrap; }
.news-list .cat { font-size:11px; font-weight:700; color: var(--green-700); background: var(--green-50); border:1px solid var(--green-100); padding:4px 11px; border-radius:3px; white-space:nowrap; }
.news-list .ttl { color: var(--ink); font-size:15px; }
.news-list .chev { color: var(--green-500); }

/* contact */
.contact-grid { display:grid; grid-template-columns: 1fr 1.2fr; gap:48px; align-items:start; }
.contact-info .ci { display:flex; gap:16px; padding:22px 0; border-bottom:1px solid var(--line); }
.contact-info .ci:first-child { padding-top:0; }
.contact-info .ic { width:46px;height:46px;border-radius:50%;background:var(--green-50);border:1px solid var(--green-100);display:grid;place-items:center;color:var(--green-700);flex:0 0 auto; }
.contact-info .ic svg { width:22px;height:22px; }
.contact-info h4 { font-size:14px; color: var(--green-800); letter-spacing:.06em; margin-bottom:4px; }
.contact-info p { color: var(--muted); font-size:14px; line-height:1.85; }
.form { background:#fff; border:1px solid var(--line); border-radius:14px; padding:36px 38px; box-shadow:var(--shadow-sm); }
.field { margin-bottom:22px; }
.field label { display:block; font-size:14px; font-weight:700; color: var(--green-800); margin-bottom:8px; letter-spacing:.03em; }
.field label .req { color:#c0392b; font-size:12px; margin-left:6px; }
.field input, .field textarea, .field select { width:100%; border:1.5px solid var(--line); border-radius:8px; padding:13px 15px; font-family:var(--sans); font-size:15px; color:var(--ink); transition:.2s; background:#fff; }
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color: var(--green-600); box-shadow:0 0 0 3px var(--green-50); }
.field textarea { resize:vertical; min-height:130px; }
.form .submit { width:100%; justify-content:center; font-size:16px; padding:17px; }
.form-done { background: var(--green-50); border:1px solid var(--green-100); border-radius:10px; padding:22px; text-align:center; color: var(--green-800); margin-top:20px; }
.form-done .ic { width:48px;height:48px;border-radius:50%;background:var(--green-600);color:#fff;display:grid;place-items:center;margin:0 auto 12px; }

/* form privacy consent */
.consent { display:flex; gap:11px; align-items:flex-start; margin:2px 0 24px; font-size:13.5px; color:var(--muted); line-height:1.75; }
.consent input { width:18px; height:18px; margin-top:3px; flex:0 0 auto; accent-color: var(--green-700); cursor:pointer; }
.consent a { color:var(--green-700); text-decoration:underline; }

/* privacy policy page */
.policy { max-width: 820px; margin:0 auto; }
.policy h2 { font-family: var(--serif); font-size: 19px; color: var(--green-800); letter-spacing:.04em; margin: 38px 0 12px; padding-left:14px; border-left:4px solid var(--green-500); }
.policy p { color: var(--muted); line-height: 2.05; margin-bottom: 12px; }
.policy ul { margin:0 0 12px; padding-left: 22px; color: var(--muted); line-height: 2; }
.policy ul li { margin-bottom: 4px; }
.policy .policy-meta { margin-top: 48px; padding-top:24px; border-top:1px solid var(--line); font-size:13.5px; color: var(--muted); line-height:2; }

@media (max-width: 980px){
  .guide-grid{ grid-template-columns: repeat(2,1fr); }
  .greeting, .biz-detail, .recruit-hero-grid, .contact-grid{ grid-template-columns:1fr; gap:32px; }
  .biz-detail.rev .media{ order:0; }
  .parks-grid, .prod-grid{ grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 600px){
  .guide-grid, .parks-grid, .prod-grid{ grid-template-columns:1fr; }
  .info-table th{ width:120px; padding:14px; }
  .info-table td{ padding:14px; }
  .job dl{ grid-template-columns:1fr; gap:4px 0; }
  .job dd{ margin-bottom:10px; }
  .news-list .nrow{ grid-template-columns:auto 1fr auto; }
  .news-list .cat{ display:none; }
}
