:root{
  --da-green:#0b5d37;
  --da-green-2:#137a46;
  --da-gold:#f5b942;
  --da-gold-2:#d89419;
  --da-light:#f7f9f3;
  --da-soft:#eef6ee;
  --da-text:#173126;
  --da-muted:#6f7f76;
  --da-border:#dce8dc;
  --danger:#b42318;
  --info:#0f5f80;
  --warning:#a15c07;
  --shadow:0 10px 30px rgba(7,55,35,.10);
}
*{box-sizing:border-box}
body{
  background:
    radial-gradient(circle at top left,rgba(245,185,66,.18),transparent 32%),
    linear-gradient(180deg,#fbfcf8 0%,#f1f6ee 100%);
  color:var(--da-text);
  min-height:100vh;
}
.fw-black{font-weight:900}
.app-shell{min-height:100vh;display:flex;flex-direction:column}
.topbar{
  background:linear-gradient(135deg,var(--da-green),#3f2506);
  color:white;border-bottom:5px solid var(--da-gold);box-shadow:var(--shadow)
}
.brand-logo{
  width:64px;height:64px;border-radius:50%;object-fit:contain;background:#fff;padding:5px;
  border:2px solid rgba(255,255,255,.9);box-shadow:0 8px 20px rgba(0,0,0,.18);flex:0 0 auto
}
.brand-mark{
  width:64px;height:64px;border-radius:50%;display:none;place-items:center;background:#fff;color:var(--da-green);
  border:2px solid rgba(255,255,255,.9);box-shadow:0 8px 20px rgba(0,0,0,.18);font-weight:900;flex:0 0 auto
}
.subnav{
  background:rgba(255,255,255,.97);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--da-border);position:sticky;top:0;z-index:1010
}
.subnav .navbar{padding:.65rem 0}
.nav-title{color:var(--da-green);font-weight:900;display:flex;align-items:center;gap:.45rem}
.navbar-toggler{border:1px solid var(--da-green);color:var(--da-green);border-radius:12px;padding:.45rem .7rem;box-shadow:none!important}
.subnav-menu{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end;width:100%}
.subnav-link{
  border:1px solid var(--da-border);background:#fff;color:var(--da-green);border-radius:999px;padding:.55rem .9rem;
  display:inline-flex;align-items:center;gap:.45rem;font-weight:800;white-space:nowrap;box-shadow:0 4px 12px rgba(7,55,35,.04);
  text-decoration:none;transition:.18s ease;cursor:pointer
}
.subnav-link.active,.subnav-link:hover{background:linear-gradient(135deg,var(--da-green),var(--da-green-2));color:#fff;border-color:transparent;box-shadow:0 10px 20px rgba(11,93,55,.18)}
.hero-card,.module-card{border:1px solid var(--da-border);border-radius:18px;box-shadow:var(--shadow);background:#fff}
.hero-card{
  overflow:hidden;background:
  linear-gradient(135deg,rgba(11,93,55,.98),rgba(19,122,70,.94)),
  radial-gradient(circle at right,rgba(245,185,66,.35),transparent 40%);
  color:#fff;border-bottom:5px solid var(--da-gold)
}
.hero-pill{
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);border-radius:999px;
  padding:.35rem .75rem;font-weight:800;font-size:.82rem;display:inline-flex;gap:.4rem;align-items:center
}
.kpi-card{background:linear-gradient(135deg,#fff,#f7fbf5);border:1px solid var(--da-border);border-radius:18px;padding:1rem;min-height:116px}
.kpi-number{font-size:1.85rem;font-weight:900;color:var(--da-green)}
.btn-da{background:linear-gradient(135deg,var(--da-green),var(--da-green-2));color:white;border:none;box-shadow:0 10px 18px rgba(11,93,55,.20)}
.btn-da:hover{color:white;filter:brightness(.96)}
.btn-outline-da{border-color:var(--da-green);color:var(--da-green)}
.btn-outline-da:hover{background:var(--da-green);color:white}
.text-da{color:var(--da-green)!important}.bg-da-soft{background:var(--da-soft)!important}
.badge-da{background:#e8f6ed;color:var(--da-green);border:1px solid #cfe8d7}
.form-label{font-weight:700;color:#31483e}
.required::after{content:" *";color:var(--danger)}
.form-section-title{
  font-size:.83rem;letter-spacing:.06em;text-transform:uppercase;color:var(--da-green);font-weight:900;
  border-left:4px solid var(--da-gold);padding-left:.65rem;margin:1.15rem 0 .75rem
}
.section-hint{font-size:.86rem;color:var(--da-muted)}
.table thead th{
  background:#083f29!important;color:#fff!important;border-color:#0b5d37!important;
  font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;vertical-align:middle
}
.table tbody td{vertical-align:middle}
.table-responsive{border-radius:14px;border:1px solid var(--da-border)}
.sticky-actions{position:sticky;right:0;background:#fff;box-shadow:-8px 0 18px rgba(7,55,35,.06)}
.chart-box{min-height:320px}
.canvas-wrap{height:280px;position:relative}
.timeline-item{border-left:4px solid var(--da-gold);padding-left:1rem;margin-bottom:1rem}
.timeline-date{font-weight:900;color:var(--da-green)}
.reference-box{border:2px dashed var(--da-green);background:#f3fbf5;border-radius:18px;padding:1rem}
.footer{margin-top:auto;background:#092d20;color:rgba(255,255,255,.85);border-top:4px solid var(--da-gold)}
.small-help{font-size:.82rem;color:var(--da-muted)}
@media (max-width:991.98px){
  .subnav-menu{align-items:stretch;justify-content:flex-start;gap:.45rem;padding-top:.75rem}
  .subnav-link{width:100%;border-radius:14px;justify-content:flex-start}
}
@media (max-width:575.98px){
  .brand-logo,.brand-mark{width:54px;height:54px}
  .topbar h1{font-size:1rem}
  .hero-card h2{font-size:1.25rem}
  .kpi-number{font-size:1.55rem}
}
@media print{
  .topbar,.subnav,.footer,.no-print,.btn,.modal,.offcanvas{display:none!important}
  body{background:#fff}
  .module-card,.hero-card{box-shadow:none;border:1px solid #ddd;color:#000;background:#fff}
}

#croppingMap{
  height:560px;width:100%;border-radius:18px;border:1px solid var(--da-border);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.35);background:#e8efe7;overflow:hidden
}
.map-table{max-height:520px;overflow:auto}
.map-legend{background:#fff;border:1px solid var(--da-border);border-radius:12px;padding:.65rem .75rem;box-shadow:0 8px 18px rgba(7,55,35,.10);font-size:.82rem}
.map-legend-dot{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:.35rem;background:var(--da-green)}
.projection-note{font-size:.8rem;color:var(--da-muted)}
@media (max-width:575.98px){#croppingMap{height:390px}}
@media print{#croppingMap{height:520px}.map-table{max-height:none;overflow:visible}}
