/* ForestTrack Portal — Forestry Technologies */
:root{
  --bg:#0e1410;--bg2:#141a10;--bg3:#1c2418;
  --border:#2a3825;--border2:#3d5235;
  --text:#e8e8dc;--text2:#a0a898;--text3:#657060;
  --amber:#e8b84b;--green:#52c97a;--red:#e05252;--blue:#5ab4e8;
  --radius:8px;--radius-lg:12px;
  --shadow:0 4px 24px rgba(0,0,0,.4);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);font-size:14px}
/* Suppress the blue highlight flash on tap (iOS/Android) */
html{-webkit-tap-highlight-color:transparent}
/* Disable double-tap zoom on every interactive element so taps feel instant */
button,a,[role="button"],.nav-item,.btn-primary,.btn-secondary,.btn-danger,.btn-ghost,.btn-icon,.btn-sm,label{touch-action:manipulation}

/* ── Screens ─────────────────────────────────────────── */
/* 100dvh (dynamic viewport height) correctly excludes Safari's retractable
   URL bar, preventing the screen from overflowing on first load on iPhone. */
.screen{display:none;height:100dvh}
.screen.active{display:flex}
#login-screen{align-items:center;justify-content:center;background:var(--bg)}
#main-screen{flex-direction:row}

/* ── Login ───────────────────────────────────────────── */
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:380px;display:flex;flex-direction:column;gap:20px}
.login-brand{text-align:center;margin-bottom:8px}
.login-logo{width:64px;height:64px;background:var(--amber);border-radius:var(--radius-lg);font-size:24px;font-weight:800;color:var(--bg);display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}
.login-logo-img{width:220px;height:auto;display:block;margin:0 auto 4px}
.login-brand h1{font-size:26px;color:var(--amber);font-weight:700}
.login-brand p{color:var(--text3);font-size:13px;margin-top:2px}

/* ── Sidebar ─────────────────────────────────────────── */
#sidebar{width:220px;min-width:220px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 0}
.sidebar-brand{display:flex;align-items:center;gap:10px;padding:0 16px 20px}
.brand-logo{width:32px;height:32px;background:var(--amber);border-radius:6px;font-size:12px;font-weight:800;color:var(--bg);display:flex;align-items:center;justify-content:center}
.brand-logo-img{width:32px;height:32px;border-radius:6px;object-fit:cover;flex-shrink:0}
.brand-name{font-size:16px;font-weight:700;color:var(--amber)}
#nav-links{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius);color:var(--text2);cursor:pointer;font-size:13px;transition:.15s}
.nav-item:hover{background:var(--bg3);color:var(--text)}
.nav-item.active{background:rgba(232,184,75,.15);color:var(--amber)}
.nav-item .nav-icon{font-size:16px;width:20px;text-align:center}
.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}
#user-info{font-size:11px;color:var(--text3);margin-bottom:8px}
#user-info strong{color:var(--text2);display:block}

/* ── Content ─────────────────────────────────────────── */
/* -webkit-overflow-scrolling:touch gives iOS momentum/inertia scrolling
   inside the content column (Safari drops it on non-scrollable children). */
#content{flex:1;overflow:auto;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch}
#page-container{flex:1;padding:24px;max-width:1200px;width:100%}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.page-title{font-size:20px;font-weight:600}
.page-subtitle{font-size:12px;color:var(--text3);margin-top:2px}

/* ── Cards ───────────────────────────────────────────── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:16px}
.card-title{font-size:13px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:14px}
.stat-value{font-size:28px;font-weight:700;color:var(--amber)}
.stat-label{font-size:11px;color:var(--text3);margin-top:2px}

/* ── Tables ──────────────────────────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{text-align:left;padding:8px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);border-bottom:1px solid var(--border)}
td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);font-size:13px}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02)}
.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge-green{background:rgba(82,201,122,.15);color:var(--green)}
.badge-red{background:rgba(224,82,82,.15);color:var(--red)}
.badge-amber{background:rgba(232,184,75,.15);color:var(--amber)}
.badge-blue{background:rgba(90,180,232,.15);color:var(--blue)}
.badge-gray{background:var(--bg3);color:var(--text2)}

/* ── Forms ───────────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-group label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.4px}
input,select,textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:9px 12px;font-size:14px;width:100%;outline:none;transition:.15s;font-family:inherit}
input:focus,select:focus,textarea:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(232,184,75,.1)}
input::placeholder{color:var(--text3)}
select option{background:var(--bg2)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
label.checkbox{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2);cursor:pointer;text-transform:none;letter-spacing:0;font-weight:normal}

/* ── Buttons ─────────────────────────────────────────── */
.btn-primary{background:var(--amber);color:var(--bg);border:none;border-radius:var(--radius);padding:9px 18px;font-size:13px;font-weight:600;cursor:pointer;transition:.15s}
.btn-primary:hover{background:#f0c55a}
.btn-secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:9px 18px;font-size:13px;font-weight:500;cursor:pointer;transition:.15s}
.btn-secondary:hover{border-color:var(--border2)}
.btn-danger{background:rgba(224,82,82,.15);color:var(--red);border:1px solid rgba(224,82,82,.3);border-radius:var(--radius);padding:9px 18px;font-size:13px;font-weight:500;cursor:pointer;transition:.15s}
.btn-danger:hover{background:rgba(224,82,82,.25)}
.btn-ghost{background:transparent;color:var(--text2);border:none;padding:6px 10px;font-size:12px;cursor:pointer;border-radius:var(--radius)}
.btn-ghost:hover{background:var(--bg3);color:var(--text)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-icon{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;color:var(--text2);cursor:pointer;font-size:13px}
.btn-icon:hover{border-color:var(--border2);color:var(--text)}
.btn-full{width:100%}
.btn-group{display:flex;gap:8px;flex-wrap:wrap}

/* ── Modals ──────────────────────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;box-shadow:var(--shadow)}
.modal.modal-lg{max-width:760px}
.modal.modal-xl{max-width:1000px}
.modal h3{font-size:17px;font-weight:600;margin-bottom:20px;color:var(--text)}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}
/* Prevent background scroll when modal open; top offset set via JS to preserve position.
   height:100% is required on iOS — without it Safari can still scroll the body. */
body.modal-open{overflow:hidden;position:fixed;width:100%;height:100%}

/* ── Map ─────────────────────────────────────────────── */
.map-container{height:500px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}
.map-container.map-full{height:calc(100dvh - 200px)}
.map-container.map-sm{height:300px}
#map,#tract-map,#overview-map,#session-map{height:100%}
/* dvh avoids overflow when Safari's URL bar is visible */
#om-layout{height:calc(100dvh - 280px)}
/* Dashboard map inline-style override: give more map on small screens */
#dash-map{min-height:300px}

/* ── Filters ─────────────────────────────────────────── */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:16px}
.filter-group{display:flex;flex-direction:column;gap:4px}
.filter-group label{font-size:10px;text-transform:uppercase;color:var(--text3);letter-spacing:.4px}
.filter-group input,.filter-group select{width:auto;min-width:140px}

/* ── Utilities ───────────────────────────────────────── */
.hidden{display:none!important}
.text-amber{color:var(--amber)}
.text-green{color:var(--green)}
.text-red{color:var(--red)}
.text-muted{color:var(--text3)}
.text-sm{font-size:12px}
.text-right{text-align:right}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}
.flex{display:flex}.gap-8{gap:8px}.gap-12{gap:12px}.items-center{align-items:center}
.divider{border:none;border-top:1px solid var(--border);margin:16px 0}
.error-msg{background:rgba(224,82,82,.1);border:1px solid rgba(224,82,82,.3);border-radius:var(--radius);padding:10px 14px;color:var(--red);font-size:13px}
.success-msg{background:rgba(82,201,122,.1);border:1px solid rgba(82,201,122,.3);border-radius:var(--radius);padding:10px 14px;color:var(--green);font-size:13px}
.info-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:14px;font-size:13px;color:var(--text2)}
.code-block{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-family:monospace;font-size:13px;color:var(--amber);word-break:break-all}
.copy-btn{background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:2px 8px;font-size:11px;cursor:pointer;color:var(--text2)}
.copy-btn:hover{color:var(--text)}
.acres-display{font-size:22px;font-weight:700;color:var(--green);margin-bottom:4px}
.acres-label{font-size:11px;color:var(--text3)}

/* ── Real-time indicator ─────────────────────────────── */
.live-dot{width:8px;height:8px;background:var(--green);border-radius:50%;display:inline-block;animation:pulse-dot 1.5s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.live-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(82,201,122,.1);border:1px solid rgba(82,201,122,.3);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;color:var(--green)}

/* ── Toast ───────────────────────────────────────────── */
/* Raise above the home indicator on iPhone (env() is 0 on non-notched) */
#toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));right:max(24px,env(safe-area-inset-right,0px));z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:13px;box-shadow:var(--shadow);animation:toast-in .2s ease;max-width:320px}
.toast-item.toast-success{border-color:var(--green);color:var(--green)}
.toast-item.toast-error{border-color:var(--red);color:var(--red)}
.toast-item.toast-info{border-color:var(--amber);color:var(--amber)}
@keyframes toast-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── Acre polygon breakdown ───────────────────────────── */
.polygon-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.polygon-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg3);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:12px}
.polygon-item .poly-name{color:var(--text2)}
.polygon-item .poly-acres{color:var(--green);font-weight:600}
.polygon-item .poly-pct{color:var(--text3)}

/* ── Scrollbar ───────────────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* ── Mobile Responsive ────────────────────────────────── */
#hamburger{display:none;position:fixed;top:12px;left:12px;z-index:200;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;cursor:pointer;font-size:18px;color:var(--text)}
#sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:149}

/* Map expand button — shown only on mobile */
.map-expand-btn{display:none;position:absolute;top:8px;right:8px;z-index:10;background:rgba(20,26,16,.85);border:1px solid var(--border2);border-radius:var(--radius);padding:5px 9px;color:var(--text2);cursor:pointer;font-size:12px}
.map-container{position:relative}
.map-container.map-fullscreen{position:fixed!important;inset:0!important;z-index:500!important;height:100vh!important;border-radius:0!important;border:none!important}
.map-container.map-fullscreen .map-expand-btn{top:env(safe-area-inset-top,8px)}
.map-collapse-btn{display:none;position:fixed;bottom:16px;left:50%;transform:translateX(-50%);z-index:510;background:rgba(20,26,16,.9);border:1px solid var(--border2);border-radius:20px;padding:7px 18px;color:var(--amber);cursor:pointer;font-size:13px;font-weight:600}
.map-container.map-fullscreen~.map-collapse-btn{display:block}

@media(max-width:768px){
  #hamburger{display:flex;align-items:center;justify-content:center}
  #main-screen{position:relative}
  #sidebar{
    position:fixed;left:-240px;top:0;bottom:0;z-index:150;
    width:240px;transition:left .25s ease;box-shadow:4px 0 20px rgba(0,0,0,.4);
    /* Sidebar scrolls to bottom even behind home indicator */
    padding-bottom:env(safe-area-inset-bottom,0px)
  }
  #sidebar.open{left:0}
  #sidebar-overlay.open{display:block}
  #content{width:100%;padding-top:52px;-webkit-overflow-scrolling:touch}
  #page-container{padding:10px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px))}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr}
  .page-header{flex-direction:column;align-items:flex-start;gap:8px}
  .page-header .btn-group{width:100%}
  .page-header .btn-group .btn-primary,.page-header .btn-group .btn-secondary{flex:1;text-align:center}

  /* ── iOS Safari: prevent auto-zoom on input focus ─────────────────── */
  /* Any input smaller than 16px causes iOS Safari to zoom the viewport in.
     Setting 16px here ensures every form field avoids that behaviour.     */
  input,select,textarea{font-size:16px!important}

  /* ── Modals ──────────────────────────────────────────────────────── */
  .modal{padding:16px;margin:6px;min-width:unset!important}
  .modal.modal-lg,.modal.modal-xl{max-width:100%}
  .modal-footer{flex-wrap:wrap}
  .modal-footer .btn-primary,.modal-footer .btn-secondary,.modal-footer .btn-danger{flex:1;text-align:center;min-width:120px}
  /* Modals that open over the keyboard need extra bottom padding on iPhone */
  .modal{padding-bottom:max(16px,env(safe-area-inset-bottom,0px))}

  /* ── Maps ────────────────────────────────────────────────────────── */
  .map-container{height:360px}
  /* map-full uses dynamic viewport height and accounts for the hamburger bar */
  .map-container.map-full{height:calc(100dvh - 110px)}
  .map-expand-btn{display:block}
  /* Dashboard map inline override */
  #dash-map{height:calc(100dvh - 200px)!important;min-height:260px!important}
  /* Overview map: less wasted vertical space with hamburger-aware top */
  #om-layout{height:calc(100dvh - 160px)!important}
  /* Tract list panel smaller on phone so map gets ~70% of height */
  #tract-list-panel{max-height:120px!important}

  /* ── Filters ─────────────────────────────────────────────────────── */
  .filters{flex-direction:column;align-items:stretch}
  .filter-group input,.filter-group select{width:100%;min-width:unset}
  .filters input{width:100%!important;min-width:unset!important}
  .filters .btn-primary,.filters .btn-secondary{width:100%}
  .card>div>input[type=text],.card>div>input:not([type]){width:100%!important;min-width:unset!important}

  /* ── Tables ──────────────────────────────────────────────────────── */
  table{font-size:12px}
  th,td{padding:5px 7px}

  /* ── Buttons / touch targets ─────────────────────────────────────── */
  .btn-group{flex-wrap:wrap}
  /* Minimum 44px is Apple's HIG recommended touch target */
  .btn-primary,.btn-secondary,.btn-danger,.btn-ghost{min-height:44px}
  .btn-sm{min-height:38px}
  td .btn-sm{padding:7px 10px;min-height:38px}

  /* ── Login ───────────────────────────────────────────────────────── */
  .login-box{padding:20px 16px;margin:12px;width:100%;max-width:400px}
  /* Ensure the Sign In button is large enough to tap comfortably */
  .login-box .btn-primary{min-height:50px;font-size:16px}

  /* ── Misc ────────────────────────────────────────────────────────── */
  .stat-value{font-size:22px}
  .col-hide-mobile{display:none}
  .session-layout{flex-direction:column!important}
  /* Ops panel: keep within screen width on portrait iPhone */
  #ops-panel{max-width:calc(100% - 20px)!important;min-width:unset!important;max-height:40%!important;left:10px!important;right:10px!important}
}

@media(max-width:1024px){
  /* Stack tracts above map; keep explicit height so flex:1 on map wrapper resolves */
  #om-layout{flex-direction:column!important;width:100%;height:calc(100dvh - 280px)}
  #om-map-wrap{width:100%;flex:1;border-radius:0 0 var(--radius-lg) var(--radius-lg)!important}
  #overview-map{width:100%!important;height:100%!important}
  #tract-list-panel{width:100%!important;min-width:0!important;max-height:160px!important;
    border-right:1px solid var(--border)!important;border-bottom:none!important;
    border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;
    /* iOS momentum scroll inside the panel */
    -webkit-overflow-scrolling:touch}
}

@media(max-width:480px){
  .stat-grid{grid-template-columns:1fr}
  #page-container{padding:6px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}
  .map-container{height:300px}
  /* Map containers inside modals shrink so form controls below remain reachable */
  .modal-overlay .map-container,.modal .map-container{height:240px!important}
  /* More map height on small iPhone screens (SE, mini) using dynamic vh */
  .map-container.map-full{height:calc(100dvh - 90px)}
  #dash-map{height:calc(100dvh - 190px)!important;min-height:220px!important}
  #om-layout{height:calc(100dvh - 130px)!important}
  /* Give map ~65% of om-layout with smaller list */
  #tract-list-panel{max-height:90px!important}
  table{font-size:11px}
  .stat-value{font-size:20px}
  /* Full-width bottom-edge modal (like native sheet) on very small screens */
  .modal{margin:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:96dvh;
         padding-bottom:max(16px,env(safe-area-inset-bottom,0px))}
  .modal-overlay{align-items:flex-end}
  /* Any remaining hardcoded-width inputs become full-width */
  input[style*="width:"]{width:100%!important;min-width:unset!important}
  input[type=number][style*="width:"]{width:auto!important}
  input[type=range]{width:100%!important}
  /* Filters in a tighter single column */
  .filter-group{width:100%}
}

/* ── Safe-area insets for notched / Dynamic-Island iPhones ──────── */
/* Top inset: push content and hamburger below the status bar / notch  */
@supports(padding:env(safe-area-inset-top)){
  @media(max-width:768px){
    #content{padding-top:calc(52px + env(safe-area-inset-top))}
    #hamburger{top:calc(12px + env(safe-area-inset-top))}
    /* Sidebar top padding accounts for the notch */
    #sidebar{padding-top:env(safe-area-inset-top,0px)}
  }
}
/* Bottom inset: raise collapse button and toast above the home indicator */
@supports(padding:env(safe-area-inset-bottom)){
  @media(max-width:768px){
    .sidebar-footer{padding-bottom:calc(12px + env(safe-area-inset-bottom,0px))}
    .map-collapse-btn{bottom:calc(16px + env(safe-area-inset-bottom,0px))}
    /* Also keep the map fullscreen collapse reachable */
    .map-container.map-fullscreen .map-collapse-btn{bottom:calc(20px + env(safe-area-inset-bottom,0px))}
  }
}

/* Mapbox popup close button — larger tap target on mobile */
.mapboxgl-popup-close-button{
  font-size:16px!important;width:32px!important;height:32px!important;
  display:flex!important;align-items:center!important;justify-content:center!important;
  touch-action:manipulation
}
/* Mapbox popup content — scrollable on small screens */
.mapboxgl-popup-content{
  max-height:60dvh;overflow-y:auto;-webkit-overflow-scrolling:touch
}

/* Map expand/collapse JS hooks — toggled via portal.js */
.map-container.map-fullscreen #tract-map,
.map-container.map-fullscreen #overview-map,
.map-container.map-fullscreen #session-map,
.map-container.map-fullscreen #map{height:100%!important}
