/* ============================================================
   PiqoGIZ Slim5 — mobile field test-bed
   ------------------------------------------------------------
   Goals:
   - Fast, touch-friendly, no-scroll-jank
   - Unified add/edit flow: draw point/line/area → choose what to create
   - Modular JS (public/js/sim5)
   ============================================================ */

/* ---- Icon scale tokens: change --mm-icon-font (or cardIconSize pref) to resize all card icons ---- */
:root {
  --mm-icon-font:   22px;  /* emoji/glyph size — box = font + (--mm-icon-pad * 2) */
  --mm-icon-pad:    4px;   /* tight inner padding so box hugs the icon */
  --mm-icon-radius: 8px;   /* box corner radius */
}

/* ---- Reset & Shell ---- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;-webkit-tap-highlight-color:transparent}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:#f0f0ea;color:#1a2a1a}
#app{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;margin:0 auto;position:relative}

/* ---- Auth Overlay ---- */
@keyframes ao-autofill-detect{from{opacity:0.99}to{opacity:1}}
#authOverlay{position:fixed;inset:0;background:linear-gradient(160deg,#1a3a1a 0%,#2d5a2d 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;padding:28px 24px;
  z-index:9999;color:#fff}
#authOverlay.hidden{display:none}
.ao-inner{width:100%;max-width:380px;display:flex;flex-direction:column}
.ao-form,.ao-token-row,#aoRegPanel,.ao-err,.ao-or,.ao-toggle-reg{width:min(100%,380px)}
#aoLoginForm,#aoRegPanel,#aoShowRegBtn{max-width:380px;width:100%}
.ao-logo{font-size:52px;margin-bottom:6px}
.ao-brand{font-size:26px;font-weight:800;letter-spacing:-0.5px}
.ao-tagline{font-size:13px;opacity:0.72;margin-bottom:28px;text-align:center;line-height:1.5}
.ao-input{width:100%;padding:13px 16px;border:none;border-radius:14px;font-size:16px;margin-bottom:10px;
  background:rgba(255,255,255,0.15);color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.ao-input::placeholder{color:rgba(255,255,255,0.5)}
.ao-input:focus{outline:none;background:rgba(255,255,255,0.25)}
.ao-btn{width:100%;padding:14px;background:#fff;color:#2d5a2d;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer}
.ao-or{font-size:12px;opacity:0.55;text-align:center;margin:10px 0}
.ao-token-row{display:flex;gap:8px}
.ao-token-row .ao-input{margin-bottom:0;flex:1}
.ao-token-btn{padding:13px 16px;background:rgba(255,255,255,0.2);color:#fff;border:1px solid rgba(255,255,255,0.3);
  border-radius:14px;font-size:14px;cursor:pointer;white-space:nowrap}
.ao-err{color:#ffaaaa;font-size:13px;text-align:center;min-height:20px;margin-top:10px}
.ao-form{display:flex;flex-direction:column}
.ao-input:-webkit-autofill,.ao-input:-webkit-autofill:focus{
  -webkit-box-shadow:0 0 0 100px rgba(255,255,255,0.15) inset;
  -webkit-text-fill-color:#fff}

/* ---- Header ---- */
.slim-header{display:flex;align-items:center;gap:10px;padding:10px 14px;padding-top:calc(10px + env(safe-area-inset-top));
  background:#2d5a2d;color:#fff;flex-shrink:0;min-height:54px;flex-wrap:wrap}
.slim-brand-wrap{display:flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap}
.slim-brand-title{font-size:16px;font-weight:900;letter-spacing:-0.02em;white-space:nowrap}
.slim-capture-modes{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.slim-capture-mode-btn{border:1px solid rgba(255,255,255,0.22);background:rgba(255,255,255,0.14);color:#fff;
  border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800;cursor:pointer;line-height:1;white-space:nowrap}
.slim-capture-mode-btn.is-active{background:#fff;color:#244024;border-color:#fff;box-shadow:0 2px 10px rgba(0,0,0,0.15)}
.farm-btn{flex:1;background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.28);color:#fff;
  padding:7px 10px;border-radius:10px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;
  text-align:left;min-width:min(220px,100%)}
.farm-btn-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.farm-btn-chevron{opacity:0.7;flex-shrink:0;font-size:12px}
.slim-avatar{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;flex-shrink:0;cursor:pointer;letter-spacing:-0.5px;user-select:none}
.slim-avatar:active{background:rgba(255,255,255,0.35)}
@media (max-width: 760px){
  .slim-brand-wrap{width:100%;justify-content:space-between}
  .slim-capture-modes{justify-content:flex-end}
  .farm-btn{order:3;flex-basis:calc(100% - 44px)}
}

/* ---- Main ---- */
.slim-main{flex:1;overflow:hidden;position:relative}
.slim-tab{position:absolute;inset:0;overflow-y:auto;display:none;-webkit-overflow-scrolling:touch}
.slim-tab.active{display:block}
#tabMap{overflow:hidden}

/* ---- Content pane (wraps all non-map tabs) ---- */
/* Mobile: fills slim-main; tabMap sits on top of it (DOM order) */
#contentPane{position:absolute;inset:0;overflow:hidden}

/* Pane resizer handle — hidden on mobile */
#paneResizer{display:none}

/* ================================================================
   Wide-pane split layout — two columns above 900 px
   Left: scrollable content tabs  ·  Right: map always visible
   ================================================================ */
@media(min-width:900px){
  /* slim-main becomes a flex row — THIS is the critical display:flex */
  .slim-main{display:flex;flex-direction:row;align-items:stretch}

  /* Left column — position:relative so abs-pos tabs inside it fill it correctly */
  #contentPane{position:relative;inset:auto;width:380px;min-width:0;flex-shrink:0;overflow:hidden}

  /* Drag handle between the two panes */
  #paneResizer{display:block;width:5px;flex-shrink:0;background:#dde8dd;
    cursor:col-resize;position:relative;z-index:20;transition:background .15s}
  #paneResizer:hover,#paneResizer.dragging{background:#2d5a2d}
  /* Extend hit area 6px either side without affecting layout */
  #paneResizer::after{content:'';position:absolute;top:0;bottom:0;left:-6px;right:-6px;cursor:col-resize}
  /* Subtle grip dots */
  #paneResizer::before{content:'';position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%);
    width:3px;height:28px;
    background:repeating-linear-gradient(to bottom,#aac0aa 0,#aac0aa 3px,transparent 3px,transparent 7px);
    border-radius:2px;pointer-events:none}

  /* Right column — always visible; display:block !important overrides .slim-tab display:none */
  #tabMap{flex:1;min-width:0;position:relative;inset:auto;display:block !important;overflow:hidden}

  /* slimMap fills tabMap via absolute positioning (height:100% is unreliable in flex context) */
  #slimMap{position:absolute;inset:0;width:auto;height:auto}

  /* Map nav button is redundant when map is always on screen */
  .slim-nav button[data-tab="tabMap"]{display:none}

  /* Sheets constrained to left column — position:fixed -> absolute so overflow:hidden clips them */
  /* position:fixed children (imgLightbox, newFarmModal, toastEl) still break out to viewport */
  #contentPane .bsheet{position:absolute}
}

/* ---- Map ---- */
#slimMap{width:100%;height:100%}
.photo-marker{width:44px;height:44px;border-radius:10px;overflow:hidden;border:2.5px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,0.35);background:#ddd}
.photo-marker img{width:100%;height:100%;object-fit:cover;display:block}

/* ---- Top-left map layer shortcuts ---- */
#mapLayerControl{position:absolute;top:12px;left:10px;z-index:505;display:flex;flex-direction:column;align-items:flex-start;gap:6px}
#mapLayerToggleBtn{border:1.5px solid #dbe8db;background:#fff;color:#2d5a2d;border-radius:10px;padding:7px 10px;font-size:12px;font-weight:800;cursor:pointer;box-shadow:0 1px 8px rgba(0,0,0,0.18)}
#mapLayerToggleBtn:active{background:#f1f8f1}
#mapLayerPanel{min-width:190px;background:rgba(255,255,255,0.96);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);border:1px solid #dce8dc;border-radius:12px;padding:8px;box-shadow:0 4px 16px rgba(0,0,0,0.2)}
.mlc-chip{display:inline-flex;align-items:center;justify-content:center;border:1px solid #d7e3d7;background:#fff;color:#516351;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;line-height:1.2;margin:0 6px 6px 0}
.mlc-chip.active{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d;font-weight:800}
#mapLayerMoreBtn{display:block;width:100%;border:1px solid #d7e3d7;background:#fff;color:#2d5a2d;border-radius:9px;padding:7px 9px;font-size:12px;font-weight:700;cursor:pointer;line-height:1.2}
#mapLayerMoreBtn:active{background:#f2f8f2}

@media(min-width:900px){
  #mapLayerControl{top:14px;left:12px}
}

/* ---- Floating draw toolbar (Map) ---- */
#mapDrawTools{position:absolute;bottom:calc(86px + env(safe-area-inset-bottom));left:10px;z-index:400;display:flex;flex-direction:column;gap:6px}
.mdt-btn{width:40px;height:40px;border-radius:11px;background:#fff;border:1.5px solid #ddd;font-size:17px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;box-shadow:0 1px 8px rgba(0,0,0,0.18);-webkit-tap-highlight-color:transparent;color:#555}
.mdt-btn.active{background:#f0f7f0;border-color:#2d5a2d;color:#2d5a2d;box-shadow:0 0 0 2px #c8e8a8}

/* ---- Map Banners ---- */
#drawBanner{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:510;background:#1a6a3a;color:#fff;
  border-radius:14px;padding:9px 14px;display:none;align-items:center;gap:8px;box-shadow:0 2px 12px rgba(0,0,0,0.3);
  max-width:calc(100vw - 28px)}
#drawBanner.show{display:flex}
#drawBanner span{font-size:12px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#drawBanner button{background:rgba(255,255,255,0.25);border:none;color:#fff;border-radius:8px;padding:5px 9px;font-size:12px;font-weight:700;
  cursor:pointer;flex-shrink:0}
#drawBanner .draw-done-btn{background:rgba(255,255,255,0.4)}

#moveBanner{position:absolute;top:12px;left:50%;transform:translateX(-50%);z-index:510;background:#f0a800;color:#fff;border-radius:14px;
  padding:10px 16px;font-size:13px;font-weight:700;display:none;align-items:center;gap:10px;box-shadow:0 2px 12px rgba(0,0,0,0.3);
  white-space:nowrap;max-width:90vw}
#moveBanner.show{display:flex}
#moveBannerCancel{background:rgba(255,255,255,0.3);border:none;border-radius:8px;color:#fff;font-size:12px;font-weight:700;padding:4px 10px;cursor:pointer}

/* ---- Date Bar (always visible) ---- */
.date-bar{background:#fff;border-top:1px solid #e8e8e0;padding:6px 14px 6px;flex-shrink:0}
.date-search-row{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.date-search-row input{flex:1;border:1.5px solid #e8e8e0;border-radius:8px;padding:5px 10px;font-size:13px;color:#1a2a1a;background:#f8f8f4;
  -webkit-appearance:none}
.date-search-row input:focus{outline:none;border-color:#2d5a2d}
.date-search-row input::placeholder{color:#ccc}
.date-search-icon{font-size:15px;flex-shrink:0;color:#aaa}

.paddock-filter-btn{border:1.5px solid #e8e8e0;background:#f8f8f4;color:#2d5a2d;border-radius:10px;padding:6px 10px;font-size:12px;font-weight:700;
  cursor:pointer;white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}
.paddock-filter-btn:active{background:#f0f7f0}

.range-row{display:flex;flex-direction:column;gap:6px}
.range-line{display:flex;align-items:center;gap:8px}
.range-label{font-size:11px;color:#aaa;font-weight:700;min-width:52px;text-transform:uppercase;letter-spacing:0.6px}

.pgz-range{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:2px;outline:none;cursor:pointer;background:#e8e8e0}
.pgz-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#2d5a2d;cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,0.25);border:2.5px solid #fff}
.pgz-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2d5a2d;cursor:pointer;border:2.5px solid #fff}

.date-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.date-meta-edge{font-size:10px;color:#ccc}
#dateLabel{font-size:11px;color:#4a7c4e;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:78%}

/* Legacy template compatibility: hide old always-visible slider/date rows.
  New compact filter panel still shows these controls inside `.mf-panel`. */
.date-bar > .range-row,
.date-bar > .date-meta{display:none}

/* ---- Compact map filter UI ---- */
.mf-compact-row{display:flex;align-items:center;gap:8px}
.mf-range-pill{flex:1;min-width:0;font-size:12px;font-weight:700;color:#2d5a2d;background:#f8fbf8;border:1px solid #dce8dc;border-radius:999px;padding:7px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mf-icons{display:flex;gap:4px;align-items:center;min-height:28px;max-width:120px;overflow:hidden}
.mf-icon{font-size:13px;background:#eef5ee;border:1px solid #d7e3d7;color:#2d5a2d;border-radius:999px;padding:4px 7px;line-height:1;white-space:nowrap}
.mf-toggle-btn{border:1.5px solid #dbe8db;background:#fff;color:#2d5a2d;border-radius:10px;padding:7px 10px;font-size:12px;font-weight:800;cursor:pointer;white-space:nowrap}
.mf-menu-toggle{padding:7px 0;min-width:36px;width:36px;text-align:center}
.mf-menu-toggle.active{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d}
.mf-panel{margin-top:8px;border:1px solid #e7eee7;border-radius:12px;padding:10px;background:#fbfdfb;max-height:58vh;overflow:auto}
.mf-nav-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.mf-nav-btn{border:1px solid #d7e3d7;background:#fff;color:#2e3f2e;border-radius:10px;padding:8px 6px;font-size:12px;font-weight:700;cursor:pointer}
.mf-nav-btn:active{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d}
.mf-section{padding-bottom:10px;margin-bottom:10px;border-bottom:1px solid #eef3ee}
.mf-section:last-child{border-bottom:none;margin-bottom:6px;padding-bottom:0}
.mf-sec-title{font-size:11px;text-transform:uppercase;letter-spacing:0.5px;color:#7d8f7d;font-weight:900;margin-bottom:6px}
.mf-toggle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 10px}
.mf-toggle-grid label{font-size:12px;color:#2e3f2e;display:flex;gap:6px;align-items:center}
.mf-search{margin-bottom:6px}
.mf-list{max-height:140px;overflow:auto;border:1px solid #e3ece3;border-radius:10px;background:#fff}
.mf-row{display:block;width:100%;border:none;background:#fff;text-align:left;padding:9px 11px;font-size:12px;color:#234;border-bottom:1px solid #f1f4f1;cursor:pointer}
.mf-row:last-child{border-bottom:none}
.mf-row.sel{background:#ecf8ec;color:#1d5a1d;font-weight:700}
.mf-types{display:flex;flex-wrap:wrap;gap:6px}
.mf-type-chip{border:1px solid #d7e3d7;background:#fff;border-radius:999px;padding:5px 9px;font-size:12px;cursor:pointer}
.mf-type-chip.sel{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d;font-weight:700}
.mf-actions{display:flex;gap:8px;margin-top:4px}
.mf-actions .btn-ghost,.mf-actions .btn-primary{margin:0;flex:1}

/* ---- Bottom Nav ---- */
.slim-nav{
  display:flex;
  align-items:stretch;
  background:#fff;
  border-top:1px solid #e8e8e0;
  flex-shrink:0;
  min-height:58px;
  padding-bottom:env(safe-area-inset-bottom);
  position:relative;
  z-index:450
}
.slim-nav button{
  flex:1;
  min-width:0;
  min-height:58px;
  padding:8px 2px 8px;
  background:none;
  border:none;
  font-size:10px;
  color:#6d786d;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:2px;
  letter-spacing:0.2px;
  text-transform:uppercase;
  font-weight:700;
  transition:color 0.1s;
  -webkit-tap-highlight-color:transparent;
  line-height:1.05;
  -webkit-text-fill-color:currentColor;
  opacity:1
}
.slim-nav button .ni{
  width:24px;
  min-width:24px;
  height:24px;
  min-height:24px;
  margin:0 auto 2px;
  font-size:20px;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  vertical-align:top;
  position:relative;
  font-family:'Noto Color Emoji','Twemoji Mozilla','Segoe UI Emoji','Apple Color Emoji','Noto Emoji',sans-serif
}
@supports (-moz-appearance:none){
  /* Firefox glyph fallback badge only; dock layout is class-driven below. */
  .slim-nav button .ni::after{
    content:attr(data-fallback);
    position:absolute;
    right:-3px;
    bottom:-9px;
    font-size:8px;
    line-height:1;
    font-weight:800;
    color:#435543;
    background:rgba(255,255,255,0.88);
    border:1px solid #d9e2d9;
    border-radius:8px;
    padding:1px 3px;
    font-family:'Segoe UI',sans-serif;
    letter-spacing:0.2px;
  }
  .slim-nav .nav-add .ni::after{
    content:'';
    display:none;
  }
}
.slim-nav button.active{color:#2d5a2d}
.slim-nav .nav-add .ni{
  background:#2d5a2d;
  color:#fff;
  border-radius:50%;
  width:34px;
  min-width:34px;
  height:34px;
  min-height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  margin:0 auto
}
.slim-nav .nav-add:active .ni{background:#1a3a1a}

/* ---- Mobile nav dock (script-enabled) ---- */
body.nav-dock-enabled #app{height:100vh;min-height:100vh}

body.nav-dock-enabled .slim-nav-spacer{
  flex:0 0 auto;
  height:calc(58px + env(safe-area-inset-bottom));
}

body.nav-dock-enabled.nav-dock-collapsed .slim-nav-spacer{
  height:calc(14px + env(safe-area-inset-bottom));
}

body.nav-dock-enabled .slim-tab{padding-bottom:8px}

body.nav-dock-enabled .slim-nav{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:2200;
  min-height:58px;
  justify-content:flex-start;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  scroll-snap-type:x proximity;
  touch-action:pan-x;
  box-shadow:0 -6px 14px rgba(0,0,0,0.16);
  transition:transform .18s ease;
}

body.nav-dock-enabled .slim-nav::-webkit-scrollbar{display:none}

body.nav-dock-enabled.nav-dock-collapsed .slim-nav{
  transform:translateY(calc(100% - 14px));
}

body.nav-dock-enabled .slim-nav button{
  flex:0 0 62px;
  min-width:62px;
  min-height:56px;
  padding:5px 3px 6px;
  font-size:9px;
  scroll-snap-align:start;
}

body.nav-dock-enabled .slim-nav.is-dragging button{pointer-events:none}

body.nav-dock-enabled .slim-nav button .ni{
  font-size:16px;
  margin-bottom:1px;
}

body.nav-dock-enabled .slim-nav-toggle{
  position:fixed;
  right:10px;
  bottom:calc(60px + env(safe-area-inset-bottom));
  z-index:2210;
  border:1px solid #d3ded3;
  background:rgba(255,255,255,0.96);
  color:#234223;
  border-radius:999px;
  padding:5px 10px;
  font-size:11px;
  font-weight:800;
  line-height:1.1;
  box-shadow:0 3px 10px rgba(0,0,0,0.16);
}

body.nav-dock-enabled.nav-dock-collapsed .slim-nav-toggle{
  bottom:calc(18px + env(safe-area-inset-bottom));
}

/* ---- Rich feed cards ---- */
.fc-card{align-items:flex-start;padding:11px 14px}
.fc-icon{font-size:var(--mm-icon-font);display:flex;align-items:center;justify-content:center}
.fc-icon-photo{width:calc(var(--mm-icon-font) + var(--mm-icon-pad) * 2);height:calc(var(--mm-icon-font) + var(--mm-icon-pad) * 2);border-radius:var(--mm-icon-radius);overflow:hidden;flex-shrink:0;background:#ddd}
.fc-icon-photo img{width:100%;height:100%;object-fit:cover;display:block}
/* Header: type label + entity tag side by side */
.fc-header{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:2px}
.fc-type{font-size:10px;text-transform:uppercase;letter-spacing:0.6px;color:#7d8f7d;font-weight:900;white-space:nowrap}
.fc-entity-tag{font-size:11px;color:#2d5a2d;font-weight:700;background:#eef5ee;border:1px solid #c8e8a8;padding:1px 7px;border-radius:999px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}
/* Optional title */
.fc-title{font-size:13px;font-weight:700;color:#1a2a1a;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Note excerpt */
.fc-note-text{font-size:13px;color:#3a4a3a;line-height:1.45;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
/* Fact pills row */
.fc-facts{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}
.fc-fact{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;background:#f0f0ea;color:#555;white-space:nowrap}
.fc-fact-ok{background:#e6f5e6;color:#1d5a1d}
.fc-fact-warn{background:#fff8e0;color:#7a5500}
.fc-fact-bad{background:#fef0f0;color:#c0392b}
/* Meta: author · time */
.fc-meta{font-size:11px;color:#aaa;line-height:1.2}
/* User tags */
.fc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.fc-tag{background:#eef5ee;color:#4a7c4e;font-size:10px;padding:2px 6px;border-radius:999px;font-weight:600}

/* ---- Feed header (sticky wrapper for list-top + context bar + sel toolbar) ---- */
.feed-header{position:sticky;top:0;z-index:10;background:#fff}
.feed-header .list-top{position:static;border-bottom:none}

/* ---- Feed context bar ---- */
#feedContextBar{padding:0 12px 6px;border-bottom:1px solid #eaeae0}
.feed-top-row{gap:6px;padding:8px 12px 7px}
.feed-title{font-weight:800;font-size:15px;color:#2d5a2d;white-space:nowrap;flex-shrink:0}
.fcb-date-mini{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:700;color:#5f7260;background:#f8fbf8;border:1px solid #dce8dc;border-radius:999px;padding:4px 8px;white-space:nowrap;flex-shrink:0}
.feed-top-row .fcb-types-toggle{padding:4px 8px;font-size:11px;line-height:1.2;flex-shrink:0}
.fcb-gear-btn{border:1px solid #d7e3d7;background:#fff;border-radius:999px;padding:3px 8px;font-size:13px;font-weight:700;color:#516351;cursor:pointer;flex-shrink:0;line-height:1.2}
.fcb-gear-btn:hover,.fcb-gear-btn.active{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d}
.feed-top-row .fcb-search{flex:1;min-width:120px;padding:5px 8px;font-size:13px;margin:0}
.feed-top-row .fcb-count{font-size:11px;min-width:34px;text-align:right;flex-shrink:0}
.feed-top-row #feedSelectBtn,
.feed-top-row #feedRefreshBtn{flex-shrink:0}
.feed-select-toggle.active{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d}
.fcb-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-bottom:6px}
.fcb-badge{display:inline-flex;align-items:center;gap:3px;font-size:12px;font-weight:700;color:#2d5a2d;background:#f3faf3;border:1px solid #c8e8a8;border-radius:999px;padding:4px 9px;cursor:pointer;white-space:nowrap;flex-shrink:0;line-height:1.2}
.fcb-badge-active{background:#e5f5e5}
.fcb-types-toggle{border:1px solid #d7e3d7;background:#fff;border-radius:999px;padding:4px 9px;font-size:11px;font-weight:800;color:#425642;cursor:pointer;white-space:nowrap;line-height:1.2}
.fcb-types-toggle.active{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d}
.fcb-clear{background:none;border:none;font-size:13px;cursor:pointer;color:#2d5a2d;padding:0 0 0 2px;opacity:0.65;line-height:1}
.fcb-clear:hover{opacity:1}
.fcb-settings{background:none;border:none;font-size:12px;font-weight:800;cursor:pointer;color:#8da48d;padding:3px 6px;margin-left:auto;flex-shrink:0;border-radius:999px;border:1px solid #d7e3d7;line-height:1.2}
.fcb-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:6px}
.fcb-chip{border:1px solid #d7e3d7;background:#fff;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;cursor:pointer;color:#516351;white-space:nowrap;line-height:1.3}
.fcb-chip.sel{background:#ecf8ec;border-color:#8fc08f;color:#1d5a1d}
.fcb-chip-hint{display:inline-flex;align-items:center;border:1px dashed #d7e3d7;border-radius:999px;padding:3px 9px;font-size:11px;font-weight:700;color:#7b8f7b;background:#fafdf9;line-height:1.3}
.fcb-search-row{display:flex;align-items:center;gap:6px}
.fcb-search{flex:1;border:1.5px solid #e8e8e0;border-radius:8px;padding:5px 9px;font-size:13px;color:#1a2a1a;background:#f8f8f4;-webkit-appearance:none;outline:none}
.fcb-search:focus{border-color:#2d5a2d}
.fcb-count{font-size:11px;color:#aaa;font-weight:700;white-space:nowrap;flex-shrink:0}
.fcb-quick-drawer{padding-top:6px}
.fcb-date-mini-panel{margin-bottom:6px;padding:10px 12px 8px;border:1px solid #e7eee7;border-radius:12px;background:#fbfdfb;min-width:260px}
.fcb-date-mini-actions{display:flex;gap:6px;margin-top:10px;align-items:center;flex-wrap:wrap}
.fcb-mini-section{padding-bottom:4px;margin-bottom:8px}
.fcb-mini-section+.fcb-mini-section{border-top:1px solid #eef3ee;padding-top:8px}
.fcb-mini-sec-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#7b8f7b;margin-bottom:5px}#fcbTypesCount{font-weight:400;letter-spacing:0;text-transform:none}
.fcb-date-apply,.fcb-date-close{flex:1;border:1px solid #d7e3d7;background:#fff;color:#2d5a2d;border-radius:10px;padding:6px 10px;font-size:12px;font-weight:800;cursor:pointer}
.fcb-date-apply{background:#2d5a2d;color:#fff;border-color:#2d5a2d}
.fcb-date-apply:active{background:#1d4a1d}
.fcb-date-close:active{background:#f3f9f3}

@media(max-width:700px){
  .mf-menu-toggle{min-width:34px;width:34px;padding:6px 0;font-size:11px}
  .mf-nav-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .feed-top-row{gap:4px;padding:7px 10px 6px}
  .feed-title{font-size:14px}
  .fcb-date-mini{font-size:10px;padding:3px 6px}
  .feed-top-row .fcb-types-toggle{padding:3px 7px;font-size:10px}
  .fcb-gear-btn{padding:2px 7px;font-size:12px}
  .feed-top-row .fcb-search{min-width:76px;padding:4px 7px;font-size:12px}
  .feed-top-row .fcb-count{font-size:10px;min-width:28px}
}

/* ---- Feed selection toolbar ---- */
#feedSelToolbar{display:none;align-items:center;gap:6px;padding:7px 10px;background:#edf7ed;border-bottom:2px solid #c8e8a8}
#feedSelToolbar.fst-active{display:flex}
.fst-count{font-size:12px;font-weight:800;color:#1d5a1d;white-space:nowrap;min-width:78px}
.fst-btn{border:1px solid #c0dcc0;background:#fff;color:#2d5a2d;border-radius:8px;padding:5px 10px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
.fst-btn:hover:not(:disabled){background:#f3fbf3}
.fst-btn:disabled{opacity:0.38;cursor:not-allowed}
.fst-action{background:#2d5a2d;color:#fff;border-color:#2d5a2d}
.fst-action:hover:not(:disabled){background:#1d4a1d}
.fst-ai{background:#2d3a6a;color:#fff;border-color:#2d3a6a}
.fst-ai:hover:not(:disabled){background:#1d2a5a}
.fst-delete{background:#b71c1c;color:#fff;border-color:#b71c1c}
.fst-delete:hover:not(:disabled){background:#8b0000}
.fst-cancel{background:none;border:none;color:#999;font-size:16px;padding:4px 6px;cursor:pointer;line-height:1;font-weight:900;margin-left:2px}
.fst-cancel:hover{color:#555}

/* ---- Selected card state (selection mode) ---- */
.fc-selected{background:#f3faf3 !important;border-left:3px solid #2d5a2d !important}
.fc-sel-check{flex-shrink:0;width:20px;text-align:center;line-height:42px;font-size:16px;color:#2d5a2d;cursor:pointer}

/* ---- Lists ---- */
.list-top{padding:10px 16px 8px;font-weight:800;font-size:15px;color:#2d5a2d;background:#fff;position:sticky;top:0;z-index:10;
  display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eaeae0}
.list-top button{background:none;border:none;font-size:18px;cursor:pointer;color:#2d5a2d;padding:0 4px}

.card{padding:13px 16px;background:#fff;border-bottom:1px solid #f0f0e8;display:flex;gap:12px;align-items:flex-start;cursor:pointer;
  transition:background 0.1s;-webkit-tap-highlight-color:transparent}
.card:active{background:#f5f5ee}
.card-icon{width:calc(var(--mm-icon-font) + var(--mm-icon-pad) * 2);height:calc(var(--mm-icon-font) + var(--mm-icon-pad) * 2);border-radius:var(--mm-icon-radius);display:flex;align-items:center;justify-content:center;font-size:var(--mm-icon-font);flex-shrink:0;
  overflow:hidden;background:#f0f0ea}
.card-icon img{width:100%;height:100%;object-fit:cover;display:block}
.card-body{flex:1;min-width:0}
.card-title{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-meta{font-size:12px;color:#aaa;margin-top:3px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:5px}
.card-tag{background:#eef5ee;color:#4a7c4e;font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}

.card-actions{display:flex;gap:4px;align-items:center}
.card-actions button{background:none;border:none;padding:6px 7px;font-size:18px;cursor:pointer;color:#ccc;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;border-radius:8px}
.card-actions button:active{background:#f0f0ea;color:#2d5a2d}

.empty{padding:50px 28px;text-align:center;color:#bbb}
.empty .icon{font-size:44px;margin-bottom:12px}
.empty p{font-size:14px;line-height:1.6;color:#999}

/* ---- Bottom Sheets ---- */
.bsheet{position:fixed;inset:0;z-index:500;display:none;width:100%;margin:0 auto}
.bsheet.show{display:block}
.bsheet-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.45)}
.bsheet-card{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:22px 22px 0 0;padding:16px 20px;padding-bottom:calc(20px + env(safe-area-inset-bottom));
  max-height:82vh;overflow-y:auto;animation:slideUp 0.22s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
/* Bulk-add mode: shrink form to half height on mobile so map is usable */
@media(max-width:899px){
  #formSheet.bulk-active .bsheet-card{max-height:50vh;max-height:50dvh}
  #formSheet.map-assist .bsheet-card{max-height:56vh;max-height:56dvh}
}
/* In bulk mode the backdrop must be gone so the map is fully tappable */
#formSheet.bulk-active .bsheet-backdrop{display:none}
#formSheet.map-assist .bsheet-backdrop{display:none}
/* Pass pointer events through the transparent upper area to the map */
#formSheet.bulk-active{pointer-events:none}
#formSheet.map-assist{pointer-events:none}
#formSheet.bulk-active .bsheet-card{pointer-events:auto}
#formSheet.map-assist .bsheet-card{pointer-events:auto}
/* Bulk add toggle row */
.bulk-toggle-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-top:14px;padding:10px 12px;background:#f4fbf4;border:1.5px solid #c8e8a8;border-radius:12px}
.bulk-toggle-label{display:flex;align-items:flex-start;gap:8px;flex:1;cursor:pointer;-webkit-tap-highlight-color:transparent}
.bulk-toggle-check{width:18px;height:18px;flex-shrink:0;margin-top:1px;accent-color:#2d5a2d;cursor:pointer}
.bulk-toggle-text{font-size:14px;font-weight:900;color:#2d5a2d;white-space:nowrap}
.bulk-toggle-hint{font-size:11px;color:#7aaa7a;line-height:1.4;margin-top:2px}
.bulk-counter{font-size:13px;font-weight:900;color:#2d5a2d;white-space:nowrap;flex-shrink:0;padding-top:2px}
@keyframes slideDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
.bsheet-handle{width:4px;height:4px;background:#e0e0d8;border-radius:2px;margin:0 auto 14px}
.bsheet-title{font-size:17px;font-weight:900;color:#1a2a1a;margin-bottom:14px}
.sheet-close{float:right;background:none;border:none;font-size:24px;cursor:pointer;color:#ccc;line-height:1;margin-top:-4px}

/* Farm picker drops from top */
#farmSheet .bsheet-card{top:0;bottom:auto;border-radius:0 0 22px 22px;padding-top:calc(16px + env(safe-area-inset-top));padding-bottom:16px;animation:slideDown 0.22s ease}
#farmSheet .bsheet-handle{display:none}

/* ---- Form controls ---- */
.slim-field{width:100%;padding:11px 13px;border:1.5px solid #e8e8e0;border-radius:12px;font-size:15px;background:#fff;color:#1a2a1a}
.slim-field:focus{outline:none;border-color:#2d5a2d}
.slim-field::placeholder{color:#ccc}
.slim-select{width:100%;padding:11px 13px;border:1.5px solid #e8e8e0;border-radius:12px;font-size:15px;background:#fff;color:#1a2a1a;appearance:none;-webkit-appearance:none}
.slim-select:focus{outline:none;border-color:#2d5a2d}

/* Searchable select combobox */
.sss-wrap{position:relative}
.sss-trigger{width:100%;padding:11px 13px;border:1.5px solid #e8e8e0;border-radius:12px;font-size:15px;background:#fff;color:#1a2a1a;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:6px}
.sss-trigger:focus{outline:none;border-color:#2d5a2d}
.sss-trigger.open{border-color:#2d5a2d;border-radius:12px 12px 0 0;border-bottom-color:transparent}
.sss-trigger-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sss-arrow{font-size:10px;color:#aaa;flex-shrink:0;transition:transform .15s;line-height:1}
.sss-trigger.open .sss-arrow{transform:rotate(180deg)}
.sss-dropdown{position:absolute;left:0;right:0;z-index:500;background:#fff;border:1.5px solid #2d5a2d;border-top:none;border-radius:0 0 12px 12px;padding:8px 8px 6px;box-shadow:0 6px 20px rgba(0,0,0,0.13)}
.sss-search{margin-bottom:6px}
.sss-list{max-height:200px}

.sec{font-size:11px;text-transform:uppercase;letter-spacing:0.6px;color:#aaa;font-weight:900;margin-bottom:8px;margin-top:16px}
.sec:first-child{margin-top:0}

.btn-primary{width:100%;padding:15px;background:#2d5a2d;color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:800;cursor:pointer;margin-top:16px}
.btn-primary:disabled{opacity:0.4;cursor:not-allowed}
.btn-primary:active:not(:disabled){background:#1a3a1a}
.btn-secondary{padding:12px 16px;background:#f0f6f0;color:#2d5a2d;border:1.5px solid #c8e0c8;border-radius:12px;font-size:14px;font-weight:700;cursor:pointer;margin-top:0}
.btn-secondary:disabled{opacity:0.4;cursor:not-allowed}
.btn-secondary:active:not(:disabled){background:#e0ede0}
/* Farm details form */
.farm-details-form .sec{margin-top:14px;margin-bottom:5px}

.btn-row{display:flex;gap:10px}
.btn-ghost{flex:1;padding:13px;background:#f0f0ea;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;color:#666}
.btn-ghost:active{opacity:0.8}

.status{margin-top:10px;font-size:13px;min-height:18px;text-align:center;color:#4a7c4e;font-weight:700}
.status.err{color:#c0392b}
.status.status-hint{margin-top:8px;font-size:12px;min-height:16px;color:#6e7f6e;font-weight:700}
.status.status-hint.err{color:#b03a2e}
.status-hint-row{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.status-hint-row .status.status-hint{margin-top:0;text-align:left;flex:1;min-height:16px}
.status-hint-reset{border:1px solid #d7e3d7;background:#fff;color:#3e5b3e;border-radius:999px;padding:4px 9px;font-size:11px;font-weight:700;cursor:pointer;line-height:1.2;white-space:nowrap}
.status-hint-reset:active{background:#f2f8f2}
.status-hint-link{border:none;background:none;padding:0;color:#1f6d3a;font-size:12px;font-weight:800;text-decoration:underline;cursor:pointer}
.status-hint-link:active{opacity:.75}

.obs-type-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px}
.obs-type-toggle{border:1px solid #d7e3d7;background:#fff;color:#2d5a2d;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;cursor:pointer;max-width:58%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.obs-type-recent-wrap{margin-top:8px;margin-bottom:2px}
.obs-type-recent-label{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#8aa08a;font-weight:800;margin-bottom:6px}
.obs-type-recent-row{display:flex;gap:6px;flex-wrap:wrap}
.obs-type-recent-btn{border:1px solid #d7e3d7;background:#fff;color:#2d5a2d;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:700;cursor:pointer;line-height:1.2}
.obs-type-recent-btn.sel{background:#eef7ee;border-color:#2d5a2d}

/* ---- Create picker ---- */
.create-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.create-btn{background:#fff;border:2px solid #e8e8e0;border-radius:16px;padding:14px 10px;text-align:center;cursor:pointer;
  -webkit-tap-highlight-color:transparent}
.create-btn:active{transform:scale(0.98)}
.create-ico{font-size:28px;display:block;margin-bottom:6px}
.create-lbl{font-size:12px;color:#2d5a2d;font-weight:900}
.create-sub{font-size:11px;color:#999;margin-top:4px;line-height:1.2}

/* ---- Detail sheet ---- */
.sheet-type-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.sheet-icon{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;overflow:hidden}
.sheet-icon img{width:100%;height:100%;object-fit:cover}
.sheet-title{font-size:17px;font-weight:900;line-height:1.2}
.sheet-sub{font-size:13px;color:#aaa;margin-top:3px}
.sheet-photo-full{width:100%;border-radius:12px;overflow:hidden;margin-top:12px;background:#f0f0ea;position:relative}
.sheet-photo-full img{width:100%;max-height:280px;object-fit:cover;display:block;cursor:zoom-in}
.sheet-photo-full::after{content:'🔍';position:absolute;bottom:8px;right:10px;font-size:18px;pointer-events:none;opacity:0.7}
/* Lightbox */
#imgLightbox{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,0.92);display:none;flex-direction:column;align-items:center;justify-content:center}
#imgLightbox.show{display:flex}
#lbToolbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(0,0,0,0.55);z-index:1}
#lbToolbar button{background:rgba(255,255,255,0.15);border:none;color:#fff;border-radius:8px;padding:6px 12px;font-size:15px;font-weight:700;cursor:pointer}
#lbToolbar a{background:rgba(255,255,255,0.15);border:none;color:#fff;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:700;cursor:pointer;text-decoration:none}
#lbToolbar .lbSpacer{flex:1}
#lbImg{max-width:100vw;max-height:calc(100vh - 56px);object-fit:contain;transform-origin:center center;cursor:grab;user-select:none;-webkit-user-drag:none}
#lbImg.loading{opacity:0.3}
.sheet-payload{background:#f8f8f4;border-radius:12px;padding:12px 14px;margin-top:12px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;white-space:pre-wrap;word-break:break-word;color:#555;max-height:180px;overflow:auto;border:1px solid #eee}
/* Schema-driven field rows (replaces sheet-payload for obs/entity/paddock) */
.sheet-fields{display:flex;flex-direction:column;gap:0;margin-top:12px;border:1px solid #eef0e8;border-radius:12px;overflow:hidden}
.sheet-field{display:flex;align-items:baseline;gap:8px;padding:7px 12px;border-bottom:1px solid #f3f4ee;font-size:13px}
.sheet-field:last-child{border-bottom:none}
.sheet-field-label{font-size:11px;font-weight:700;color:#8da48d;white-space:nowrap;min-width:90px;flex-shrink:0;text-transform:capitalize}
.sheet-field-value{color:#2a3a2a;flex:1;min-width:0;word-break:break-word}
.sheet-field--text{flex-direction:column;align-items:flex-start;gap:3px}
.sheet-field--text .sheet-field-value{font-size:12px;line-height:1.5;color:#555}
.sheet-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.sheet-tag{background:#eef5ee;color:#4a7c4e;font-size:13px;padding:4px 10px;border-radius:999px;font-weight:700}
.sheet-id{margin-top:12px;font-size:11px;color:#ccc;font-family:monospace}
.sheet-actions{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid #f0f0e8}
/* Linked observations in entity/paddock detail */
.linked-obs-row{padding:7px 10px;border-radius:10px;background:#f9f9f5;border:1px solid #edeee6;cursor:pointer;transition:background .12s}
.linked-obs-row:hover{background:#f0f2e8}
.linked-obs-head{display:flex;align-items:center;gap:7px;font-size:13px}
.linked-obs-dot{display:inline-block;width:9px;height:9px;border-radius:50%;flex-shrink:0}
.linked-obs-type{font-weight:700;color:#2d5a2d;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.linked-obs-when{font-size:11px;color:#aaa;flex-shrink:0;white-space:nowrap}
.linked-obs-brief{font-size:11px;color:#888;margin-top:2px;padding-left:16px;font-family:ui-monospace,Menlo,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sa-btn{flex:1;padding:12px 8px;border-radius:12px;font-size:14px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;border:none}
.sa-locate{background:#eef5ff;color:#2d5a2d;border:1.5px solid #cfe2ff}
.sa-move{background:#f0f7f0;color:#2d5a2d;border:1.5px solid #c8e8a8}
.sa-edit{background:#fff8e6;color:#7a5500;border:1.5px solid #ffe3a1}
.sa-delete{background:#fef0f0;color:#c0392b;border:1.5px solid #fcc}
.sa-locate:active{background:#dfefff}
.sa-move:active{background:#ddf0dd}
.sa-edit:active{background:#ffeabf}
.sa-delete:active{background:#fdd8d8}

/* ---- Farm / User picker ---- */
.farm-row{padding:14px 4px;border-bottom:1px solid #f0f0e8;display:flex;align-items:center;gap:12px;cursor:pointer;font-size:15px;font-weight:600;
  -webkit-tap-highlight-color:transparent}
.farm-row.cur{color:#2d5a2d;font-weight:900}
.farm-row .farm-check{margin-left:auto;font-size:18px;opacity:0}
.farm-row.cur .farm-check{opacity:1}
.farm-new-row{padding:14px 4px;display:flex;align-items:center;gap:12px;cursor:pointer;color:#2d5a2d;font-size:15px;font-weight:900;
  -webkit-tap-highlight-color:transparent;margin-top:4px}
.farm-new-row:active{opacity:0.7}

.user-avatar-lg{width:68px;height:68px;border-radius:50%;background:#2d5a2d;color:#fff;font-size:26px;font-weight:900;
  display:flex;align-items:center;justify-content:center;margin:0 auto 10px;letter-spacing:-1px}
.user-name{font-size:18px;font-weight:900;text-align:center;color:#1a2a1a}
.user-email{font-size:13px;color:#aaa;text-align:center;margin-bottom:6px}
.user-stat{font-size:12px;color:#bbb;text-align:center;margin-bottom:18px}
.user-btn{width:100%;padding:13px;border-radius:12px;font-size:15px;font-weight:900;cursor:pointer;border:none;margin-top:10px}
.user-btn.primary{background:#2d5a2d;color:#fff}
.user-btn.danger{background:#fef0f0;color:#c0392b;border:1.5px solid #fcc}
.user-btn:active{opacity:0.85}

#aoRegPanel{display:none;flex-direction:column;gap:10px;margin-top:4px}
#aoRegPanel.show{display:flex}
.ao-toggle-reg{background:transparent;border:1.5px solid rgba(255,255,255,0.3);color:rgba(255,255,255,0.75);border-radius:12px;padding:10px 20px;font-size:13px;font-weight:700;cursor:pointer;margin-top:2px}
.ao-toggle-reg.open{color:#fff;border-color:rgba(255,255,255,0.55)}
#toastEl{position:fixed;bottom:calc(160px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);
  background:rgba(0,0,0,0.72);color:#fff;padding:8px 18px;border-radius:999px;font-size:13px;opacity:0;transition:opacity 0.25s;
  pointer-events:none;z-index:9000;white-space:nowrap;max-width:82vw;text-align:center;overflow:hidden;text-overflow:ellipsis}

/* ---- Drone / Muster placeholder tabs ---- */
.placeholder-tab{display:flex;flex-direction:column;align-items:center;padding:28px 24px;gap:0}
.placeholder-icon{font-size:52px;margin-bottom:10px}
.placeholder-title{font-size:18px;font-weight:800;color:#2d5a2d;margin-bottom:6px}
.placeholder-sub{font-size:13px;color:#aaa;text-align:center;line-height:1.6;margin-bottom:22px;max-width:260px}
.placeholder-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:320px}
.ph-btn{padding:14px 20px;border-radius:14px;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;border:none}
.ph-btn-primary{background:#2d5a2d;color:#fff;opacity:0.55}
.ph-btn-secondary{background:#fff;color:#2d5a2d;border:2px solid #c8e8a8}
.ph-coming{font-size:11px;color:#bbb;text-align:center;margin-top:12px}
.task-placeholder{width:100%;margin-top:14px;max-width:320px}
.task-ph-item{padding:12px 14px;background:#fff;border-radius:12px;margin-bottom:8px;display:flex;align-items:center;gap:12px;opacity:0.35}
.tpi-check{width:20px;height:20px;border-radius:5px;border:2px solid #ccc;flex-shrink:0}
.tpi-title{font-size:13px;font-weight:600;color:#1a2a1a}
.tpi-meta{font-size:11px;color:#aaa;margin-top:2px}

/* ---- Colour + icon pickers ---- */
.colour-picker{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:10px}
.colour-swatch{width:26px;height:26px;border-radius:50%;cursor:pointer;border:3px solid transparent;box-sizing:border-box;transition:transform .12s,border-color .12s}
.colour-swatch:hover{transform:scale(1.12)}
.colour-swatch.sel{border-color:rgba(0,0,0,0.65);transform:scale(1.20)}
.colour-none{background:#f0f0ea;border:2px dashed #ccc !important;display:flex;align-items:center;justify-content:center;font-size:11px;color:#bbb}

.icon-picker{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.icon-opt{width:36px;height:36px;border-radius:10px;border:2px solid #e4e8e0;background:#f9f9f5;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;box-sizing:border-box;transition:border-color .12s,transform .12s,background .12s}
.icon-opt:hover{border-color:#a0bca0;transform:scale(1.10)}
.icon-opt.sel{border-color:#2d5a2d;background:#e8f5e9;transform:scale(1.15)}
.icon-none{font-size:12px;color:#bbb;display:flex;align-items:center;justify-content:center;height:100%;width:100%}

/* ---- Compact meta strip (shared form controls) ---- */
.meta-strip-wrap{margin:8px 0 10px}
.meta-strip{display:flex;gap:6px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px}
.meta-strip::-webkit-scrollbar{height:0}
.meta-chip{border:1.5px solid #dbe6db;background:#f7fbf7;color:#2d5a2d;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:700;white-space:nowrap;cursor:pointer}
.meta-chip:active{background:#edf7ed}
.meta-chip-swatch{display:inline-block;width:12px;height:12px;border-radius:50%;border:1.5px solid rgba(0,0,0,0.35);vertical-align:-1px;margin-right:6px}
.meta-strip-panel{margin-top:6px;padding:8px;border:1px solid #e8efe8;border-radius:12px;background:#fbfdfb}
.meta-panel-section{display:none !important}
.meta-panel-section.active{display:block !important}
.meta-loc-actions{display:flex;gap:6px;flex-wrap:wrap}
.meta-loc-actions button{border:1px solid #d7e3d7;background:#fff;border-radius:10px;padding:6px 10px;font-size:12px;font-weight:700;color:#2d5a2d;cursor:pointer}
.meta-date-preview{font-size:12px;color:#4a7c4e;font-weight:700;margin-bottom:6px}
.meta-mini-picker .colour-swatch{width:22px;height:22px;border-width:2px}
.meta-mini-picker .icon-opt{width:30px;height:30px;font-size:16px;border-radius:8px}
.meta-pick-search{margin-bottom:8px}
.meta-pick-list{max-height:180px;overflow:auto;border:1px solid #e1e9e1;border-radius:10px;background:#fff}
.meta-pick-row{display:block;width:100%;text-align:left;border:none;background:#fff;padding:10px 12px;border-bottom:1px solid #f1f4f1;font-size:13px;color:#234;cursor:pointer}
.meta-pick-row:last-child{border-bottom:none}
.meta-pick-row:active{background:#f3f9f3}
.meta-pick-row.sel{background:#ecf8ec;color:#1d5a1d;font-weight:700}

/* ---- Observation type compact buttons ---- */
.obs-type-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin-bottom:8px}
.obs-type-btn{background:#fff;border:1.5px solid #e8e8e0;border-radius:12px;padding:7px 4px 6px;text-align:center;cursor:pointer}
.obs-type-btn.sel{border-color:#2d5a2d;background:#f3faf3}
.obs-type-ico{font-size:16px;display:block;line-height:1.1;margin-bottom:2px}
.obs-type-lbl{font-size:10px;font-weight:700;color:#516351;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ---- AI analysis ---- */
.ai-sel-summary{font-size:13px;font-weight:700;color:#2d5a2d;margin-bottom:12px}
.ai-section-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#7a9a7a;margin-bottom:8px}
.ai-type-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:8px}
.ai-type-card{background:#fff;border:1.5px solid #e0e8e0;border-radius:14px;padding:10px 6px 8px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}
.ai-type-card.selected{border-color:#2d5a2d;background:#f2fbf2}
.ai-type-card:active{background:#edf7ed}
.ai-type-icon{font-size:22px;display:block;margin-bottom:4px;line-height:1}
.ai-type-label{font-size:11px;font-weight:700;color:#334;display:block;line-height:1.2}
.ai-include-images-row{margin:12px 0 8px;display:flex;align-items:center}
.ai-toggle-label{display:flex;align-items:center;gap:8px;font-size:13px;color:#334;cursor:pointer}
.ai-toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:#2d5a2d;cursor:pointer}
/* AI job list */
.ai-job-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #f0f4f0;cursor:pointer;gap:8px}
.ai-job-row:active{background:#f3faf3}
.ai-del-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px 6px;border-radius:6px;opacity:0.45;flex-shrink:0;line-height:1}
.ai-del-btn:hover{opacity:1;background:#fdecea}
.ai-job-left{display:flex;align-items:center;gap:10px;min-width:0}
.ai-job-icon{font-size:22px;flex-shrink:0}
.ai-job-info{min-width:0}
.ai-job-name{font-size:14px;font-weight:700;color:#1a2a1a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ai-job-meta{font-size:11px;color:#7a8a7a;margin-top:2px}
.ai-job-right{flex-shrink:0}
/* Status badges */
.ai-status-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;display:inline-block}
.ai-badge-queued{background:#f5f0e8;color:#8a6a2a}
.ai-badge-running{background:#e8f0ff;color:#2a4aaa;animation:ai-pulse 1.2s infinite}
.ai-badge-done{background:#e8f8e8;color:#1a5a1a}
.ai-badge-error{background:#fce8e8;color:#aa2a2a}
@keyframes ai-pulse{0%,100%{opacity:1}50%{opacity:.5}}
/* Result sheet */
.ai-meta-row{display:flex;flex-wrap:wrap;gap:6px;font-size:11px;color:#7a8a7a;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid #f0f4f0}
.ai-meta-model{background:#f0f4f0;padding:2px 7px;border-radius:99px;font-weight:700}
.ai-meta-tokens{background:#f0f4f0;padding:2px 7px;border-radius:99px}
.ai-narrative{font-size:14px;line-height:1.65;color:#1a2a1a}
.ai-narrative h2{font-size:17px;font-weight:800;margin:18px 0 8px}
.ai-narrative h3{font-size:15px;font-weight:800;margin:14px 0 6px}
.ai-narrative h4{font-size:13px;font-weight:800;margin:12px 0 4px}
.ai-narrative ul{padding-left:18px;margin:6px 0}
.ai-narrative li{margin-bottom:4px}
.ai-narrative p{margin:0 0 10px}
.ai-stub-banner{background:#fff8e0;border:1px solid #e8d870;border-radius:10px;padding:8px 12px;font-size:12px;color:#7a6010;margin-bottom:12px}
.ai-task-created{font-size:13px;color:#2d5a2d;font-weight:700;margin-top:12px;padding:10px;background:#f2fbf2;border-radius:10px}
.ai-error-wrap{text-align:center;padding:32px 0}
.ai-error-icon{font-size:36px;margin-bottom:8px}
.ai-error-msg{font-size:14px;color:#c0392b}
/* Running / spinner */
.ai-running-wrap{text-align:center;padding:40px 0}
.ai-running-label{font-size:15px;font-weight:700;color:#334;margin-top:16px}
.ai-running-sub{font-size:12px;color:#888;margin-top:6px}
.ai-spinner{width:40px;height:40px;border:4px solid #e0ece0;border-top-color:#2d5a2d;border-radius:50%;animation:ai-spin .8s linear infinite;margin:0 auto}
@keyframes ai-spin{to{transform:rotate(360deg)}}
/* AI result actions row */
.ai-result-actions{display:flex;gap:8px;margin-top:12px}
.ai-result-actions .btn-ghost{flex:1;padding:10px 8px;font-size:13px;text-align:center}
/* Conversation section in AI tab */
.ai-conv-section-header{font-size:12px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.6px;padding:14px 0 6px}
.ai-conv-preview{font-size:11px;color:#999;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px;text-align:right;padding-left:6px}
.ai-conv-row .ai-job-right{align-self:center}
/* AI debug log collapsible */
.ai-debug-details{margin-top:14px;border:1px solid #e0eae0;border-radius:12px;overflow:hidden}
.ai-debug-summary{padding:10px 14px;font-size:12px;font-weight:800;color:#2d5a2d;cursor:pointer;background:#f4fbf4;list-style:none;display:flex;align-items:center;justify-content:space-between;-webkit-user-select:none;user-select:none}
.ai-debug-summary::-webkit-details-marker{display:none}
.ai-debug-summary::after{content:'▼';font-size:10px;color:#7aaa7a;transition:transform .2s}
.ai-debug-details[open] .ai-debug-summary::after{transform:rotate(180deg)}
.ai-debug-toggle-hint{font-size:10px;font-weight:400;color:#aaa;margin-left:8px}
.ai-debug-body{padding:12px 14px;background:#fafff8;overflow-x:auto}
.ai-debug-section-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#7a9a7a;margin-bottom:6px}
.ai-debug-pre{font-family:'SF Mono',Monaco,Consolas,monospace;font-size:10px;line-height:1.5;color:#1a3a1a;white-space:pre-wrap;word-break:break-all;background:#fff;border:1px solid #e8f0e8;border-radius:8px;padding:8px;max-height:300px;overflow-y:auto;margin:0}
/* AI chat sheet — tall card with flex column layout */
#aiChatSheet .bsheet-card.ai-chat-card{max-height:82dvh;max-height:82vh;display:flex;flex-direction:column;overflow-y:hidden;padding-bottom:calc(8px + env(safe-area-inset-bottom))}
/* Make the close × more visible on the chat sheet */
#aiChatSheet .sheet-close{color:#888;font-size:26px}
/* ── AI Debug Sheet ── */
#aiDebugSheet .bsheet-card.ai-debug-sheet-card{max-height:92dvh;max-height:92vh;display:flex;flex-direction:column;overflow-y:hidden;padding-bottom:calc(8px + env(safe-area-inset-bottom))}
.ai-debug-sheet-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-bottom:8px}
.ai-dbg-meta{display:flex;flex-wrap:wrap;gap:5px;padding:2px 0 6px}
.ai-dbg-chip{background:#f0f4f0;border-radius:6px;padding:3px 8px;font-size:11px;color:#444}
.ai-dbg-chip code{font-family:monospace;font-size:11px;color:#1a4a1a}
.ai-dbg-error-banner{background:#fff0f0;border:1px solid #f5c6c6;border-radius:8px;padding:8px 12px;color:#c0392b;font-size:13px;font-weight:600}
.ai-dbg-section{border:1px solid #d8e8d8;border-radius:10px;overflow:hidden;flex-shrink:0}
.ai-dbg-section-hd{display:flex;align-items:center;gap:8px;padding:7px 10px;background:#f2f7f2;font-size:12px;font-weight:700;color:#1a3a1a;border-bottom:1px solid #d8e8d8}
.ai-dbg-section-hd span:first-child{flex:1}
.ai-dbg-charcount{color:#888;font-weight:400;font-size:11px;white-space:nowrap}
.ai-dbg-copy{background:#fff;border:1px solid #c8d8c8;border-radius:6px;padding:2px 8px;font-size:11px;cursor:pointer;color:#444;white-space:nowrap}
.ai-dbg-copy:active{background:#e8f0e8}
.ai-dbg-pre{margin:0;padding:10px 12px;font-size:11px;font-family:'Menlo','Monaco','Courier New',monospace;white-space:pre-wrap;word-break:break-word;max-height:260px;overflow-y:auto;background:#fafbfa;color:#1a2a1a;line-height:1.45}
.ai-dbg-budget{padding:8px 12px;display:flex;flex-direction:column;gap:4px}
.ai-dbg-budget-row{display:flex;justify-content:space-between;font-size:12px;color:#444;padding:3px 0;border-bottom:1px solid #f0f0e8}
.ai-dbg-budget-row span:last-child{font-family:monospace;font-size:11px;color:#1a4a1a}
.ai-dbg-budget-total{font-weight:700;color:#1a2a1a;border-bottom:2px solid #c8d8c8}
/* Debug button in result actions */
.ai-debug-open-btn{font-size:12px;padding:8px 10px}
.ai-chat-messages{flex:1;overflow-y:auto;padding:0 4px 8px;display:flex;flex-direction:column;gap:10px;min-height:80px}
.ai-chat-empty{font-size:13px;color:#aaa;text-align:center;padding:24px 0}
.ai-chat-msg{display:flex;max-width:88%}
.ai-chat-msg--user{align-self:flex-end;flex-direction:row-reverse}
.ai-chat-msg--assistant{align-self:flex-start}
.ai-chat-bubble{padding:10px 13px;border-radius:16px;font-size:14px;line-height:1.55}
.ai-chat-msg--user .ai-chat-bubble{background:#2d5a2d;color:#fff;border-radius:16px 16px 4px 16px}
.ai-chat-msg--user .ai-chat-bubble p{color:#fff;margin:0}
.ai-chat-msg--assistant .ai-chat-bubble{background:#f4f8f4;color:#1a2a1a;border-radius:16px 16px 16px 4px}
.ai-chat-msg--assistant .ai-chat-bubble h2,.ai-chat-msg--assistant .ai-chat-bubble h3,.ai-chat-msg--assistant .ai-chat-bubble h4{margin:8px 0 4px}
.ai-chat-msg--assistant .ai-chat-bubble ul{padding-left:16px;margin:4px 0}
.ai-chat-msg--assistant .ai-chat-bubble li{margin-bottom:3px}
.ai-chat-msg--assistant .ai-chat-bubble p{margin:0 0 6px}
/* Thinking / loading dots */
.ai-chat-thinking{display:flex;align-items:center;gap:5px;padding:12px 16px !important}
.ai-chat-thinking span{width:7px;height:7px;background:#2d5a2d;border-radius:50%;animation:chatDot 1.2s infinite}
.ai-chat-thinking span:nth-child(2){animation-delay:.2s}
.ai-chat-thinking span:nth-child(3){animation-delay:.4s}
@keyframes chatDot{0%,80%,100%{opacity:.2;transform:scale(0.8)}40%{opacity:1;transform:scale(1)}}
/* Chat input row */
.ai-chat-input-row{flex-shrink:0;display:flex;gap:8px;align-items:flex-end;padding-top:10px;border-top:1px solid #f0f4f0;margin-top:4px}
.ai-chat-input{flex:1;padding:10px 12px;border:1.5px solid #e8e8e0;border-radius:14px;font-size:14px;background:#fff;color:#1a2a1a;resize:none;max-height:100px;overflow-y:auto;line-height:1.4}
.ai-chat-input:focus{outline:none;border-color:#2d5a2d}
.ai-chat-send-btn{flex-shrink:0;width:42px;height:42px;border-radius:50%;background:#2d5a2d;color:#fff;border:none;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.ai-chat-send-btn:active{background:#1a3a1a}
.ai-chat-send-btn:disabled{opacity:0.4;cursor:not-allowed}
/* Continue chat button */
.ai-chat-continue-btn{background:#e8f5e8;color:#2d5a2d;border:1.5px solid #c0d8c0}
.ai-chat-continue-btn:active{background:#d0e8d0}
