/* ============================================================
   Leafscape Green Impact Platform — Tactical Light Theme
   ============================================================ */
:root{
  --bg:#e1ebe2;
  --bg-2:#d5e2d6;
  --surface:#ffffff;
  --surface-2:#eef4ee;
  --ink:#102708;
  --ink-soft:#2c4329;
  --muted:#5a6b58;
  --line:#bccfbe;
  --line-strong:#9ab59c;
  --primary:#354e33;
  --primary-2:#456449;
  --secondary:#102708;
  --accent:#7fb069;
  --warn:#c98a18;
  --danger:#a83232;
  --info:#2f6b8f;
  --good:#3f7a3a;
  --shadow: 0 1px 0 rgba(16,39,8,.04), 0 8px 24px -12px rgba(16,39,8,.18);
  --radius: 14px;
  --radius-sm: 10px;
  --mono: "JetBrains Mono", ui-monospace, Menlo, monospace;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:14px;
  letter-spacing:.01em;
  background-image:
    radial-gradient(1200px 600px at -10% -20%, rgba(53,78,51,.10), transparent 60%),
    radial-gradient(900px 500px at 110% 110%, rgba(16,39,8,.08), transparent 60%);
}
b,strong{font-weight:600}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--secondary)}
.mono{font-family:var(--mono)}

/* ===== Boot splash ===== */
#boot-splash{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(160deg,#102708 0%, #1c3819 60%, #2c4729 100%);
  color:#dfe9d9;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);
  overflow:hidden;
}
#boot-splash::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:40px 40px;
  mask-image:radial-gradient(circle at center, #000 30%, transparent 75%);
}
.boot-inner{position:relative;width:min(560px,90vw);text-align:center}
.boot-logo{
  width:96px;height:96px;border-radius:50%;
  background:#e1ebe2;padding:14px;
  box-shadow:0 0 0 6px rgba(255,255,255,.06), 0 0 60px rgba(127,176,105,.4);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{0%,100%{transform:scale(1);box-shadow:0 0 0 6px rgba(255,255,255,.06),0 0 60px rgba(127,176,105,.4)}50%{transform:scale(1.04);box-shadow:0 0 0 10px rgba(255,255,255,.04),0 0 90px rgba(127,176,105,.6)}}
.boot-bar{
  margin:24px auto 10px;width:100%;height:6px;background:rgba(255,255,255,.08);
  border-radius:99px;overflow:hidden;
}
.boot-bar-fill{
  width:0%;height:100%;
  background:linear-gradient(90deg,#7fb069,#c8e6a0,#7fb069);
  background-size:200% 100%;
  animation: bootfill 2.6s ease forwards, shimmer 2s linear infinite;
}
@keyframes bootfill{to{width:100%}}
@keyframes shimmer{to{background-position:-200% 0}}
.boot-status{font-size:12px;letter-spacing:.2em;text-transform:uppercase;opacity:.85;margin-bottom:18px}
.boot-status .dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#7fb069;margin-right:8px;animation:blink 1s infinite}
@keyframes blink{50%{opacity:.2}}
.boot-grid{
  display:grid;grid-template-columns:auto 1fr;gap:6px 18px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.2);
  padding:14px 18px;border-radius:8px;text-align:left;
}
.boot-grid > div:nth-child(odd){opacity:.55}
.boot-grid > div:nth-child(even){color:#c8e6a0}

/* ===== App layout ===== */
#app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{
  background:linear-gradient(180deg, #102708 0%, #1b3717 100%);
  color:#cfe0c7;
  border-right:1px solid rgba(255,255,255,.06);
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;
  z-index:10;
}
.brand{display:flex;align-items:center;gap:12px;padding:18px 18px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.brand img{width:38px;height:38px;border-radius:9px;background:#e1ebe2;padding:5px}
.brand-name{font-weight:800;letter-spacing:.18em;font-size:14px;color:#fff}
.brand-sub{font-size:9.5px;letter-spacing:.28em;color:#7fb069;font-family:var(--mono)}

.role-switch{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.role-label{font-size:10px;letter-spacing:.28em;color:#7fb069;font-family:var(--mono);display:block;margin-bottom:6px}
.role-switch select{
  background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.1);
}
.role-switch select:focus{box-shadow:none;border-color:var(--accent)}

.nav-list{flex:1;overflow-y:auto;padding:10px 10px 16px}
.nav-section{font-size:10px;letter-spacing:.24em;color:#7fb069;font-family:var(--mono);padding:14px 10px 6px;text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;
  color:#cfe0c7;font-size:13px;cursor:pointer;border:1px solid transparent;
  transition:all .15s ease;
}
.nav-item i{width:18px;text-align:center;color:#7fb069}
.nav-item .epic{font-family:var(--mono);font-size:9.5px;color:rgba(255,255,255,.4);margin-left:auto}
.nav-item:hover{background:rgba(255,255,255,.04);color:#fff}
.nav-item.active{background:rgba(127,176,105,.14);color:#fff;border-color:rgba(127,176,105,.3)}
.nav-item.active i{color:#c8e6a0}

.sidebar-foot{padding:12px 14px;border-top:1px solid rgba(255,255,255,.06)}
.btn-tour{
  background:linear-gradient(135deg,#7fb069,#3f7a3a);color:#fff;border:none;font-weight:600;
  letter-spacing:.05em;
}
.btn-tour:hover{filter:brightness(1.08);color:#fff}
.sys-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;font-family:var(--mono);font-size:10px}
.sys-stats > div{background:rgba(255,255,255,.04);padding:6px 8px;border-radius:6px;display:flex;flex-direction:column}
.sys-stats span{opacity:.5;letter-spacing:.18em}
.sys-stats b{color:#c8e6a0;font-size:12px}

/* ===== Main ===== */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  position:sticky;top:0;z-index:5;
  display:flex;align-items:center;gap:18px;
  padding:12px 22px;
  background:rgba(225,235,226,.85);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.topbar-left{display:flex;align-items:center;gap:10px;min-width:0}
.crumb{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.crumb #crumb-page{color:var(--secondary);font-weight:600}
.topbar-mid{flex:1;display:flex;justify-content:center}
.ticker{
  font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;
  background:#fff;border:1px solid var(--line);padding:6px 14px;border-radius:99px;
  display:flex;align-items:center;gap:8px;color:var(--ink-soft);
  max-width:60ch;overflow:hidden;white-space:nowrap;
}
.ticker i{color:var(--accent);animation:blink 1.4s infinite}
.topbar-right{display:flex;align-items:center;gap:10px}
.kpi-mini{
  display:flex;align-items:center;gap:6px;
  background:#fff;border:1px solid var(--line);padding:6px 10px;border-radius:99px;
  font-size:12px;font-family:var(--mono);
}
.kpi-mini i{color:var(--primary)}
.kpi-mini b{color:var(--secondary)}
.icon-btn{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:10px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;
  color:var(--secondary);cursor:pointer;
}
.icon-btn:hover{background:var(--surface-2)}
.badge-dot{
  position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;
  font-size:10px;line-height:1;padding:3px 5px;border-radius:99px;font-family:var(--mono);
}
.user-chip{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:99px;padding:4px 12px 4px 4px}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.user-chip .meta{display:flex;flex-direction:column;line-height:1.1}
.user-chip b{font-size:12px}
.user-chip span{font-size:10.5px;color:var(--muted)}

.view{padding:22px;flex:1}

.footer{
  display:flex;justify-content:space-between;gap:10px;
  padding:12px 22px;border-top:1px solid var(--line);color:var(--muted);
  font-size:11.5px;
}
.footer .mono{font-family:var(--mono);letter-spacing:.1em}

/* ===== Cards & components ===== */
.card-l{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.card-l .card-l-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:14px 16px;border-bottom:1px solid var(--line);
}
.card-l .card-l-head h6{margin:0;font-weight:700;font-size:13px;letter-spacing:.04em;color:var(--secondary);display:flex;align-items:center;gap:8px}
.card-l .card-l-head h6 i{color:var(--primary)}
.card-l .card-l-head .tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase}
.card-l .card-l-body{padding:16px}

.section-title{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  margin:0 0 16px;
}
.section-title h3{margin:0;font-size:22px;font-weight:700;letter-spacing:-.01em;color:var(--secondary)}
.section-title .lead{color:var(--muted);font-size:13px;margin-top:2px}
.section-title .tag-mono{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;color:var(--primary);text-transform:uppercase;background:#fff;border:1px solid var(--line);padding:5px 10px;border-radius:99px}

.kpi-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;position:relative;overflow:hidden;box-shadow:var(--shadow);
}
.kpi-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--primary);
}
.kpi-card.alt::before{background:var(--accent)}
.kpi-card.warn::before{background:var(--warn)}
.kpi-card.dn::before{background:var(--danger)}
.kpi-card .kpi-label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-family:var(--mono)}
.kpi-card .kpi-value{font-size:30px;font-weight:700;color:var(--secondary);margin-top:6px;line-height:1}
.kpi-card .kpi-foot{display:flex;align-items:center;gap:10px;margin-top:10px;font-size:12px;color:var(--muted)}
.kpi-card .delta{font-family:var(--mono);font-size:11px;padding:2px 7px;border-radius:99px;background:rgba(63,122,58,.1);color:var(--good)}
.kpi-card .delta.dn{background:rgba(168,50,50,.1);color:var(--danger)}
.kpi-card .spark{position:absolute;right:10px;top:10px;width:90px;height:36px;opacity:.85}

.btn-primary-ls{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-primary-ls:hover{background:var(--secondary);border-color:var(--secondary);color:#fff}
.btn-outline-ls{background:#fff;border:1px solid var(--line);color:var(--secondary)}
.btn-outline-ls:hover{background:var(--surface-2);border-color:var(--line-strong)}
.btn-ghost{background:transparent;border:1px dashed var(--line-strong);color:var(--ink-soft)}

.chip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-family:var(--mono);letter-spacing:.05em;padding:3px 8px;border-radius:99px;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);text-transform:uppercase}
.chip.good{background:rgba(63,122,58,.1);color:var(--good);border-color:rgba(63,122,58,.25)}
.chip.warn{background:rgba(201,138,24,.12);color:var(--warn);border-color:rgba(201,138,24,.3)}
.chip.bad{background:rgba(168,50,50,.1);color:var(--danger);border-color:rgba(168,50,50,.3)}
.chip.info{background:rgba(47,107,143,.1);color:var(--info);border-color:rgba(47,107,143,.3)}

.progress-l{height:8px;background:var(--surface-2);border-radius:99px;overflow:hidden}
.progress-l > div{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent));border-radius:99px;transition:width 1.2s cubic-bezier(.2,.8,.2,1)}

table.lstable{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
table.lstable th{
  text-align:left;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-family:var(--mono);font-weight:600;
  padding:10px 12px;background:var(--surface-2);border-bottom:1px solid var(--line);
}
table.lstable td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
table.lstable tr:hover td{background:var(--surface-2)}
table.lstable td .mono{font-family:var(--mono);font-size:12px;color:var(--ink-soft)}

.timeline{position:relative;padding-left:20px}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:var(--line)}
.timeline .ev{position:relative;padding:0 0 14px 14px}
.timeline .ev::before{content:"";position:absolute;left:-18px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px rgba(53,78,51,.15)}
.timeline .ev .when{font-family:var(--mono);font-size:10.5px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.timeline .ev .what{font-size:13px;color:var(--ink)}

/* HUD frame for charts */
.hud-frame{position:relative}
.hud-frame::before,.hud-frame::after{
  content:"";position:absolute;width:14px;height:14px;border:1px solid var(--primary);
}
.hud-frame::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.hud-frame::after{bottom:-1px;right:-1px;border-left:none;border-top:none}

/* Map */
.map-wrap{height:380px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line)}
.leaflet-container{background:#dfeadc !important;font-family:Inter,sans-serif}
.leaflet-popup-content-wrapper{border-radius:10px}

/* Drawer */
.drawer{
  position:fixed;top:0;right:-420px;height:100vh;width:400px;max-width:90vw;
  background:#fff;border-left:1px solid var(--line);box-shadow:-12px 0 40px rgba(16,39,8,.15);
  z-index:50;display:flex;flex-direction:column;transition:right .25s ease;
}
.drawer.open{right:0}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--line)}
.drawer-body{padding:10px;overflow-y:auto;flex:1}
.notif-item{padding:12px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:var(--surface-2);display:flex;gap:10px}
.notif-item .ic{width:34px;height:34px;border-radius:9px;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--primary);flex-shrink:0}
.notif-item .ic.warn{color:var(--warn)}
.notif-item .ic.bad{color:var(--danger)}
.notif-item .meta{flex:1;min-width:0}
.notif-item .meta b{font-size:13px;display:block}
.notif-item .meta p{margin:2px 0 4px;font-size:12px;color:var(--muted)}
.notif-item .meta .when{font-family:var(--mono);font-size:10px;color:var(--muted);letter-spacing:.1em}

/* Toasts */
.toast-stack{position:fixed;bottom:18px;right:18px;z-index:80;display:flex;flex-direction:column;gap:8px}
.toast-l{
  background:#fff;border:1px solid var(--line);border-left:4px solid var(--primary);
  border-radius:10px;padding:10px 14px;min-width:280px;max-width:380px;
  box-shadow:0 10px 30px -12px rgba(16,39,8,.2);
  animation:slideIn .25s ease;
}
.toast-l b{font-size:13px;display:block}
.toast-l p{margin:2px 0 0;font-size:12px;color:var(--muted)}
@keyframes slideIn{from{transform:translateX(20px);opacity:0}}

/* Calendar */
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal .cal-h{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;padding:6px}
.cal .cal-d{
  background:var(--surface);border:1px solid var(--line);border-radius:8px;min-height:78px;padding:6px;
  position:relative;font-size:11px;
}
.cal .cal-d.muted{opacity:.4}
.cal .cal-d .day{font-family:var(--mono);font-size:11px;color:var(--muted)}
.cal .cal-d.today{border-color:var(--primary);box-shadow:inset 0 0 0 1px var(--primary)}
.cal .cal-d .ev{
  display:block;font-size:10.5px;background:rgba(127,176,105,.15);color:var(--secondary);
  padding:2px 5px;border-radius:5px;margin-top:3px;border-left:3px solid var(--primary);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;
}
.cal .cal-d .ev.training{background:rgba(47,107,143,.12);border-left-color:var(--info)}
.cal .cal-d .ev.monitor{background:rgba(201,138,24,.14);border-left-color:var(--warn)}

/* Step list / report card */
.step{display:flex;gap:12px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#fff;margin-bottom:8px}
.step .num{width:30px;height:30px;border-radius:8px;background:var(--surface-2);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--primary);flex-shrink:0;font-family:var(--mono)}

/* AI panel */
.ai-panel{
  background:linear-gradient(135deg, rgba(53,78,51,.06), rgba(127,176,105,.1));
  border:1px solid var(--line);border-radius:var(--radius);padding:16px;
  position:relative;overflow:hidden;
}
.ai-panel::before{
  content:"";position:absolute;right:-30px;top:-30px;width:160px;height:160px;
  background:radial-gradient(circle, rgba(127,176,105,.35), transparent 60%);
}
.ai-tag{display:inline-flex;align-items:center;gap:6px;background:var(--secondary);color:#c8e6a0;font-family:var(--mono);font-size:10px;letter-spacing:.2em;padding:3px 9px;border-radius:99px;text-transform:uppercase}
.ai-rec{
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-top:8px;
  display:flex;gap:10px;align-items:flex-start;
}
.ai-rec .pr{font-family:var(--mono);font-size:10px;letter-spacing:.18em;padding:2px 8px;border-radius:99px;background:var(--surface-2);color:var(--ink-soft);text-transform:uppercase;flex-shrink:0}
.ai-rec.high .pr{background:rgba(168,50,50,.1);color:var(--danger)}
.ai-rec.med .pr{background:rgba(201,138,24,.14);color:var(--warn)}

/* Species cards */
.species-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s ease, box-shadow .2s ease;
}
.species-card:hover{transform:translateY(-3px);box-shadow:0 16px 40px -18px rgba(16,39,8,.25)}
.species-img{height:120px;background:linear-gradient(135deg,#3f7a3a,#7fb069);position:relative;display:flex;align-items:center;justify-content:center;color:#fff;font-size:42px}
.species-card .body{padding:12px}
.species-card h6{margin:0;font-size:14px;font-weight:700;color:var(--secondary)}
.species-card .latin{font-size:11px;color:var(--muted);font-style:italic;font-family:var(--mono)}
.species-card .stats{display:flex;justify-content:space-between;margin-top:10px;font-size:11px;color:var(--muted)}
.species-card .stats b{color:var(--secondary);font-family:var(--mono)}
.species-card .price{font-size:18px;font-weight:700;color:var(--primary);margin-top:6px}
.species-card .price small{font-size:11px;font-weight:400;color:var(--muted)}

/* School cards */
.school-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px;display:flex;flex-direction:column;gap:8px;height:100%}
.school-card .ribbon{display:flex;align-items:center;gap:8px}
.school-card .icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center}
.school-card h6{margin:0;font-size:14px;color:var(--secondary)}
.school-card .loc{font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:.05em}
.school-card .stat-row{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-top:4px}
.school-card .stat-row b{color:var(--secondary);font-family:var(--mono);font-size:12px}

/* Photo strip */
.photo-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.photo-strip .ph{
  aspect-ratio:1;border-radius:8px;background:linear-gradient(135deg,#3f7a3a,#7fb069);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px;
  position:relative;overflow:hidden;
}
.photo-strip .ph::after{
  content:attr(data-label);position:absolute;left:6px;bottom:4px;font-size:9px;font-family:var(--mono);
  letter-spacing:.1em;background:rgba(0,0,0,.4);padding:1px 5px;border-radius:4px;
}

/* Walkthrough highlight pulse */
.walk-target{outline:2px dashed var(--primary);outline-offset:6px;border-radius:8px}

/* Mobile */
@media (max-width: 900px){
  #app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:-280px;width:260px;transition:left .25s ease}
  .sidebar.open{left:0}
  .topbar-mid{display:none}
  .user-chip .meta{display:none}
  .photo-strip{grid-template-columns:repeat(3,1fr)}
}

/* Form polish */
.form-control,.form-select{border-color:var(--line);background:#fff}
.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 .2rem rgba(53,78,51,.15)}

/* Driver.js theme */
.driver-popover{background:#fff;border:1px solid var(--line);box-shadow:0 24px 60px -20px rgba(16,39,8,.3);font-family:Inter}
.driver-popover-title{color:var(--secondary);font-weight:700}
.driver-popover-progress-text{font-family:var(--mono);color:var(--muted)}
.driver-popover-next-btn,.driver-popover-prev-btn{background:var(--primary)!important;color:#fff!important;text-shadow:none!important;border:none!important;font-weight:600!important}
.driver-popover-next-btn:hover{background:var(--secondary)!important}
