:root {
  --ink: #07120e;
  --soil: #10231b;
  --cau: #00873c;
  --teal: #0d6f68;
  --mint: #77e0c2;
  --fog: #e4ebe7;
  --mist: #d9e5e2;
  --paper: #f1f4f1;
  --white: #fbfcf8;
  --text: #14211f;
  --muted: #60706b;
  --line: rgba(20, 33, 31, 0.15);
  --warm: #b8a37a;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans SC", "PingFang SC", sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: clip; }
body { margin: 0; color: var(--text); background: linear-gradient(180deg, #e2ebe8 0%, #edf2ef 42%, #e4ece8 100%); }
a { color: inherit; }
.site-header { position: sticky; top: 0; z-index: 20; display: grid; grid-template-columns: minmax(250px, 272px) 1fr auto; align-items: stretch; min-height: 60px; border-bottom: 1px solid rgba(241,244,241,.12); background: rgba(7,18,14,.94); backdrop-filter: blur(18px); box-shadow: 0 12px 34px rgba(7,18,14,.12); }
.brand { display: flex; align-items: center; gap: 12px; min-width: 0; padding: 0 22px; color: var(--white); text-decoration: none; background: var(--cau); }
.brand > span { min-width: 0; }
.brand-mark { display: grid; place-items: center; flex: 0 0 auto; width: 36px; height: 36px; border: 1px solid rgba(255,255,255,.55); border-radius: 50%; font-weight: 850; }
.brand strong, .brand small { display: block; line-height: 1.15; }
.brand small { margin-top: 4px; overflow: hidden; color: rgba(255,255,255,.78); font-size: 11px; text-overflow: ellipsis; white-space: nowrap; }
.site-nav { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); align-items: stretch; min-width: 0; overflow: hidden; }
.site-nav a { position: relative; display: flex; align-items: center; justify-content: center; min-width: 0; min-height: 60px; padding: 0 8px; color: rgba(241,244,241,.74); border-left: 1px solid rgba(241,244,241,.1); text-align: center; text-decoration: none; white-space: nowrap; line-height: 1.2; font-size: 13px; font-weight: 760; transition: color .2s ease, background .2s ease; }
.site-nav a::after { content: ""; position: absolute; right: 18px; bottom: 0; left: 18px; height: 2px; transform: scaleX(0); transform-origin: center; background: var(--mint); transition: transform .22s ease; }
.site-nav a:hover, .site-nav a.active { color: var(--mint); background: rgba(119,224,194,.04); }
.site-nav a:hover::after, .site-nav a.active::after { transform: scaleX(1); }
.language-switcher { position: relative; display: flex; align-items: stretch; border-left: 1px solid rgba(255,255,255,.18); background: var(--cau); }
.lang-button { display: grid; place-items: center; min-width: 60px; border: 0; color: var(--white); background: transparent; cursor: pointer; }
.lang-button svg { width: 23px; height: 23px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.lang-button:hover, .lang-button[aria-expanded="true"] { background: rgba(7,18,14,.18); }
.language-menu { position: absolute; top: calc(100% + 1px); right: 0; display: none; width: 250px; border: 1px solid rgba(241,244,241,.16); border-radius: 8px; background: rgba(7,18,14,.97); box-shadow: 0 20px 60px rgba(7,18,14,.28); overflow: hidden; }
.language-switcher.open .language-menu { display: grid; }
.language-menu a { display: grid; gap: 3px; padding: 13px 15px; color: rgba(241,244,241,.82); border-bottom: 1px solid rgba(241,244,241,.1); text-decoration: none; }
.language-menu a:last-child { border-bottom: 0; }
.language-menu a:hover, .language-menu a.active { color: var(--mint); background: rgba(0,135,60,.18); }
.language-menu small { color: rgba(241,244,241,.5); font-size: 11px; line-height: 1.35; }
.hero { min-height: calc(100svh - 60px); display: grid; grid-template-columns: minmax(0, 1fr) minmax(300px, 360px); align-items: end; gap: 44px; padding: 76px max(24px, calc((100vw - 1200px) / 2)); color: var(--white); background: linear-gradient(90deg, rgba(7,18,14,.96), rgba(7,18,14,.78) 48%, rgba(7,18,14,.22)), url("field-hero.jpg") center/cover; }
.hero-copy { max-width: 880px; }
.eyebrow, .kicker { margin: 0 0 14px; color: var(--mint); font-size: 13px; font-weight: 850; letter-spacing: .06em; text-transform: uppercase; }
h1, h2, h3, p { letter-spacing: 0; }
h1 { margin: 0; font-size: clamp(48px, 7vw, 96px); line-height: .96; }
h2 { margin: 0; font-size: clamp(30px, 3.4vw, 46px); line-height: 1.08; }
h3 { margin: 0; font-size: 22px; line-height: 1.2; }
.lead { max-width: 760px; margin: 28px 0 0; font-size: 20px; line-height: 1.72; color: rgba(241,244,241,.82); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 34px; }
.button { display: inline-flex; align-items: center; min-height: 46px; padding: 0 18px; border: 1px solid rgba(241,244,241,.32); border-radius: 8px; color: var(--white); text-decoration: none; font-weight: 760; }
.button.primary { background: var(--cau); border-color: var(--cau); }
.hero-copy { animation: hero-rise .7s ease both; }
.hero-panel { align-self: end; padding: 24px; border: 1px solid rgba(241,244,241,.18); border-radius: 8px; background: rgba(16,35,27,.68); box-shadow: 0 24px 70px rgba(0,0,0,.22); animation: hero-rise .7s ease .08s both; }
@keyframes hero-rise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
.hero-panel span, .metric span, .feature-grid span { display: block; color: var(--mint); font-size: 12px; font-weight: 850; text-transform: uppercase; }
.hero-panel strong { display: block; margin-top: 12px; font-size: 26px; line-height: 1.14; }
.hero-panel p { color: rgba(241,244,241,.68); line-height: 1.6; }
.band, .split, .pathways, .answer-block, .data-table, .faq, .timeline-list, .daily-board, .daily-overview, .daily-records, .daily-metrics, .today-news-card, .archive-band, .frontline-ledger, .crop-board, .yard-ledger { width: min(1120px, calc(100% - 48px)); margin: 0 auto; }
.band { padding: 76px 0; }
.band.inline-band { padding: 0 0 34px; }
.band.cool { width: 100%; padding: 76px max(24px, calc((100vw - 1120px) / 2)); color: var(--white); background: radial-gradient(circle at 12% 0%, rgba(119,224,194,.12), transparent 34%), var(--ink); }
.section-head { display: grid; grid-template-columns: minmax(0,1fr) minmax(280px,420px); gap: 30px; align-items: end; margin-bottom: 28px; }
.section-head.compact h2 { font-size: clamp(28px, 3vw, 40px); }
.section-head p { margin: 0; color: var(--muted); line-height: 1.7; }
.cool .section-head p { color: rgba(241,244,241,.7); }
.metric-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 1px; border: 1px solid var(--line); border-radius: 8px; background: var(--line); overflow: hidden; }
.feature-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 1px; border: 1px solid var(--line); border-radius: 8px; background: var(--line); overflow: hidden; }
main > .feature-grid { width: min(1120px, calc(100% - 48px)); margin: 0 auto 34px; }
.metric, .feature-grid article { min-height: 180px; padding: 24px; background: rgba(246,248,245,.82); transition: transform .22s ease, background .22s ease; }
.metric, .feature-grid article, .answer-block, .case-card, .service-card, .theme-rollup-row { min-width: 0; overflow-wrap: break-word; }
.feature-grid article:hover, .metric:hover { transform: translateY(-2px); background: var(--white); }
.metric strong, .feature-grid strong { display: block; margin: 14px 0 10px; font-size: clamp(22px, 2.1vw, 28px); line-height: 1.12; }
.metric p, .feature-grid p { margin: 0; color: var(--muted); line-height: 1.62; }
.split { display: grid; grid-template-columns: minmax(0, .92fr) minmax(340px, .68fr); gap: 50px; align-items: center; padding: 86px 0; }
.split p, .answer-block p, .faq p { color: var(--muted); font-size: 16px; line-height: 1.78; }
.text-link { display: inline-flex; margin-top: 12px; color: var(--teal); font-weight: 850; text-decoration: none; }
.text-link.secondary-link { margin-left: 18px; }
.manual-note { width: min(1120px, calc(100% - 48px)); margin: 18px auto 0; color: var(--muted); font-size: 13px; line-height: 1.6; }
.image-strip { margin: 0; height: 440px; overflow: hidden; border-radius: 8px; }
.image-strip img { width: 100%; height: 100%; object-fit: cover; display: block; }
.daily-empty, .daily-status { display: flex; justify-content: space-between; gap: 20px; padding: 22px 24px; border: 1px solid rgba(241,244,241,.18); border-radius: 8px; background: rgba(16,35,27,.76); }
.daily-empty strong, .daily-status strong { color: var(--mint); }
.daily-empty span, .daily-status p { color: rgba(241,244,241,.72); margin: 0; }
.daily-overview { display: flex; justify-content: space-between; gap: 28px; align-items: start; margin-bottom: 18px; padding: 24px; border: 1px solid rgba(241,244,241,.18); border-radius: 8px; background: rgba(16,35,27,.76); }
.daily-overview strong { display: block; color: var(--mint); font-size: 22px; line-height: 1.2; }
.daily-overview p { max-width: 840px; margin: 10px 0 0; color: rgba(241,244,241,.74); line-height: 1.72; }
.daily-overview span { flex: 0 0 auto; padding: 8px 10px; border: 1px solid rgba(119,224,194,.28); border-radius: 999px; color: var(--mint); font-weight: 850; font-size: 12px; }
.daily-overview.page { color: var(--text); background: rgba(241,244,241,.76); border-color: var(--line); }
.daily-overview.page p { color: var(--muted); }
.news-ticker { position: relative; width: min(1180px, calc(100% - 40px)); margin: 0 auto 18px; overflow: hidden; border: 1px solid rgba(119,224,194,.24); border-radius: 8px; background: rgba(7,18,14,.72); }
.ticker-track { display: flex; width: max-content; gap: 32px; padding: 12px 0; animation: ticker-scroll 180s linear infinite; }
.ticker-track span { display: inline-flex; align-items: center; flex: 0 0 auto; max-width: min(560px, 82vw); overflow: hidden; color: rgba(241,244,241,.88); white-space: nowrap; text-overflow: ellipsis; font-size: 14px; line-height: 1.35; }
.ticker-track span::before { content: ""; width: 7px; height: 7px; margin: 0 10px 0 0; border-radius: 50%; background: var(--mint); box-shadow: 0 0 14px rgba(119,224,194,.52); flex: 0 0 auto; }
.news-ticker:hover .ticker-track { animation-play-state: paused; }
@keyframes ticker-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
.today-news-card { margin-bottom: 54px; padding: 30px; border: 1px solid var(--line); border-radius: 8px; background: var(--ink); color: var(--white); overflow: hidden; }
.today-news-card .news-ticker { width: 100%; margin: 22px 0 20px; background: rgba(241,244,241,.06); }
.today-news-head { display: flex; justify-content: space-between; gap: 24px; align-items: start; }
.today-news-head h2 { color: var(--white); max-width: 820px; }
.today-news-head span { flex: 0 0 auto; padding: 8px 10px; border: 1px solid rgba(119,224,194,.28); border-radius: 999px; color: var(--mint); font-weight: 850; font-size: 12px; }
.scroll-panel { position: relative; overflow-y: auto; overscroll-behavior: contain; scrollbar-gutter: stable; }
.scroll-panel::-webkit-scrollbar { width: 10px; }
.scroll-panel::-webkit-scrollbar-track { background: transparent; }
.scroll-panel::-webkit-scrollbar-thumb { border-radius: 999px; border: 3px solid transparent; background-clip: content-box; }
.today-news-scroll { max-height: 265px; border: 1px solid rgba(241,244,241,.12); border-radius: 8px; background: rgba(241,244,241,.12); }
.today-news-scroll::-webkit-scrollbar-thumb { background-color: rgba(119,224,194,.52); }
.today-news-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1px; margin: 0; padding: 0; list-style: none; background: rgba(241,244,241,.12); }
.today-news-list li { height: 132px; padding: 18px 20px; overflow: hidden; background: rgba(16,35,27,.78); }
.today-news-list span { display: block; color: var(--mint); font-weight: 850; line-height: 1.35; }
.today-news-list p { display: -webkit-box; margin: 10px 0 0; overflow: hidden; color: rgba(241,244,241,.76); line-height: 1.66; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }
.archive-band { margin-bottom: 54px; padding: 30px; border: 1px solid var(--line); border-radius: 8px; background: rgba(241,244,241,.76); }
.archive-band .section-head.compact { margin-bottom: 22px; }
.archive-band .section-head.compact h2 { font-size: clamp(28px, 3vw, 40px); }
.archive-scroll { max-height: 381px; border: 1px solid var(--line); border-radius: 8px; background: var(--line); }
.archive-scroll::-webkit-scrollbar-thumb { background-color: rgba(13,111,104,.45); }
.archive-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1px; background: var(--line); }
.archive-card { height: 190px; padding: 22px; overflow: hidden; background: var(--white); }
.archive-card span { color: var(--teal); font-weight: 900; font-size: 14px; }
.archive-card h3 { display: -webkit-box; margin-top: 12px; overflow: hidden; color: var(--ink); font-size: 24px; line-height: 1.22; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.archive-card p { display: -webkit-box; margin: 12px 0 0; overflow: hidden; color: var(--muted); line-height: 1.62; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.daily-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.daily-card { min-height: 238px; padding: 20px; border: 1px solid rgba(241,244,241,.16); border-radius: 8px; background: rgba(241,244,241,.08); }
.daily-card h3 { margin-top: 10px; color: var(--white); font-size: 21px; }
.daily-card p { color: rgba(241,244,241,.73); line-height: 1.7; }
.daily-meta { color: var(--mint); font-size: 12px; font-weight: 850; text-transform: uppercase; }
.daily-card-foot { display: flex; justify-content: space-between; gap: 14px; align-items: end; margin-top: 18px; color: rgba(241,244,241,.62); font-size: 12px; }
.daily-card-foot b { color: var(--mint); white-space: nowrap; }
.daily-records { margin-bottom: 34px; padding: 28px; border: 1px solid var(--line); border-radius: 8px; background: rgba(246,248,245,.78); }
.daily-metrics { margin-bottom: 34px; }
.daily-records .section-head.compact { margin-bottom: 22px; }
.daily-records .section-head.compact h2 { font-size: clamp(28px, 3vw, 40px); }
.page-list .daily-card { background: var(--white); border-color: var(--line); }
.page-list .daily-card h3 { color: var(--ink); }
.page-list .daily-card p { color: var(--muted); }
.page-list .daily-card-foot { color: var(--muted); }
.page-list .daily-card-foot b { color: var(--teal); }
.daily-overview.page + .news-ticker { margin-bottom: 34px; }
.on-dark { color: var(--mint); }
.stats-ribbon { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px; margin-bottom: 18px; border-radius: 8px; background: var(--line); overflow: hidden; }
.stats-ribbon article { min-height: 150px; padding: 22px; background: rgba(241,244,241,.78); }
.stats-ribbon span, .index-card-head span, .crop-row span, .yard-row span, .weekly-row span { display: block; color: var(--teal); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.stats-ribbon strong { display: block; margin-top: 14px; color: var(--ink); font-size: 38px; line-height: 1; }
.stats-ribbon p { margin: 12px 0 0; color: var(--muted); line-height: 1.56; }
.index-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.index-card { min-height: 255px; padding: 22px; border: 1px solid var(--line); border-radius: 8px; background: var(--white); transition: transform .22s ease, border-color .22s ease; }
.index-card:hover { transform: translateY(-3px); border-color: rgba(13,111,104,.42); }
.index-card-head { display: flex; justify-content: space-between; gap: 12px; align-items: start; }
.index-card-head small { color: var(--muted); font-weight: 800; line-height: 1.3; }
.index-card h3 { margin-top: 30px; color: var(--ink); }
.index-card p { color: var(--muted); line-height: 1.68; }
.tag-row { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 18px; }
.tag-row b { padding: 6px 8px; border: 1px solid rgba(13,111,104,.2); border-radius: 999px; color: var(--teal); background: rgba(13,111,104,.07); font-size: 12px; line-height: 1; }
.frontline-ledger, .crop-board, .yard-ledger { margin-bottom: 34px; padding: 28px; border: 1px solid var(--line); border-radius: 8px; background: rgba(246,248,245,.78); }
.answer-block.strong-intro { display: grid; grid-template-columns: minmax(260px, .72fr) minmax(0, 1.28fr); gap: 18px 52px; align-items: start; padding: 42px 46px; background: linear-gradient(135deg, #07120e 0%, #0b1d17 62%, #10231b 100%); color: var(--white); border-color: rgba(119,224,194,.22); box-shadow: 0 28px 80px rgba(7,18,14,.16); }
.answer-block.strong-intro .kicker { grid-column: 1 / -1; }
.answer-block.strong-intro h2 { grid-column: 1 / -1; max-width: 820px; }
.answer-block.strong-intro p:not(.kicker) { grid-column: 2; margin: 0; color: rgba(241,244,241,.74); }
.answer-block.strong-intro p:not(.kicker) + p:not(.kicker) { margin-top: 12px; }
.crop-list, .yard-list, .weekly-list { display: grid; gap: 1px; border: 1px solid var(--line); border-radius: 8px; background: var(--line); overflow: hidden; }
.theme-rollup-list { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.service-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.case-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.method-grid article small { display: block; margin-top: 16px; color: var(--teal); font-weight: 850; line-height: 1.5; }
.case-card { min-height: 360px; padding: 22px; border: 1px solid var(--line); border-radius: 8px; background: var(--white); transition: transform .22s ease, border-color .22s ease; }
.case-card:hover { transform: translateY(-2px); border-color: rgba(13,111,104,.36); }
.case-card span { display: block; color: var(--teal); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.case-card h3 { margin: 14px 0 18px; color: var(--ink); font-size: 22px; }
.case-card dl { display: grid; gap: 10px; margin: 0; }
.case-card dt { color: var(--teal); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.case-card dd { margin: 0; color: var(--muted); line-height: 1.58; }
.case-card p { margin: 18px 0 0; color: var(--teal); font-size: 12px; font-weight: 850; line-height: 1.5; }
.theme-rollup-row { min-height: 150px; padding: 22px; border: 1px solid var(--line); border-radius: 8px; background: var(--white); transition: transform .22s ease, border-color .22s ease; }
.theme-rollup-row:hover { transform: translateY(-2px); border-color: rgba(13,111,104,.36); }
.theme-rollup-row strong { display: block; margin: 12px 0; color: var(--ink); font-size: 24px; line-height: 1.1; }
.theme-rollup-row p { margin: 0; color: var(--muted); line-height: 1.65; }
.service-card { min-height: 264px; padding: 22px; border: 1px solid var(--line); border-radius: 8px; background: var(--white); transition: transform .22s ease, border-color .22s ease; }
.service-card:hover { transform: translateY(-2px); border-color: rgba(13,111,104,.36); }
.service-card h3 { margin: 12px 0 18px; color: var(--ink); font-size: 22px; }
.service-card dl { display: grid; grid-template-columns: 72px minmax(0,1fr); gap: 9px 12px; margin: 0; }
.service-card dt { color: var(--teal); font-size: 12px; font-weight: 900; text-transform: uppercase; }
.service-card dd { margin: 0 0 6px; color: var(--muted); line-height: 1.58; }
.crop-row { display: grid; grid-template-columns: 120px 90px minmax(0, 1fr) 110px; gap: 18px; align-items: center; min-height: 92px; padding: 18px 20px; background: var(--white); }
.crop-row strong { color: var(--ink); font-size: 28px; line-height: 1; }
.crop-row p, .yard-row p, .weekly-row p { margin: 0; color: var(--muted); line-height: 1.58; }
.crop-row small { color: var(--teal); font-weight: 850; text-align: right; }
.yard-row { display: grid; grid-template-columns: 92px minmax(220px, .7fr) minmax(0, 1fr); gap: 22px; align-items: center; min-height: 96px; padding: 20px 22px; background: var(--white); }
.yard-row h3 { font-size: 20px; color: var(--ink); }
.weekly-row { display: grid; grid-template-columns: 112px minmax(220px, .72fr) minmax(0, 1fr); gap: 22px; align-items: center; min-height: 108px; padding: 20px 22px; background: var(--white); }
.weekly-row h3 { color: var(--ink); font-size: 20px; }
.pathways { display: grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap: 1px; padding: 0 0 88px; background: var(--line); border-radius: 8px; overflow: hidden; }
.pathways a { min-height: 210px; padding: 24px; background: var(--paper); text-decoration: none; }
.pathways span { color: var(--teal); font-weight: 850; }
.pathways strong { display: block; margin: 28px 0 10px; font-size: 24px; }
.pathways p { color: var(--muted); line-height: 1.65; }
.page-hero { width: 100%; margin: 0 0 42px; padding: 58px max(24px, calc((100vw - 1120px) / 2)) 50px; border-bottom: 1px solid rgba(20,33,31,.09); background: linear-gradient(135deg, rgba(236,243,240,.96), rgba(216,229,225,.9)); }
.page-hero h1 { max-width: 880px; color: var(--ink); font-size: clamp(44px, 5.5vw, 72px); }
.page-hero p { max-width: 720px; color: var(--muted); font-size: 18px; line-height: 1.72; }
.answer-block, .data-table, .faq, .timeline-list, .daily-board { margin-bottom: 34px; padding: 28px; border: 1px solid var(--line); border-radius: 8px; background: rgba(246,248,245,.78); }
.data-table h2, .faq h2 { font-size: clamp(28px, 3vw, 40px); }
.source-note { font-size: 14px !important; }
.source-note a, .data-table a { color: var(--teal); }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 14px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; line-height: 1.55; }
th { color: var(--teal); background: var(--mist); }
tr:last-child td { border-bottom: 0; }
.faq details { padding: 18px 0; border-bottom: 1px solid var(--line); }
.faq details:last-child { border-bottom: 0; }
.faq summary { cursor: pointer; font-weight: 850; }
.timeline-list { display: grid; gap: 1px; padding: 0; background: var(--line); overflow: hidden; }
.timeline-item { display: grid; grid-template-columns: 120px 1fr 280px; gap: 24px; align-items: center; padding: 22px 26px; background: rgba(241,244,241,.78); }
.timeline-item span { color: var(--teal); font-weight: 900; font-size: 22px; }
.timeline-item p { margin: 0; color: var(--muted); }
.daily-board { display: grid; grid-template-columns: .9fr 1.1fr; gap: 28px; }
.field-list { columns: 2; color: var(--muted); line-height: 1.9; }
.site-footer { display: flex; justify-content: space-between; gap: 40px; padding: 36px min(7vw, 88px); color: rgba(241,244,241,.7); background: var(--ink); }
.site-footer p { max-width: 720px; line-height: 1.6; }
.site-footer .icp { margin: 10px 0 0; font-size: .84rem; }
.site-footer .icp a { color: rgba(241,244,241,.68); text-decoration: none; }
.site-footer .icp a:hover { color: var(--mint); }
.footer-links { display: flex; gap: 16px; align-items: start; }
.footer-links a { color: var(--mint); text-decoration: none; white-space: nowrap; }
.reveal { opacity: 1; transform: translateY(0); transition: opacity .55s ease, transform .55s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }
@media (max-width: 980px) {
  .site-header { grid-template-columns: minmax(0, 1fr) auto; min-height: 58px; }
  .brand { grid-column: 1 / 2; }
  .language-switcher { grid-column: 2 / 3; grid-row: 1; }
  .site-nav { grid-column: 1 / -1; border-top: 1px solid rgba(241,244,241,.12); }
  .site-nav a { min-height: 48px; padding: 0 5px; font-size: 12px; }
  .hero, .split, .section-head, .daily-board { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding: 96px 20px 54px; }
  .hero-panel { max-width: 420px; }
  .metric-grid, .feature-grid, .pathways, .daily-list, .index-grid, .stats-ribbon, .theme-rollup-list, .service-grid, .case-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .answer-block.strong-intro { grid-template-columns: 1fr; gap: 12px; padding: 34px; }
  .answer-block.strong-intro .kicker, .answer-block.strong-intro h2, .answer-block.strong-intro p:not(.kicker) { grid-column: 1; }
  .crop-row, .yard-row, .weekly-row { grid-template-columns: 1fr; gap: 10px; align-items: start; }
  .crop-row small { text-align: left; }
  .news-ticker { width: calc(100% - 40px); }
  .daily-overview, .today-news-head { display: block; }
  .daily-overview span { display: inline-flex; margin-top: 14px; }
  .today-news-head span { display: inline-flex; margin-top: 14px; }
  .timeline-item { grid-template-columns: 1fr; gap: 10px; }
}
@media (max-width: 640px) {
  body { background: #e2ebe8; }
  .brand { padding: 0 14px; }
  .brand-mark { width: 34px; height: 34px; font-size: 12px; }
  .brand strong { font-size: 15px; }
  .brand small { font-size: 10px; }
  .lang-button { min-width: 56px; font-size: 18px; }
  .language-menu { width: min(260px, calc(100vw - 28px)); }
  .site-nav a { min-height: 42px; padding: 0 2px; border-top: 1px solid rgba(241,244,241,.08); font-size: 11px; font-weight: 800; }
  .site-nav a::after { right: 10px; left: 10px; }
  .hero { padding: 82px 20px 54px; background-position: 58% center; }
  .hero h1 { font-size: clamp(46px, 15vw, 58px); }
  .lead { margin-top: 24px; font-size: 19px; line-height: 1.72; }
  .hero-actions { margin-top: 28px; }
  .button { min-height: 44px; padding: 0 16px; }
  .hero-panel { padding: 22px; }
  .hero-panel strong { font-size: 25px; }
  .metric-grid, .feature-grid, .pathways, .daily-list, .index-grid, .stats-ribbon, .theme-rollup-list, .service-grid, .case-grid { grid-template-columns: 1fr; }
  .today-news-list, .archive-grid { grid-template-columns: 1fr; }
  .today-news-scroll { max-height: 528px; }
  .archive-scroll { max-height: 763px; }
  .band, .split, .pathways, .feature-grid, .answer-block, .data-table, .faq, .timeline-list, .daily-board, .daily-overview, .daily-records, .daily-metrics, .news-ticker, .today-news-card, .archive-band, .frontline-ledger, .crop-board, .yard-ledger, .manual-note { width: calc(100% - 28px); }
  .page-hero { width: 100%; margin-bottom: 30px; padding: 50px 20px 40px; }
  .page-hero h1 { font-size: clamp(40px, 12vw, 52px); line-height: 1.03; }
  .page-hero p { font-size: 17px; line-height: 1.7; }
  .answer-block.strong-intro { padding: 28px; }
  .answer-block.strong-intro h2 { font-size: clamp(28px, 9vw, 38px); line-height: 1.12; }
  .answer-block, .data-table, .faq, .timeline-list, .daily-board, .daily-records, .today-news-card, .archive-band, .frontline-ledger, .crop-board, .yard-ledger { padding: 22px; }
  .service-card, .case-card { min-height: auto; padding: 20px; }
  .service-card dl { grid-template-columns: 1fr; gap: 7px; }
  .service-card dd { margin-bottom: 8px; }
  .feature-grid article, .metric { min-height: auto; }
  .pathways { padding-bottom: 44px; }
  .data-table { overflow-x: auto; }
  .field-list { columns: 1; }
  .site-footer { display: block; }
  .footer-links { margin-top: 20px; flex-wrap: wrap; }
}
@media (prefers-reduced-motion: reduce) {
  .ticker-track { animation: none; flex-wrap: wrap; width: auto; padding: 12px; }
  .ticker-track span { white-space: normal; }
}
