@import url('https://fonts.googleapis.com/css2?family=Syne:wght@600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600&display=swap');
:root{
  --dark:#062E20;--dark2:#0A3D2A;--dark3:#031A12;
  --green:#1D9E75;--gn2:#0F6E56;--lt:#5DCAA5;--xlt:#9FE1CB;
  --bg:#F0FBF6;--bg2:#E1F5EE;--bg3:#C7EEE0;--white:#fff;
  --text:#062E20;--text2:#0F5A3E;--text3:#3A8A6A;
  --bdr:rgba(29,158,117,.15);--bdr2:rgba(29,158,117,.3);
  --gold:#EF9F27;--red:#E24B4A;--blue:#378ADD;
  --ff:'Plus Jakarta Sans',system-ui,sans-serif;
  --ffh:'Syne',system-ui,sans-serif;
  --sb:220px;--nav-h:62px;--bot-h:64px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;overflow:hidden}
body{font-family:var(--ff);background:var(--bg);color:var(--text);display:flex;flex-direction:column}

/* ─ TOAST ─ */
#toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--dark);color:var(--xlt);padding:10px 20px;border-radius:99px;font-size:13px;font-weight:500;z-index:9999;opacity:0;transition:opacity .25s;pointer-events:none;white-space:nowrap;max-width:90vw;text-align:center}
#toast.show{opacity:1}

/* ─ TOPBAR ─ */
#topbar{background:var(--dark2);padding:0 16px;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0;position:relative;z-index:50}
.tb-left{display:flex;align-items:center;gap:10px}
#menuToggle{background:none;border:none;color:var(--xlt);cursor:pointer;padding:6px;font-size:22px;display:none}
.tb-logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.tb-logo canvas{border-radius:7px;display:block}
.tb-name{font-family:var(--ffh);font-size:17px;font-weight:800;color:var(--xlt)}
.tb-name span{color:var(--lt);font-weight:600}
.tb-right{display:flex;align-items:center;gap:8px}
.tb-user{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--xlt)}
.tb-lang{background:var(--dark3);color:var(--xlt);border:1px solid var(--bdr2);border-radius:8px;padding:5px 6px;font-size:12px;font-family:var(--ff);cursor:pointer}
.tb-role{font-size:10px;background:rgba(29,158,117,.2);border:1px solid rgba(29,158,117,.3);color:var(--lt);padding:2px 7px;border-radius:3px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.tb-btn{background:none;border:none;color:var(--xlt);cursor:pointer;padding:7px;font-size:18px;border-radius:7px;position:relative;transition:background .15s}
.tb-btn:hover{background:rgba(29,158,117,.1)}
.notif-badge{position:absolute;top:4px;right:4px;width:8px;height:8px;border-radius:50%;background:var(--red);display:none}
.notif-badge.show{display:block}

/* ─ BODY LAYOUT ─ */
#body{display:flex;flex:1;overflow:hidden}

/* ─ SIDEBAR ─ */
#sidebar{width:var(--sb);background:var(--dark2);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;transition:transform .25s}
.sb-sect{font-size:10px;font-weight:700;color:rgba(157,225,203,.3);text-transform:uppercase;letter-spacing:.1em;padding:14px 16px 4px}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 16px;font-size:13px;color:rgba(157,225,203,.5);cursor:pointer;border-left:2px solid transparent;transition:all .13s;user-select:none;font-weight:400}
.nav-item i{font-size:16px;flex-shrink:0}
.nav-item:hover{background:rgba(29,158,117,.07);color:var(--xlt)}
.nav-item.active{background:rgba(29,158,117,.12);color:var(--xlt);border-left-color:var(--green)}
.nav-item.hidden{display:none!important}
.sb-bottom{margin-top:auto;padding:12px 16px;border-top:1px solid rgba(29,158,117,.1);font-size:11px;color:rgba(157,225,203,.3)}
.sb-farm{font-size:12px;color:var(--lt);font-weight:500;margin-bottom:2px}
.online-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green);margin-right:4px;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ─ CONTENT ─ */
#content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;position:relative}
.page{display:none;padding:16px;max-width:1280px;margin:0 auto;animation:fadeIn .2s ease}
.page.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ─ PAGE HEADER ─ */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px;flex-wrap:wrap}
.ph-title{font-family:var(--ffh);font-size:20px;font-weight:700;color:var(--dark)}
.ph-sub{font-size:12px;color:var(--text3);margin-top:2px}
.ph-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ─ CARDS ─ */
.card{background:var(--white);border:1px solid var(--bdr);border-radius:14px;padding:16px}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.kpi{background:var(--white);border:1px solid var(--bdr);border-radius:12px;padding:14px;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}
.kpi:hover{border-color:var(--bdr2);transform:translateY(-2px)}
.kpi::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:2px 2px 0 0;background:var(--green)}
.kpi.red::before{background:var(--red)}.kpi.gold::before{background:var(--gold)}.kpi.blue::before{background:var(--blue)}
.kpi-lbl{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;display:flex;align-items:center;gap:4px}
.kpi-lbl i{font-size:13px}
.kpi-val{font-size:26px;font-weight:700;color:var(--dark);font-family:var(--ffh);line-height:1}
.kpi-sub{font-size:11px;color:var(--text3);margin-top:3px}

/* ─ JOB CARDS ─ */
.jobs-grid{display:flex;flex-direction:column;gap:8px}
.job-card{background:var(--white);border:1px solid var(--bdr);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all .15s;display:flex;gap:12px;align-items:flex-start}
.job-card:hover{border-color:var(--bdr2);transform:translateY(-1px);box-shadow:0 2px 8px rgba(6,46,32,.07)}
.job-card.urgent{border-left:3px solid var(--red)}
.job-card.high{border-left:3px solid var(--gold)}
.job-card.done{opacity:.7}
.job-status-bar{width:4px;border-radius:2px;flex-shrink:0;align-self:stretch;min-height:40px}
.js-open{background:var(--gold)}.js-assigned{background:var(--blue)}.js-inprogress{background:var(--green)}
.js-done{background:#C0C0BA}.js-checked{background:var(--lt)}.js-cancelled{background:var(--red)}
.job-body{flex:1;min-width:0}
.job-title{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.job-chips{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:5px}
.chip{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:3px;text-transform:uppercase;letter-spacing:.04em}
.chip-cat{background:var(--bg2);color:var(--text2)}
.chip-open{background:#FFF3E0;color:#7C3F00}
.chip-assigned{background:#E6F1FB;color:#0C447C}
.chip-inprogress{background:#E1F5EE;color:#085041}
.chip-done{background:#F4F4F2;color:#666}
.chip-checked{background:#E1F5EE;color:var(--gn2)}
.chip-cancelled{background:#FCEBEB;color:#791F1F}
.chip-urgent{background:#FCEBEB;color:#791F1F}
.chip-high{background:#FFF3E0;color:#7C3F00}
.chip-normal{background:var(--bg2);color:var(--text3)}
.chip-low{background:var(--bg2);color:var(--text3)}
.job-notes{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.job-meta{font-size:11px;color:var(--text3);margin-top:5px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.job-meta i{font-size:12px}
.job-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}
.icon-btn{background:var(--bg2);border:1px solid var(--bdr);border-radius:7px;padding:7px 9px;cursor:pointer;font-size:14px;color:var(--text2);transition:all .15s;display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;font-family:var(--ff)}
.icon-btn:hover{background:var(--bg3);border-color:var(--bdr2)}
.icon-btn.primary{background:var(--green);color:var(--white);border-color:var(--green)}
.icon-btn.primary:hover{background:var(--gn2)}
.icon-btn.danger{color:var(--red);border-color:rgba(226,75,74,.25)}
.icon-btn.danger:hover{background:#FCEBEB}

/* ─ FILTER BAR ─ */
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
.flt{background:var(--white);border:1px solid var(--bdr);border-radius:99px;padding:5px 12px;font-size:12px;font-weight:500;color:var(--text2);cursor:pointer;font-family:var(--ff);transition:all .13s;white-space:nowrap}
.flt:hover,.flt.on{background:var(--dark);color:var(--xlt);border-color:var(--dark)}
.flt-select{background:var(--white);border:1px solid var(--bdr);border-radius:99px;padding:5px 12px;font-size:12px;font-family:var(--ff);color:var(--text2);cursor:pointer;appearance:none;padding-right:28px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:all .13s}
.flt-select:focus,.flt-select:hover{border-color:var(--green);outline:none}

/* ─ FAB ─ */
#fab{position:fixed;bottom:80px;right:20px;width:52px;height:52px;border-radius:50%;background:var(--green);color:var(--white);border:none;cursor:pointer;font-size:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(6,46,32,.3);z-index:40;transition:all .2s}
#fab:hover{background:var(--gn2);transform:scale(1.05)}
#fab.hidden{display:none}

/* ─ MODAL ─ */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:3000;display:none;align-items:flex-end;justify-content:center}
.overlay.show{display:flex}
.sheet{background:var(--white);border-radius:20px 20px 0 0;width:100%;max-width:680px;max-height:92vh;overflow-y:auto;padding:20px;position:relative;animation:slideUp .25s ease}
@keyframes slideUp{from{transform:translateY(60px);opacity:0}to{transform:none;opacity:1}}
.sheet-handle{width:36px;height:4px;background:var(--bdr2);border-radius:2px;margin:0 auto 16px;cursor:pointer}
.sheet h2{font-family:var(--ffh);font-size:17px;font-weight:700;color:var(--dark);margin-bottom:16px;display:flex;align-items:center;justify-content:space-between}
.sheet-close{background:var(--bg);border:1px solid var(--bdr);border-radius:50%;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text2);flex-shrink:0}

/* ─ FORMS ─ */
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.form-field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.form-field label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}
.form-field input,.form-field select,.form-field textarea{padding:10px 12px;border:1px solid var(--bdr2);border-radius:9px;font-size:14px;font-family:var(--ff);color:var(--text);background:var(--bg);outline:none;transition:border-color .15s;width:100%}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--green);background:var(--white)}
.form-field textarea{min-height:80px;resize:vertical}
.form-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.btn{padding:11px 20px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--ff);border:1px solid;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--green);color:var(--white);border-color:var(--green)}
.btn-primary:hover{background:var(--gn2)}
.btn-secondary{background:none;color:var(--text);border-color:var(--bdr2)}
.btn-secondary:hover{background:var(--bg2)}
.btn-danger{background:none;color:var(--red);border-color:rgba(226,75,74,.25)}
.btn-danger:hover{background:#FCEBEB}
.btn-icon{background:var(--bg2);color:var(--text2);border-color:var(--bdr);padding:10px 14px}
.btn-icon:hover{background:var(--bg3)}

/* ─ PHOTO STRIP ─ */
.photo-strip{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.thumb{width:80px;height:64px;object-fit:cover;border-radius:8px;border:1px solid var(--bdr2)}

/* ─ STATUS SELECT (color-coded) ─ */
select.status-select{appearance:none;font-weight:600}
select.status-open{background:#FFF3E0!important;color:#7C3F00!important;border-color:#FAC775!important}
select.status-assigned{background:#E6F1FB!important;color:#0C447C!important}
select.status-inprogress{background:#E1F5EE!important;color:#085041!important}
select.status-done{background:#F4F4F2!important;color:#666!important}
select.status-checked{background:#E1F5EE!important;color:var(--gn2)!important}
select.status-cancelled{background:#FCEBEB!important;color:#791F1F!important}

/* ─ TABLE ─ */
.tbl-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--bdr)}
table{width:100%;border-collapse:collapse;min-width:500px}
thead th{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;padding:9px 14px;text-align:left;background:var(--bg);border-bottom:1px solid var(--bdr);white-space:nowrap}
tbody tr{border-bottom:1px solid var(--bg2);transition:background .1s}
tbody tr:hover{background:var(--bg2)}
tbody tr:last-child{border-bottom:none}
td{padding:10px 14px;font-size:13px;color:var(--text2);vertical-align:middle}
.td-bold{font-weight:600;color:var(--dark)}
.td-small{font-size:11px;color:var(--text3)}

/* ─ LIVESTOCK CARDS ─ */
.animal-card{background:var(--white);border:1px solid var(--bdr);border-radius:12px;padding:14px;display:flex;gap:12px;align-items:flex-start;margin-bottom:8px;cursor:pointer;transition:all .15s}
.animal-card:hover{border-color:var(--bdr2)}
.animal-icon{width:44px;height:44px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.animal-info{flex:1;min-width:0}
.animal-name{font-size:14px;font-weight:600;color:var(--dark)}
.animal-meta{font-size:12px;color:var(--text2);margin-top:2px}
.animal-status{font-size:10px;font-weight:600;padding:2px 8px;border-radius:3px;text-transform:uppercase;flex-shrink:0}
.as-ok{background:var(--bg2);color:var(--gn2)}
.as-att{background:#FFF3E0;color:#7C3F00}
.as-sick{background:#FCEBEB;color:#791F1F}
.as-other{background:var(--bg2);color:var(--text3)}

/* ─ PADDOCK CARDS ─ */
.paddock-card{background:var(--white);border:1px solid var(--bdr);border-radius:12px;padding:14px;margin-bottom:8px;cursor:pointer;transition:all .15s}
.paddock-card:hover{border-color:var(--bdr2)}
.paddock-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}
.paddock-name{font-size:14px;font-weight:600;color:var(--dark)}
.paddock-area{font-size:12px;color:var(--text3);font-weight:400}
.paddock-details{display:flex;gap:8px;flex-wrap:wrap}
.pd-chip{font-size:11px;background:var(--bg2);color:var(--text2);padding:3px 8px;border-radius:5px;font-weight:500}

/* ─ MAP ─ */
#map{height:calc(100vh - var(--nav-h) - 120px);min-height:300px;border-radius:12px;border:1px solid var(--bdr)}

/* ─ USER TABLE ─ */
.role-pill{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:3px;text-transform:uppercase;letter-spacing:.04em}
.role-master{background:#EEEDFE;color:#3C3489}
.role-admin{background:#E1F5EE;color:#085041}
.role-manager{background:#E6F1FB;color:#0C447C}
.role-worker{background:var(--bg2);color:var(--text3)}
.locked-badge{font-size:10px;background:#FCEBEB;color:#791F1F;padding:2px 7px;border-radius:3px;font-weight:600}

/* ─ STATS ─ */
.stat-group{background:var(--white);border:1px solid var(--bdr);border-radius:12px;padding:16px;margin-bottom:14px}
.stat-title{font-size:13px;font-weight:600;color:var(--dark);margin-bottom:12px}
.stat-bars{display:flex;flex-direction:column;gap:8px}
.stat-bar-row{display:flex;align-items:center;gap:10px;font-size:12px}
.stat-bar-label{width:100px;color:var(--text2);flex-shrink:0;font-size:11px}
.stat-bar-wrap{flex:1;height:8px;background:var(--bg2);border-radius:4px;overflow:hidden}
.stat-bar-fill{height:100%;border-radius:4px;background:var(--green);transition:width .4s}
.stat-bar-count{font-weight:600;color:var(--dark);width:30px;text-align:right;flex-shrink:0;font-size:12px}

/* ─ NOTIFICATIONS ─ */
.notif-item{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid var(--bg2);align-items:flex-start;transition:background .12s}
.notif-item:hover{background:var(--bg2)}
.notif-clickable{cursor:pointer}
.notif-clickable:hover{background:var(--bg3)!important;border-left:3px solid var(--green)}
.notif-item:last-child{border-bottom:none}
.notif-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:4px}
.nd-info{background:var(--blue)}.nd-security{background:var(--red)}.nd-success{background:var(--green)}.nd-warn{background:var(--gold)}
.notif-msg{flex:1;font-size:13px;color:var(--text)}
.notif-time{font-size:11px;color:var(--text3);flex-shrink:0}

/* ─ LOGIN PAGE ─ */
#loginOverlay{position:fixed;inset:0;background:var(--dark3);display:flex;align-items:center;justify-content:center;z-index:500;padding:16px}
.login-box{background:var(--dark2);border-radius:20px;padding:32px;width:100%;max-width:380px;border:1px solid rgba(29,158,117,.2)}
.login-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px;justify-content:center}
.login-title{font-family:var(--ffh);font-size:22px;font-weight:800;color:var(--xlt)}
.login-title span{color:var(--lt)}
.login-field{margin-bottom:14px}
.login-field label{font-size:11px;font-weight:600;color:rgba(157,225,203,.5);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:5px}
.login-field input{width:100%;padding:12px 14px;background:rgba(29,158,117,.08);border:1px solid rgba(29,158,117,.2);border-radius:10px;font-size:15px;color:var(--xlt);font-family:var(--ff);outline:none;transition:border-color .15s}
.login-field input:focus{border-color:var(--green);background:rgba(29,158,117,.12)}
.login-field input::placeholder{color:rgba(157,225,203,.3)}
.login-btn{width:100%;padding:13px;background:var(--green);color:var(--white);border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--ff);transition:all .15s;margin-top:4px}
.login-btn:hover{background:var(--gn2)}
.login-err{font-size:12px;color:var(--red);margin-top:8px;text-align:center;min-height:16px}
.login-tagline{font-size:12px;color:rgba(157,225,203,.35);text-align:center;margin-top:16px}

/* ─ BOTTOM NAV (mobile) ─ */
#bottomNav{display:none;background:var(--dark2);border-top:1px solid rgba(29,158,117,.15);height:var(--bot-h);flex-shrink:0;padding:0 4px}
.bnav-row{display:flex;height:100%}
.bnav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;color:rgba(157,225,203,.45);transition:color .15s;padding:6px 2px;border:none;background:none;font-family:var(--ff)}
.bnav-item i{font-size:20px}
.bnav-item span{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.bnav-item.active,.bnav-item:hover{color:var(--xlt)}
.bnav-item.active i{color:var(--lt)}
.bnav-more-menu{position:fixed;bottom:var(--bot-h);left:0;right:0;background:var(--dark2);border-top:1px solid rgba(29,158,117,.15);padding:12px;display:none;flex-wrap:wrap;gap:6px;z-index:100}
.bnav-more-menu.show{display:flex}
.bnav-menu-item{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:9px;background:rgba(29,158,117,.06);color:var(--xlt);font-size:13px;cursor:pointer;transition:background .12s;width:calc(50% - 3px)}
.bnav-menu-item:hover{background:rgba(29,158,117,.12)}
.bnav-menu-item i{font-size:16px;color:var(--lt)}

/* ─ GPS LOC INDICATOR ─ */
.loc-pill{display:inline-flex;align-items:center;gap:5px;background:var(--bg2);border:1px solid var(--bdr2);border-radius:99px;padding:4px 10px;font-size:11px;color:var(--text2);font-weight:500}
.loc-pill i{font-size:13px;color:var(--green)}

/* ─ EMPTY STATE ─ */
.empty{text-align:center;padding:48px 24px;color:var(--text3)}
.empty i{font-size:40px;display:block;margin-bottom:10px;opacity:.4}
.empty p{font-size:14px}

/* ─ RESPONSIVE ─ */
@media(max-width:900px){
  #sidebar{position:fixed;left:0;top:var(--nav-h);height:calc(100vh - var(--nav-h));z-index:150;transform:translateX(-100%)}
  #sidebar.open{transform:none;box-shadow:4px 0 24px rgba(0,0,0,.3)}
  #menuToggle{display:block}
  #bottomNav{display:flex}
  #fab{bottom:calc(var(--bot-h) + 14px)}
  #toast{bottom:calc(var(--bot-h) + 10px)}
  .kpi-row{grid-template-columns:1fr 1fr}
  #map{height:calc(100vh - var(--nav-h) - var(--bot-h) - 120px)}
}
@media(max-width:600px){
  .kpi-row{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .tb-user{display:none}
  .ph{flex-direction:column;align-items:flex-start;gap:8px}
  .page{padding:12px}
  .job-card{flex-direction:column;gap:8px}
  .job-actions{flex-direction:row;align-self:flex-end}
  .filter-bar{gap:4px}
}
@media(min-width:901px){
  #content{padding:0}
  #fab{bottom:20px}
  #toast{bottom:20px}
}

/* ── OFFLINE STATUS BAR ─────────────────────────────────────────────── */
.offline-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:1200;
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  padding:8px 14px;font-family:var(--ff);font-size:13px;font-weight:500;
  box-shadow:0 -2px 10px rgba(0,0,0,.15);
}
.offline-bar.is-offline{background:var(--dark);color:var(--xlt)}
.offline-bar.is-pending{background:var(--gold);color:#3a2600}
.offline-bar i{margin-right:4px}
.offline-sync-btn{
  border:none;border-radius:99px;padding:5px 14px;cursor:pointer;
  font-family:var(--ff);font-size:12px;font-weight:600;
  background:var(--dark);color:var(--xlt);
}
@media(max-width:900px){ .offline-bar{bottom:var(--bot-h)} }

/* ─ CALENDAR ─ */
.cal-workload{display:none;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px;font-size:12px}
.cal-wl-title{font-weight:600;color:var(--text2)}
.cal-wl-chip{background:var(--bg2);border:1px solid var(--bdr);border-radius:99px;padding:3px 10px;color:var(--text)}
.cal-wl-chip b{color:var(--green)}
.cal-wl-warn{background:var(--red);color:#fff;border-radius:99px;padding:3px 10px;font-weight:600}
.cal-container{background:var(--white);border:1px solid var(--bdr);border-radius:14px;overflow:hidden}

.cal-grid{display:flex;flex-direction:column}
.cal-head{display:grid;grid-template-columns:repeat(7,1fr);background:var(--dark2);color:var(--xlt)}
.cal-head>div{padding:8px 6px;font-size:12px;font-weight:600;text-align:center}
.cal-body{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:minmax(96px,auto)}
.cal-cell{border-right:1px solid var(--bdr);border-bottom:1px solid var(--bdr);padding:4px;min-height:96px;display:flex;flex-direction:column;gap:3px}
.cal-cell.cal-other{background:var(--bg)}
.cal-cell.cal-today{background:var(--bg2);box-shadow:inset 0 0 0 2px var(--green)}
.cal-cell.cal-drop{background:var(--bg3);outline:2px dashed var(--green);outline-offset:-3px}
.cal-daynum{font-size:11px;font-weight:600;color:var(--text3);align-self:flex-end}
.cal-cell.cal-other .cal-daynum{opacity:.5}
.cal-evs{display:flex;flex-direction:column;gap:3px}

.cal-ev{color:#fff;border-radius:6px;padding:3px 6px;font-size:11px;line-height:1.25;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:none}
.cal-ev:hover{filter:brightness(1.07)}
.cal-ev[draggable="true"]{cursor:grab}
.cal-ev-time{font-weight:700;opacity:.9}
.cal-ev-warn{box-shadow:0 0 0 2px var(--red)}

.cal-week{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-weekcol{border-right:1px solid var(--bdr);min-height:240px;display:flex;flex-direction:column}
.cal-weekcol.cal-today{background:var(--bg2)}
.cal-weekcol.cal-drop{background:var(--bg3);outline:2px dashed var(--green);outline-offset:-3px}
.cal-weekhead{padding:7px 6px;font-size:12px;font-weight:600;text-align:center;background:var(--dark2);color:var(--xlt)}
.cal-weekcol .cal-evs{padding:6px;gap:5px}
.cal-weekcol .cal-ev{white-space:normal}
.cal-weekempty{color:var(--text3);font-size:12px;text-align:center;padding:8px 0}

.cal-agenda{display:flex;flex-direction:column}
.cal-agday{display:grid;grid-template-columns:120px 1fr;gap:10px;padding:10px 12px;border-bottom:1px solid var(--bdr)}
.cal-agday.cal-drop{background:var(--bg3)}
.cal-agdate{font-size:12px;font-weight:600;color:var(--text2)}

@media(max-width:900px){
  .cal-body{grid-auto-rows:minmax(72px,auto)}
  .cal-cell{min-height:72px}
  .cal-week{grid-template-columns:1fr;display:flex;flex-direction:column}
  .cal-weekcol{min-height:auto;border-right:none;border-bottom:1px solid var(--bdr)}
  .cal-agday{grid-template-columns:90px 1fr}
}

/* ─ GIS ─ */
.gis-map-wrap{position:relative}
.gis-status{background:var(--dark);color:var(--xlt);padding:8px 12px;border-radius:10px;font-size:12px;margin-bottom:8px;align-items:center;gap:8px;flex-wrap:wrap}
.gis-status .btn{padding:5px 14px;font-size:12px}
.gis-vertex{width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid #EF9F27;box-shadow:0 1px 4px rgba(0,0,0,.4);cursor:move}
.gis-midvertex{width:10px;height:10px;border-radius:50%;background:#EF9F27;opacity:.55;border:2px solid #fff;cursor:copy}
.gis-toolbar{background:#fff;display:flex;flex-direction:column}
.gis-toolbar a{width:34px;height:34px;display:flex;align-items:center;justify-content:center;color:var(--dark);font-size:16px;border-bottom:1px solid var(--bdr)}
.gis-toolbar a:hover{background:var(--bg2)}
.gis-panel{position:absolute;top:10px;right:10px;width:280px;max-width:72vw;background:#fff;border:1px solid var(--bdr);border-radius:12px;box-shadow:0 6px 20px rgba(0,0,0,.2);z-index:1100;padding:12px}
.gis-panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.gis-x{border:none;background:none;cursor:pointer;color:var(--text3);font-size:16px}
.gis-scores{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.gis-score{background:var(--bg2);border-radius:8px;padding:6px 8px;font-size:12px;display:flex;flex-direction:column}
.gis-score span{color:var(--text3);font-size:10px}
.gis-score b{font-size:15px}
.gis-spark{margin-top:10px}
.gis-legend{background:#fff;border-radius:10px;padding:8px 10px;box-shadow:0 2px 8px rgba(0,0,0,.2);font-size:11px;color:var(--text2);min-width:120px}
.gis-legend-title{font-weight:600;margin-bottom:4px;color:var(--dark)}
.gis-legend-bar{height:10px;border-radius:5px;background:linear-gradient(to right,#E24B4A,#EF9F27,#1D9E75)}
.gis-legend-scale{display:flex;justify-content:space-between;font-size:10px;color:var(--text3);margin-top:2px}
.gis-legend-row{display:flex;align-items:center;gap:6px;margin:2px 0}
.gis-legend-row i{width:12px;height:12px;border-radius:3px;display:inline-block}

/* ─ SATELLITE DASHBOARD ─ */
.sat-widgets{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.sat-w{background:#fff;border:1px solid var(--bdr);border-radius:12px;padding:12px}
.sat-w-lbl{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.04em}
.sat-w-val{font-size:26px;font-weight:700;font-family:var(--ffh)}
#satRanking table{width:100%;border-collapse:collapse}
#satRanking th,#satRanking td{padding:8px 12px;text-align:left;font-size:13px;border-bottom:1px solid var(--bdr)}
#satRanking th{font-size:11px;color:var(--text3);text-transform:uppercase}
