  :root {
    --ocean-deep:#0a1628;--ocean-mid:#0d2240;--ocean-surface:#1a3a5c;--tide:#2a6496;
    --seafoam:#4a9ebb;--foam:#a8d4e6;--pearl:#e8f4f8;--sand:#f5f0e8;--gold:#c9a84c;
    --text-primary:#1a2a3a;--text-secondary:#4a6275;--text-light:#8aa0b0;--border:#d0e4ee;
    --white:#ffffff;--success:#27ae60;--warning:#e67e22;--error:#c0392b;
    --radius:6px;--radius-lg:12px;
    --shadow-sm:0 1px 3px rgba(10,22,40,.12);--shadow-md:0 4px 16px rgba(10,22,40,.15);--shadow-lg:0 8px 32px rgba(10,22,40,.2);
    --t:.2s ease;
  }
  *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  input[type="number"]::-webkit-outer-spin-button,input[type="number"]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
  input[type="number"]{-moz-appearance:textfield}
  body{font-family:'IBM Plex Sans',sans-serif;background:var(--ocean-deep);color:var(--text-primary);min-height:100vh;overflow:hidden}
  body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(26,58,92,.4) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(74,158,187,.15) 0%,transparent 50%),radial-gradient(ellipse at 60% 80%,rgba(13,34,64,.6) 0%,transparent 50%);pointer-events:none;z-index:0}

  /* DEV BANNER + WATERMARK */
  #dev-banner{position:fixed;top:0;left:0;right:0;z-index:9999;background:#e67e22;color:#fff;font-family:'IBM Plex Sans',sans-serif;font-size:12px;font-weight:700;text-align:center;padding:5px 0;letter-spacing:.05em;pointer-events:none}
  #dev-watermark{position:fixed;inset:0;z-index:1;pointer-events:none;display:flex;align-items:center;justify-content:center;overflow:hidden}
  #dev-watermark::after{content:'TESTING MODE ONLY';font-family:'IBM Plex Sans',sans-serif;font-size:clamp(36px,8vw,80px);font-weight:900;color:rgba(230,126,34,0.10);letter-spacing:.1em;transform:rotate(-35deg);white-space:nowrap;user-select:none}

  /* LOGIN */
  #login-screen{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}
  .login-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden;animation:slideUp .4s ease}
  @keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
  .login-header{background:var(--ocean-mid);padding:36px 40px 28px;text-align:center;border-bottom:3px solid var(--gold)}
  .login-logo{font-family:'Libre Baskerville',serif;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--foam);margin-bottom:8px}
  .login-title{font-family:'Libre Baskerville',serif;font-size:22px;color:var(--white);font-weight:700;line-height:1.3}
  .login-subtitle{font-size:13px;color:var(--seafoam);margin-top:8px;font-style:italic;font-weight:300;letter-spacing:.04em}
  .login-body{padding:32px 40px 36px}
  .login-field{margin-bottom:20px}
  .login-field label{display:block;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px}
  .login-field select,.login-field input{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:15px;color:var(--text-primary);background:var(--pearl);transition:border-color var(--t),box-shadow var(--t);outline:none;appearance:none}
  .login-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a6275' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;cursor:pointer}
  .login-field input[type="password"]{font-size:15px;letter-spacing:.04em}
  .login-field select:focus,.login-field input:focus{border-color:var(--seafoam);box-shadow:0 0 0 3px rgba(74,158,187,.15);background:var(--white)}
  .login-btn{width:100%;padding:14px;background:var(--ocean-surface);color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background var(--t),transform var(--t);margin-top:4px}
  .login-btn:hover{background:var(--tide);transform:translateY(-1px)}
  .login-btn:active{transform:translateY(0)}
  .login-error{background:#fdf0f0;border:1px solid #f5c6c6;border-radius:var(--radius);padding:10px 14px;font-size:13px;color:var(--error);margin-top:14px;text-align:center;display:none}
  .login-clear-btn{width:100%;margin-top:12px;padding:9px;background:none;border:1px dashed rgba(74,158,187,.3);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:11px;color:var(--text-light);cursor:pointer;letter-spacing:.06em;transition:all var(--t)}
  .login-clear-btn:hover{border-color:var(--seafoam);color:var(--seafoam)}

  /* PIN CHANGE */
  #pin-change-screen{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:100;padding:20px;background:rgba(10,22,40,.85)}
  .pin-change-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:400px;overflow:hidden;animation:slideUp .3s ease}
  .pin-change-header{background:var(--ocean-surface);padding:24px 32px;border-bottom:3px solid var(--gold)}
  .pin-change-header h2{font-family:'Libre Baskerville',serif;font-size:18px;color:var(--white);font-weight:700}
  .pin-change-header p{font-size:12px;color:var(--foam);margin-top:5px;line-height:1.5}
  .pin-change-body{padding:28px 32px 32px}
  .pin-error{background:#fdf0f0;border:1px solid #f5c6c6;border-radius:var(--radius);padding:9px 12px;font-size:12px;color:var(--error);margin-bottom:14px;display:none}

  /* APP */
  #app{display:none;min-height:100vh;position:relative;z-index:1}
  .topbar{position:fixed;top:0;left:0;right:0;height:56px;background:var(--ocean-mid);border-bottom:2px solid var(--gold);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:50;box-shadow:var(--shadow-md)}
  .topbar-brand{font-family:'Libre Baskerville',serif;font-size:13px;color:var(--white);letter-spacing:.05em;white-space:nowrap;overflow:hidden}
  .topbar-brand .brand-sub{font-family:'IBM Plex Sans',sans-serif;font-size:11px;color:var(--seafoam);font-style:italic;font-weight:300;letter-spacing:.08em;margin-left:10px;opacity:.9}
  .topbar-right{display:flex;align-items:center;gap:16px}
  .topbar-user{font-size:12px;color:var(--foam);font-family:'IBM Plex Mono',monospace}
  .topbar-logout{font-size:11px;color:var(--text-light);background:none;border:1px solid rgba(168,212,230,.2);border-radius:4px;padding:5px 10px;cursor:pointer;font-family:'IBM Plex Sans',sans-serif;letter-spacing:.05em;transition:all var(--t)}
  .topbar-logout:hover{color:var(--foam);border-color:var(--foam)}

  /* SIDEBAR */
  .sidebar{position:fixed;top:56px;left:0;bottom:0;width:220px;background:var(--ocean-mid);border-right:1px solid rgba(168,212,230,.1);padding:24px 0;z-index:40;overflow-y:auto;display:flex;flex-direction:column}
  .sidebar-section{margin-bottom:8px}
  .sidebar-section-label{font-size:9px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--seafoam);padding:0 20px 8px;opacity:.7}
  .nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;cursor:pointer;transition:all var(--t);border-left:3px solid transparent}
  .nav-item:hover{background:rgba(74,158,187,.1);border-left-color:rgba(74,158,187,.4)}
  .nav-item.active{background:rgba(74,158,187,.15);border-left-color:var(--seafoam)}
  .nav-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}
  .nav-label{font-size:13px;color:var(--white);font-weight:400;line-height:1.2;flex:1}
  .nav-item.active .nav-label{color:var(--white);font-weight:500}
  .nav-accordion-trigger{display:flex;align-items:center;gap:10px;padding:10px 20px;cursor:pointer;transition:all var(--t);border-left:3px solid transparent;user-select:none}
  .nav-accordion-trigger:hover{background:rgba(74,158,187,.1);border-left-color:rgba(74,158,187,.4)}
  .nav-accordion-arrow{font-size:9px;color:var(--text-light);transition:transform var(--t)}
  .nav-accordion.open .nav-accordion-arrow{transform:rotate(180deg)}
  .nav-accordion-children{display:none;background:rgba(0,0,0,.15)}
  .nav-accordion.open .nav-accordion-children{display:block}
  .nav-child{display:flex;align-items:center;padding:8px 20px 8px 50px;cursor:pointer;transition:all var(--t);border-left:3px solid transparent}
  .nav-child:hover{background:rgba(74,158,187,.1);border-left-color:rgba(74,158,187,.3)}
  .nav-child.active{background:rgba(74,158,187,.15);border-left-color:var(--seafoam)}
  .nav-child-label{font-size:12px;color:var(--foam)}
  .nav-child.active .nav-child-label{color:var(--white);font-weight:500}
  .nav-child-records .nav-child-label{color:var(--gold);font-weight:600}
  .nav-child-records:hover{background:rgba(201,168,76,.1);border-left-color:rgba(201,168,76,.4)}
  .sidebar-divider{height:1px;background:rgba(168,212,230,.08);margin:12px 20px}
  /* Farm nav: split label/caret header + collapsible location list */
  .nav-farm-header{display:flex;align-items:stretch}
  .nav-farm-main{flex:1;border-left:3px solid transparent;border-radius:0}
  .nav-farm-caret{flex-shrink:0;background:transparent;border:none;color:var(--text-light);font-size:10px;padding:0 14px;cursor:pointer;transition:transform var(--t);opacity:.6}
  .nav-farm-caret:hover{opacity:1}
  .nav-farm-caret.open{transform:rotate(90deg)}
  .nav-farm-children{display:none;background:rgba(0,0,0,.15)}
  .nav-farm-children.open{display:block}
  .nav-farm-disabled{opacity:.35;cursor:default;pointer-events:none}

  /* MAIN — position:fixed keeps topbar truly fixed to viewport on iOS Safari.
     If margin-based + overflow-y:auto on a child is used, iOS treats .main as the
     root scroller and anchors position:fixed elements to .main's top edge (y=56px),
     causing the topbar to cover form content. position:fixed avoids this entirely. */
  .main{position:fixed;left:220px;top:56px;right:0;bottom:0;overflow-y:auto;background:var(--sand)}
  .form-container{max-width:960px;margin:0 auto;padding:28px 28px 80px}
  .form-header{margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--border)}
  .form-hdr-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
  .form-title{font-family:'Libre Baskerville',serif;font-size:26px;color:var(--ocean-deep);font-weight:700}
  .form-desc{font-size:13px;color:var(--text-secondary);margin-top:6px;line-height:1.5}
  .records-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:var(--white);border:1.5px solid var(--seafoam);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:12px;font-weight:600;color:var(--seafoam);cursor:pointer;transition:all var(--t);letter-spacing:.03em;flex-shrink:0}
  .records-btn:hover{background:var(--seafoam);color:var(--white)}

  /* CARDS */
  .form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:14px;overflow:hidden}
  .form-card-header{background:var(--pearl);padding:11px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
  .form-card-header h3{font-size:11px;font-weight:600;color:var(--ocean-surface);letter-spacing:.04em;text-transform:uppercase}
  .form-card-body{padding:16px}
  .card-warning{border-left:3px solid var(--warning)!important}

  /* FIELDS */
  .field-grid{display:grid;gap:12px}
  .field-grid-2{grid-template-columns:1fr 1fr}
  .span-2{grid-column:span 2}
  .field{display:flex;flex-direction:column;gap:5px}
  .field label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}
  .field label .req{color:var(--error);margin-left:2px}
  .field input,.field select,.field textarea{padding:9px 11px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:var(--text-primary);background:var(--white);transition:border-color var(--t),box-shadow var(--t);outline:none;width:100%}
  .field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a6275' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}
  .field textarea{resize:vertical;min-height:65px;line-height:1.5}
  .field input:focus,.field select:focus,.field textarea:focus{border-color:var(--seafoam);box-shadow:0 0 0 3px rgba(74,158,187,.12)}
  .field input.error,.field select.error{border-color:var(--error);box-shadow:0 0 0 3px rgba(192,57,43,.1)}
  .field-hint{font-size:11px;color:var(--text-light);line-height:1.4}
  .field-error-msg{font-size:11px;color:var(--error);display:none;margin-top:2px}

  /* CHECKBOXES */
  .checkbox-group{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}
  .checkbox-item{display:flex;align-items:center;gap:8px;cursor:pointer;padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--radius);transition:all var(--t)}
  .checkbox-item:hover{border-color:var(--seafoam);background:var(--pearl)}
  .checkbox-item input[type="checkbox"]{width:15px;height:15px;accent-color:var(--seafoam);cursor:pointer;flex-shrink:0}
  .checkbox-item span{font-size:13px;color:var(--text-primary)}

  /* BO LAYOUT */
  .bo-layout{display:grid;grid-template-columns:210px 1fr;gap:14px;align-items:start}
  .bo-count-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--pearl);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:10px}
  .bo-count-row label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap}
  .bo-count-input{width:72px;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:15px;font-family:'IBM Plex Mono',monospace;text-align:center;outline:none;color:var(--text-primary)}
  .bo-count-input:focus{border-color:var(--seafoam);box-shadow:0 0 0 3px rgba(74,158,187,.12)}
  .bo-count-hint{font-size:10px;color:var(--text-light);line-height:1.3}
  .bo-meas-cols{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .bo-meas-col{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
  .bo-meas-col-header{display:grid;grid-template-columns:26px 1fr 1fr;background:var(--ocean-surface);color:var(--white)}
  .bo-meas-col-header span{padding:6px 5px;font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;text-align:center;border-right:1px solid rgba(255,255,255,.15)}
  .bo-meas-col-header span:last-child{border-right:none}
  .bo-meas-row{display:grid;grid-template-columns:26px 1fr 1fr;align-items:center;border-top:1px solid var(--border)}
  .bo-meas-row:nth-child(even){background:var(--pearl)}
  .bo-meas-num{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text-light);text-align:center;padding:3px 2px}
  .bo-meas-row input{border:none;border-left:1px solid var(--border);border-radius:0;padding:6px 7px;font-size:13px;background:transparent;outline:none;width:100%;font-family:'IBM Plex Mono',monospace}
  .bo-meas-row input:focus{background:rgba(74,158,187,.07)}
  .source-add-row{display:flex;gap:7px;margin-top:6px}
  .source-add-row input{flex:1;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:13px;outline:none}
  .source-add-row input:focus{border-color:var(--seafoam)}
  .source-add-btn{padding:7px 11px;background:var(--seafoam);color:var(--white);border:none;border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background var(--t)}
  .source-add-btn:hover{background:var(--tide)}

  /* ════════════════════════════════
     BROODSTOCK SYSTEM FORM STYLES
  ════════════════════════════════ */
  .bs-form-grid{max-width:1200px;margin:0 auto;padding:28px 28px 80px}

  /* header row: date + employee side by side */
  .bs-header-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}

  /* Makeup tanks: two cards side by side */
  .bs-makeup-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
  .bs-makeup-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}
  .bs-makeup-header{padding:9px 16px;font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--white)}
  .bs-makeup-header.mk-a{background:#8b4513}
  .bs-makeup-header.mk-b{background:#0e6e85}
  .bs-makeup-body{padding:14px 16px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

  /* Tank cards: stacked vertically, each card has horizontal tiles inside */
  .bs-tank-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);margin-bottom:14px;overflow:hidden}
  .bs-tank-header{padding:10px 18px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--white)}
  .bs-tank-header.t1{background:var(--ocean-surface)}
  .bs-tank-header.t2{background:#1e7e50}
  .bs-tank-header.t3{background:#6b3090}

  /* Inside each tank card: 5 tiles horizontally */
  .bs-tank-tiles{display:grid;grid-template-columns:1.1fr 1.4fr 1.1fr 1fr 0.9fr;border-top:1px solid var(--border)}
  .bs-tile{padding:12px 14px;border-right:1px solid var(--border)}
  .bs-tile:last-child{border-right:none}
  .bs-tile-label{font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--text-light);margin-bottom:9px}

  /* Compact field inside a tile */
  .bs-field{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}
  .bs-field:last-child{margin-bottom:0}
  .bs-field-label{font-size:10px;color:var(--text-secondary);font-weight:500;line-height:1.2}
  .bs-field input,.bs-field select,.bs-field textarea{
    padding:5px 8px;border:2px solid #3d6a8a;border-radius:var(--radius);
    font-family:'IBM Plex Sans',sans-serif;font-size:12px;color:var(--text-primary);
    background:var(--white);outline:none;width:100%;
    transition:border-color var(--t);
  }
  .bs-field textarea{min-height:64px;resize:vertical;font-size:12px;line-height:1.4}
  .bs-field input:focus,.bs-field select:focus,.bs-field textarea:focus{border-color:var(--seafoam);box-shadow:0 0 0 2px rgba(74,158,187,.1)}
  .bs-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234a6275' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;padding-right:22px;cursor:pointer}
  .bs-field input[readonly]{background:var(--pearl);color:var(--text-secondary);cursor:default}
  .bs-field input.bs-computed{background:#e8f4e8;color:#1a5c30;font-weight:600;cursor:default;font-family:'IBM Plex Mono',monospace}
  .bs-field input.bs-deaths{border-color:#f0c0b0;background:#fff8f5}
  .bs-field input.bs-deaths:focus{border-color:var(--warning)}

  /* Makeup/dilution rows hidden by default */
  .bs-makeup-water-row{display:none}
  .bs-dilution-row{display:none}

  /* Temp delta warning inline */
  .bs-temp-warn{display:none;font-size:10px;color:var(--error);background:#fdf0f0;border:1px solid #f5c6c6;border-radius:4px;padding:4px 7px;margin-top:4px;line-height:1.3;font-weight:500}
  .bs-temp-warn.visible{display:block}
  .bs-range-err{font-size:10px;color:#e74c3c;margin-top:2px;display:none}
  .bs-range-err.visible{display:block}
  .bs-input-err{border-color:#e74c3c!important;background:#fff5f5!important}

  /* Temperature delta alert modal */
  .bs-alert-overlay{position:fixed;inset:0;background:rgba(10,22,40,.7);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
  .bs-alert-overlay.open{display:flex}
  .bs-alert-box{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:380px;padding:28px 32px;text-align:center;border-top:4px solid var(--error)}
  .bs-alert-box .alert-icon{font-size:40px;margin-bottom:12px}
  .bs-alert-box h3{font-family:'Libre Baskerville',serif;font-size:18px;color:var(--error);margin-bottom:8px}
  .bs-alert-box p{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:20px}
  .bs-alert-box button{padding:10px 28px;background:var(--ocean-surface);color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--t)}
  .bs-alert-box button:hover{background:var(--tide)}

  /* SUBMIT BAR */
  .submit-bar{position:fixed;bottom:0;left:220px;right:0;background:var(--white);border-top:1px solid var(--border);padding:12px 28px;display:flex;align-items:center;justify-content:space-between;z-index:30;box-shadow:0 -4px 16px rgba(10,22,40,.08)}
  .submit-left{display:flex;align-items:center;gap:12px}
  .draft-indicator{font-size:11px;font-family:'IBM Plex Mono',monospace;color:var(--text-light);opacity:0;transition:opacity .5s ease}
  .draft-indicator.visible{opacity:1}.draft-indicator.saved{color:var(--success)}.draft-indicator.restored{color:var(--warning)}
  .btn-clear{padding:9px 18px;background:none;border:1.5px solid var(--border);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all var(--t)}
  .btn-clear:hover{border-color:var(--text-secondary);color:var(--text-primary)}
  .btn-submit{padding:11px 32px;background:var(--ocean-surface);color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;letter-spacing:.06em;cursor:pointer;transition:all var(--t);display:inline-flex;align-items:center;gap:8px;min-height:44px;box-sizing:border-box}
  .btn-submit:hover{background:var(--tide);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
  .btn-submit:active{transform:translateY(0)}
  .btn-submit:disabled{background:var(--text-light);cursor:not-allowed;transform:none}

  /* TOASTS */
  #toast-container{position:fixed;top:72px;right:20px;z-index:200;display:flex;flex-direction:column;gap:8px}
  .toast{background:var(--ocean-deep);color:var(--white);padding:12px 18px;border-radius:var(--radius);font-size:13px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:10px;animation:toastIn .3s ease;max-width:320px;border-left:3px solid var(--seafoam)}
  .toast.success{border-left-color:var(--success)}.toast.error{border-left-color:var(--error)}.toast.warning{border-left-color:var(--warning)}
  @keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

  /* WELCOME */
  .welcome-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 56px);text-align:center;padding:40px}
  .welcome-icon{font-size:48px;margin-bottom:20px;opacity:.6}
  .welcome-title{font-family:'Libre Baskerville',serif;font-size:24px;color:var(--ocean-deep);margin-bottom:10px}
  .welcome-text{font-size:14px;color:var(--text-secondary);max-width:400px;line-height:1.6}
  .welcome-name{font-family:'IBM Plex Mono',monospace;font-size:13px;color:var(--seafoam);margin-top:16px;padding:6px 14px;background:rgba(74,158,187,.08);border-radius:20px;border:1px solid rgba(74,158,187,.2)}

  /* RECORDS MODAL */
  .modal-overlay{position:fixed;inset:0;background:rgba(10,22,40,.75);z-index:150;display:none;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto}
  .modal-overlay.open{display:flex}
  .modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:1020px;display:flex;flex-direction:column;animation:slideUp .3s ease;margin:auto;max-height:90vh;overflow:hidden}
  .modal-header{background:var(--ocean-mid);padding:18px 24px;border-bottom:2px solid var(--gold);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
  .modal-header-title{font-family:'Libre Baskerville',serif;font-size:18px;color:var(--white);font-weight:700}
  .modal-close{background:none;border:none;color:var(--foam);font-size:22px;cursor:pointer;padding:8px 12px;border-radius:4px;transition:all var(--t);line-height:1;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
  .modal-close:hover{background:rgba(168,212,230,.15);color:var(--white)}
  .modal-tabs{display:flex;background:var(--pearl);border-bottom:1px solid var(--border);flex-shrink:0;overflow-x:auto}
  .modal-tab{padding:11px 20px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--t);white-space:nowrap}
  .modal-tab:hover{color:var(--tide)}
  .modal-tab.active{color:var(--ocean-surface);border-bottom-color:var(--seafoam);background:var(--white)}
  .modal-cohort-tabs{display:flex;gap:6px;padding:12px 20px;background:var(--sand);border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0}
  .modal-cohort-tab{padding:6px 14px;font-size:11px;font-weight:600;font-family:'IBM Plex Mono',monospace;border:1.5px solid var(--border);border-radius:20px;cursor:pointer;transition:all var(--t);color:var(--text-secondary);background:var(--white)}
  .modal-cohort-tab:hover{border-color:var(--seafoam);color:var(--seafoam)}
  .modal-cohort-tab.active{background:var(--seafoam);border-color:var(--seafoam);color:var(--white)}
  .modal-pinned{background:var(--ocean-surface);padding:14px 20px;border-bottom:2px solid var(--gold);flex-shrink:0}
  .modal-pinned-label{font-size:9px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--foam);margin-bottom:8px}
  .modal-pinned-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px}
  .modal-pinned-item{display:flex;flex-direction:column;gap:3px}
  .pi-label{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(168,212,230,.7)}
  .pi-value{font-size:14px;font-weight:600;color:var(--white);font-family:'IBM Plex Mono',monospace}
  .modal-sub-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--pearl);flex-shrink:0}
  .modal-sub-tab{padding:9px 16px;font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--t);white-space:nowrap}
  .modal-sub-tab:hover{color:var(--tide)}
  .modal-sub-tab.active{color:var(--ocean-surface);border-bottom-color:var(--seafoam);background:var(--white)}
  .modal-body{overflow-y:auto;flex:1}
  .modal-panel{display:none}
  .modal-panel.active{display:block}
  .rec-table-wrap{overflow-x:auto;padding:0}
  .rec-table{width:100%;border-collapse:collapse;font-size:13px;min-width:600px}
  .rec-table th{background:var(--pearl);padding:9px 12px;text-align:left;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:1}
  .rec-table td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}
  .rec-table tr:hover td{background:var(--pearl)}
  .rec-table tr:last-child td{border-bottom:none}
  .rec-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap}
  .rec-badge.active{background:rgba(39,174,96,.12);color:var(--success)}
  .rec-badge.offboarded{background:rgba(74,98,117,.1);color:var(--text-secondary)}
  .rec-badge.hatchery{background:rgba(42,100,150,.12);color:var(--tide)}
  .rec-badge.farm{background:rgba(45,80,22,.1);color:#3a6b1a}
  .rec-badge.nursery{background:rgba(201,168,76,.12);color:#8a6a10}
  .rec-badge.marina{background:rgba(74,158,187,.12);color:var(--seafoam)}
  .rec-badge.admin{background:rgba(120,80,180,.12);color:#7050b4}
  .meas-expand-btn{font-size:11px;color:var(--seafoam);background:none;border:none;cursor:pointer;text-decoration:underline;padding:0}
  .meas-expand-btn:hover{color:var(--tide)}
  .meas-sub-row{display:none;background:var(--pearl)}
  .meas-sub-row.open{display:table-row}
  .meas-sub-cell{padding:14px 16px}
  .stats-panel{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .stat-block{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px}
  .stat-block-title{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:10px}
  .stat-numbers{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
  .stat-item{text-align:center}
  .stat-item .s-label{font-size:9px;color:var(--text-light);text-transform:uppercase;letter-spacing:.08em}
  .stat-item .s-val{font-size:16px;font-weight:600;font-family:'IBM Plex Mono',monospace;color:var(--ocean-surface)}
  .stat-item .s-unit{font-size:10px;color:var(--text-light)}
  .hist-wrap{position:relative;height:60px;display:flex;align-items:flex-end;gap:2px;padding-top:4px}
  .hist-bar{flex:1;background:var(--seafoam);border-radius:2px 2px 0 0;min-height:2px;transition:opacity .2s;opacity:.8;position:relative}
  .hist-bar:hover{opacity:1}
  .hist-bar .hb-tip{display:none;position:absolute;bottom:calc(100% + 4px);left:50%;transform:translateX(-50%);background:var(--ocean-deep);color:var(--white);font-size:10px;padding:3px 6px;border-radius:3px;white-space:nowrap;pointer-events:none}
  .hist-bar:hover .hb-tip{display:block}
  .hist-axis{display:flex;justify-content:space-between;margin-top:3px}
  .hist-axis span{font-size:9px;color:var(--text-light);font-family:'IBM Plex Mono',monospace}
  .modal-empty{text-align:center;padding:48px 20px;color:var(--text-light);font-size:14px}
  .modal.modal-sm{max-width:400px}
  .role-check-label{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:12px;border:1.5px solid var(--border);border-radius:var(--radius);transition:border-color var(--t)}
  .role-check-label:hover{border-color:var(--seafoam)}
  .role-check-label input[type=checkbox]{margin-top:2px;width:16px;height:16px;accent-color:var(--seafoam);flex-shrink:0;cursor:pointer}
  /* Role groups with sub-roles */
  .em-role-group{border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;transition:border-color var(--t)}
  .em-role-parent-lbl{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:12px;background:var(--pearl);transition:background var(--t)}
  .em-role-parent-lbl:hover{background:#e8f0ef}
  .em-role-parent-lbl input[type=checkbox]{margin-top:2px;width:16px;height:16px;accent-color:var(--seafoam);flex-shrink:0;cursor:pointer}
  .em-role-label{font-size:13px;font-weight:600;color:var(--text-primary)}
  .em-role-role-desc{font-size:11px;color:var(--text-light);margin-top:2px}
  .em-sub-roles{padding:6px 12px 10px 40px;display:flex;flex-direction:column;gap:2px;border-top:1px solid var(--border)}
  .em-role-sub{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 0}
  .em-role-sub input[type=checkbox]{width:14px;height:14px;accent-color:var(--seafoam);flex-shrink:0;cursor:pointer}
  .em-role-sub span{font-size:12px;color:var(--text-secondary)}
  .em-sub-disabled{opacity:.4;pointer-events:none}
  .role-edit-btn{background:none;border:none;cursor:pointer;padding:0;display:inline-flex;gap:3px;align-items:center;flex-wrap:wrap}
  .role-edit-btn:hover .rec-badge{opacity:.75;transform:translateY(-1px)}
  .role-edit-btn .rec-badge{transition:opacity .15s,transform .15s}
  .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .7s linear infinite;display:none}
  .spinner.visible{display:block}
  @keyframes spin{to{transform:rotate(360deg)}}

  /* TEST DATA VIEWER */
  .topbar-test-btn{font-size:11px;color:var(--gold);background:none;border:1px solid rgba(201,168,76,.35);border-radius:4px;padding:5px 10px;cursor:pointer;font-family:'IBM Plex Sans',sans-serif;letter-spacing:.05em;transition:all var(--t)}
  .topbar-test-btn:hover{border-color:var(--gold);background:rgba(201,168,76,.1)}
  .testdata-modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:1100px;display:flex;flex-direction:column;animation:slideUp .3s ease;margin:auto;max-height:92vh;overflow:hidden}
  .testdata-clear-btn{padding:6px 14px;font-size:11px;font-weight:600;background:none;border:1px solid rgba(192,57,43,.4);color:var(--error);border-radius:var(--radius);cursor:pointer;font-family:'IBM Plex Sans',sans-serif;transition:all var(--t)}
  .testdata-clear-btn:hover{background:rgba(192,57,43,.07);border-color:var(--error)}
  .testdata-empty{padding:40px;text-align:center;color:var(--text-light);font-size:13px}
  .testdata-count{font-size:10px;font-family:'IBM Plex Mono',monospace;color:var(--text-light);margin-left:6px}

  /* HAMBURGER + SIDEBAR OVERLAY */
  .hamburger-btn{display:none;align-items:center;justify-content:center;background:none;border:1px solid rgba(168,212,230,.2);border-radius:var(--radius);cursor:pointer;padding:8px 10px;flex-direction:column;gap:4px;transition:all var(--t);flex-shrink:0}
  .hamburger-btn:hover{border-color:var(--foam);background:rgba(168,212,230,.1)}
  .hamburger-btn span{display:block;width:16px;height:2px;background:var(--foam);border-radius:1px}
  .sidebar-mobile-footer{display:none;padding:12px 16px;border-top:1px solid rgba(168,212,230,.12);margin-top:auto;display:flex;flex-direction:column;gap:6px}
  .sidebar-footer-btn{width:100%;padding:9px 14px;background:none;border:1px solid rgba(168,212,230,.25);border-radius:var(--radius);color:var(--foam);font-family:'IBM Plex Sans',sans-serif;font-size:13px;cursor:pointer;transition:all var(--t);text-align:left;display:flex;align-items:center;gap:10px}
  .sidebar-footer-btn:hover{border-color:var(--foam);background:rgba(168,212,230,.1);color:var(--white)}
  .sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:35}
  .sidebar-overlay.open{display:block}
  /* Pull-tab to reopen sidebar */
  .sidebar-pull-tab{position:fixed;top:50%;left:0;transform:translateY(-50%);z-index:36;background:var(--ocean-mid);border:1px solid rgba(168,212,230,.2);border-left:none;border-radius:0 var(--radius) var(--radius) 0;padding:12px 6px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:all var(--t)}
  .sidebar-pull-tab:hover{background:var(--ocean-surface);padding-right:10px}
  .sidebar-pull-tab svg{width:12px;height:12px;fill:none;stroke:var(--foam);stroke-width:2;stroke-linecap:round}

  /* SETTINGS + MESSAGE MODALS */
  .simple-modal-overlay{position:fixed;inset:0;background:rgba(10,22,40,.75);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
  .simple-modal-overlay.open{display:flex}
  .simple-modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden;animation:slideUp .3s ease}
  .simple-modal-header{background:var(--ocean-mid);padding:20px 24px;border-bottom:2px solid var(--gold);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
  .simple-modal-header h2{font-family:'Libre Baskerville',serif;font-size:17px;color:var(--white);font-weight:700}
  .simple-modal-body{padding:24px}
  .simple-modal-field{margin-bottom:16px}
  .simple-modal-field label{display:block;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px}
  .simple-modal-field input,.simple-modal-field textarea,.simple-modal-field select{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:var(--text-primary);background:var(--pearl);outline:none;transition:border-color var(--t)}
  .simple-modal-field input:focus,.simple-modal-field textarea:focus{border-color:var(--seafoam);background:var(--white)}
  .simple-modal-field textarea{min-height:100px;resize:vertical}
  .simple-modal-error{background:#fdf0f0;border:1px solid #f5c6c6;border-radius:var(--radius);padding:8px 12px;font-size:12px;color:var(--error);margin-bottom:14px;display:none}
  .simple-modal-actions{display:flex;gap:10px;margin-top:4px}
  .btn-modal-primary{flex:1;padding:11px;background:var(--ocean-surface);color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--t)}
  .btn-modal-primary:hover{background:var(--tide)}
  .btn-modal-cancel{padding:11px 20px;background:none;border:1.5px solid var(--border);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:var(--text-secondary);cursor:pointer;transition:all var(--t)}
  .btn-modal-cancel:hover{border-color:var(--text-secondary)}

  /* BO RECORDS SUB-TABS */
  .modal-sub-tabs-bo{display:flex;border-bottom:1px solid var(--border);background:var(--pearl);flex-shrink:0}
  .modal-sub-tab-bo{padding:8px 14px;font-size:11px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--t);white-space:nowrap}
  .modal-sub-tab-bo:hover{color:var(--tide)}
  .modal-sub-tab-bo.active{color:var(--ocean-surface);border-bottom-color:var(--seafoam);background:var(--white)}

  /* BS SYSTEM V3 */
  .bs-wrap{max-width:760px;margin:0 auto;padding:12px 16px 72px}
  .bs-hdr-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
  .bs-hdr-title{font-family:'Libre Baskerville',serif;font-size:24px;color:var(--ocean-deep);font-weight:700}
  .bs-meta-row{display:grid;grid-template-columns:1fr 1fr 1.3fr 1.3fr;gap:8px;margin-bottom:8px}
  .bs-meta-field{display:flex;flex-direction:column;gap:3px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px;justify-content:center}
  .bs-meta-lbl{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}
  .bs-meta-field input,.bs-meta-field select{border:none;outline:none;font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:var(--text-primary);background:transparent;width:100%;padding:0;cursor:pointer;appearance:none}
  .bs-room-group{display:flex;flex-direction:column;gap:3px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:7px 10px}
  .bs-room-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:2px}
  .bs-room-sub{display:flex;flex-direction:column;gap:2px}
  .bs-room-sub-lbl{font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-light)}
  .bs-room-sub input{border:1.5px solid var(--border);border-radius:var(--radius);outline:none;font-family:'IBM Plex Sans',sans-serif;font-size:13px;color:var(--text-primary);background:var(--pearl);width:100%;padding:4px 7px;box-sizing:border-box}
  .bs-room-group.bs-room-empty{border-color:var(--warning)}
  .bs-room-group.bs-room-empty .bs-meta-lbl{color:var(--warning)}
  .bs-mk-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:4px}
  .bs-mk-btn{padding:9px 14px;border:2px solid transparent;border-radius:var(--radius);cursor:pointer;font-family:'IBM Plex Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;transition:all var(--t);background:#a8d4e6;color:#1a3a5c}
  .bs-mk-btn:hover{opacity:.88;transform:translateY(-1px)}
  .bs-mk-btn.mk-status-ongoing{background:#2e86c1;border-color:#1a6fa8;color:#fff}
  .bs-mk-btn.mk-status-error{background:#e74c3c;border-color:#1a8a78;color:#fff}
  .bs-mk-btn.mk-status-complete{background:#27ae60;border-color:#1e8e4a;color:#fff}
  .bs-mk-btn.open{background:#1565a0!important;border-color:#fff!important;color:#fff!important;box-shadow:0 0 0 3px rgba(21,101,160,.35);transform:translateY(-1px)}
  .bs-mk-btn .bs-mk-arrow{font-size:10px;transition:transform .2s;display:inline-block}
  .bs-mk-btn.open .bs-mk-arrow{transform:rotate(180deg)}
  .bs-mk-panel{display:none;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;margin-bottom:8px}
  .bs-mk-panel.open{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
  .bs-tank-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px}
  .bs-tank-btn{padding:14px 8px;border:2.5px solid transparent;border-radius:var(--radius-lg);cursor:pointer;font-family:'IBM Plex Sans',sans-serif;font-size:17px;font-weight:700;transition:all var(--t);text-align:center;line-height:1.2;width:100%}
  .bs-tank-btn.st-empty{background:#a8d4e6;border-color:#7ab8d0;color:#1a3a5c}
  .bs-tank-btn.st-ongoing{background:#2e86c1;border-color:#1a6fa8;color:#fff}
  .bs-tank-btn.st-error{background:#e74c3c;border-color:#1a8a78;color:#fff}
  .bs-tank-btn.st-complete{background:#27ae60;border-color:#1e8e4a;color:#fff}
  .bs-tank-btn:hover{transform:translateY(-1px);opacity:.9}
  .bs-tank-btn.active{box-shadow:0 0 0 3px #fff,0 0 0 5px var(--ocean-surface);transform:translateY(-2px)}
  .bs-tank-panel{display:none}
  .bs-tank-panel.active{display:block}
  .bs-subtab-row{display:flex;gap:0;margin-bottom:0;border-bottom:2px solid var(--border)}
  .bs-subtab{flex:1;padding:9px 4px;border:none;border-bottom:3px solid transparent;cursor:pointer;font-family:'IBM Plex Sans',sans-serif;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px;transition:all var(--t);background:var(--pearl);color:var(--text-secondary);margin-bottom:-2px}
  .bs-subtab:hover{background:var(--sand);color:var(--tide)}
  .bs-subtab.active{background:var(--white);color:var(--ocean-surface);border-bottom-color:var(--seafoam)}
  .bs-stind{width:7px;height:7px;border-radius:50%;background:var(--border);flex-shrink:0;transition:background .3s}
  .bs-stind.done{background:var(--success)}
  .bs-stind.warn{background:var(--warning)}
  .bs-subpanel{display:none;background:var(--white);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:12px;grid-template-columns:1fr 1fr;gap:6px 14px}
  .bs-subpanel.active{display:grid}
  .bs-subpanel .bs-f-full{grid-column:span 2}
  .bs-sec-hdr{grid-column:span 2;font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ocean-surface);padding:6px 0 3px;border-bottom:1px solid var(--border);margin-bottom:2px}
  .bs-tank-sub{display:block;font-size:13px;font-weight:700;margin-top:3px;font-family:'IBM Plex Sans',sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;opacity:1}
  .bs-section{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden}
  .bs-section-hdr{padding:7px 12px;background:var(--pearl);border-bottom:1px solid var(--border);font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ocean-surface)}
  .bs-section-body{padding:10px 12px}
  .bs-f{display:flex;flex-direction:column;gap:2px;margin-bottom:0}
  .bs-f-lbl{font-size:10px;color:var(--text-secondary);font-weight:500;line-height:1.2}
  .bs-f input,.bs-f select,.bs-f textarea{padding:4px 8px;border:2px solid #3d6a8a;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:12px;color:var(--text-primary);background:var(--white);outline:none;width:100%;transition:border-color var(--t)}
  .bs-f select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%234a6275' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 7px center;padding-right:22px;cursor:pointer}
  .bs-f input:focus,.bs-f select:focus,.bs-f textarea:focus{border-color:var(--seafoam);box-shadow:0 0 0 2px rgba(74,158,187,.1)}
  .bs-f input[readonly]{background:var(--pearl);color:var(--text-secondary);cursor:default}
  .bs-f input.bs-computed{background:#e8f4e8;color:#1a5c30;font-weight:600;cursor:default;font-family:'IBM Plex Mono',monospace}
  .bs-f input.bs-deaths{border-color:#f0c0b0;background:#fff8f5}
  .bs-f input.bs-deaths:focus{border-color:var(--warning)}
  .bs-f textarea{min-height:90px;resize:vertical;font-size:12px;line-height:1.4}
  .bs-temp-warn{display:none;font-size:10px;color:var(--error);background:#fdf0f0;border:1px solid #f5c6c6;border-radius:4px;padding:4px 7px;margin-top:2px;line-height:1.3;font-weight:500;grid-column:span 2}
  .bs-temp-warn.visible{display:block}
  .bs-makeup-water-row{display:none}
  .bs-dilution-row{display:none}
  @media(max-width:1024px),(hover:none and pointer:coarse){
    .field-grid-2{grid-template-columns:1fr}
    .span-2{grid-column:span 1}
    .form-container{padding:16px 12px 80px}
    .bo-layout{grid-template-columns:1fr}
    .bo-meas-cols{grid-template-columns:1fr}
    .modal{max-height:100vh;border-radius:0}
    .stats-panel{grid-template-columns:1fr}
    .sidebar{transform:translateX(-100%);transition:transform .3s ease}
    .sidebar.open{transform:translateX(0)}
    .sidebar-mobile-footer{display:flex}
    .hamburger-btn{display:flex}
    .sidebar-pull-tab{display:flex}
    .main{left:0}
    .submit-bar{left:0}
  }
  /* Touch device override — catches all iPads/iPhones regardless of screen width
     or attached accessories (pointer:coarse fails when Magic Keyboard is connected). */
  html.touch .sidebar{transform:translateX(-100%);transition:transform .3s ease}
  html.touch .sidebar.open{transform:translateX(0)}
  html.touch .sidebar-mobile-footer{display:flex}
  html.touch .hamburger-btn{display:flex}
  html.touch .sidebar-pull-tab{display:flex}
  html.touch .main{left:0}
  html.touch .submit-bar{left:0}
  @media(max-width:600px){
    .bs-mk-panel.open{grid-template-columns:1fr}
    .bs-subpanel.active{grid-template-columns:1fr}
    .bs-subpanel .bs-f-full{grid-column:span 1}
  }

/* ══════════════════════════════════════════════
   HELP MODAL
══════════════════════════════════════════════ */
.help-modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:700px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .25s ease;overflow:hidden}
.help-modal-header{background:var(--ocean-mid);padding:14px 20px;border-bottom:2px solid var(--gold);display:flex;align-items:center;gap:12px;flex-shrink:0;min-height:54px}
.help-modal-title{font-family:'Libre Baskerville',serif;font-size:16px;color:var(--white);font-weight:700;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.help-back-btn{background:none;border:1px solid rgba(168,212,230,.4);border-radius:var(--radius);color:var(--foam);font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:600;padding:5px 12px;cursor:pointer;transition:all var(--t);display:inline-flex;align-items:center;gap:4px;flex-shrink:0}
.help-back-btn:hover{background:rgba(168,212,230,.15);border-color:var(--foam);color:var(--white)}
.help-modal-body{overflow-y:auto;flex:1;padding:22px 22px 32px;-webkit-overflow-scrolling:touch}

/* Home */
.help-home-intro{font-size:13px;color:var(--text-secondary);margin-bottom:16px;line-height:1.5}
.help-tile-grid{display:flex;flex-direction:column;gap:8px}
.help-tile{display:flex;align-items:center;gap:14px;padding:13px 16px;background:var(--white);border:1.5px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--t);text-align:left;width:100%;font-family:'IBM Plex Sans',sans-serif}
.help-tile:hover{border-color:var(--seafoam);background:var(--pearl);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.help-tile-icon{font-size:20px;width:28px;text-align:center;flex-shrink:0}
.help-tile-title{font-size:14px;font-weight:600;color:var(--text-primary);flex:1}
.help-tile-arrow{font-size:20px;color:var(--text-light);flex-shrink:0;line-height:1}

/* Steps */
.help-steps{display:flex;flex-direction:column}
.help-step{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}
.help-step:last-child{border-bottom:none}
.help-step-num{width:26px;height:26px;border-radius:50%;background:var(--ocean-surface);color:var(--white);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;font-family:'IBM Plex Mono',monospace}
.help-step-content{flex:1;min-width:0}
.help-step-heading{font-size:14px;font-weight:700;color:var(--ocean-deep);margin-bottom:5px}
.help-step-body{font-size:13px;color:var(--text-secondary);line-height:1.65}

/* UI illustration spans */
.help-ui-btn{display:inline-flex;align-items:center;padding:1px 8px;background:var(--ocean-surface);color:var(--white);border-radius:4px;font-size:11.5px;font-weight:600;font-family:'IBM Plex Sans',sans-serif;white-space:nowrap;vertical-align:middle;line-height:20px}
.help-ui-nav{display:inline-flex;align-items:center;padding:1px 7px 1px 5px;background:rgba(74,158,187,.12);color:var(--ocean-surface);border-left:3px solid var(--seafoam);border-radius:0 4px 4px 0;font-size:11.5px;font-weight:500;font-family:'IBM Plex Sans',sans-serif;white-space:nowrap;vertical-align:middle;line-height:20px}
.help-ui-tab{display:inline-flex;align-items:center;padding:1px 8px;background:var(--white);color:var(--ocean-surface);border:1.5px solid var(--border);border-bottom:2px solid var(--seafoam);border-radius:4px 4px 0 0;font-size:11px;font-weight:600;font-family:'IBM Plex Sans',sans-serif;white-space:nowrap;vertical-align:middle;line-height:20px}
.help-ui-code{display:inline;padding:1px 5px;background:var(--pearl);border:1px solid var(--border);border-radius:3px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--ocean-surface);white-space:nowrap;vertical-align:middle}
.help-ui-tag{display:inline-flex;align-items:center;padding:1px 7px;background:rgba(42,100,150,.1);color:var(--tide);border:1px solid rgba(42,100,150,.25);border-radius:10px;font-size:11px;font-weight:600;font-family:'IBM Plex Sans',sans-serif;white-space:nowrap;vertical-align:middle}

@media(max-width:820px){.help-modal{max-width:100%;max-height:100vh;border-radius:0}.help-modal-body{padding:16px 16px 28px}}
@media(max-width:480px){.help-tile{padding:12px 14px;gap:10px}.help-step{gap:10px}}

/* ══════════════════════════════════════════════
   VISUALIZATION TOPBAR BUTTON + DROPDOWN
══════════════════════════════════════════════ */
.viz-topbar-wrap{position:relative}
.viz-topbar-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;background:linear-gradient(135deg,rgba(26,58,92,.85) 0%,rgba(42,100,150,.65) 100%);border:1px solid rgba(74,158,187,.45);border-radius:var(--radius);color:var(--foam);font-family:'IBM Plex Sans',sans-serif;font-size:12px;font-weight:600;letter-spacing:.05em;cursor:pointer;transition:all var(--t);white-space:nowrap;min-height:34px}
.viz-topbar-btn:hover{background:linear-gradient(135deg,rgba(42,100,150,.95) 0%,rgba(74,158,187,.55) 100%);border-color:var(--seafoam);color:var(--white);box-shadow:0 2px 10px rgba(74,158,187,.2)}
.viz-topbar-btn.open{background:linear-gradient(135deg,var(--tide) 0%,var(--seafoam) 100%);border-color:var(--seafoam);color:var(--white);box-shadow:0 2px 14px rgba(74,158,187,.35)}
.viz-btn-icon{flex-shrink:0;opacity:.85;transition:opacity var(--t)}
.viz-topbar-btn:hover .viz-btn-icon,.viz-topbar-btn.open .viz-btn-icon{opacity:1}
.viz-btn-chevron{flex-shrink:0;transition:transform var(--t);opacity:.7}
.viz-topbar-btn.open .viz-btn-chevron{transform:rotate(180deg);opacity:1}

.viz-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:248px;background:var(--white);border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(10,22,40,.22),0 2px 8px rgba(10,22,40,.12);border:1px solid var(--border);overflow:hidden;display:none;z-index:200;animation:vizDropIn .18s ease}
.viz-dropdown.open{display:block}
@keyframes vizDropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.viz-dropdown-header{padding:9px 15px 8px;font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-light);background:var(--pearl);border-bottom:1px solid var(--border)}
.viz-dropdown-item{display:flex;align-items:center;gap:12px;padding:12px 15px;cursor:pointer;transition:background var(--t);border-bottom:1px solid var(--border)}
.viz-dropdown-item:last-child{border-bottom:none}
.viz-dropdown-item:hover{background:var(--pearl)}
.viz-dropdown-icon{width:36px;height:36px;border-radius:var(--radius);background:linear-gradient(135deg,var(--ocean-surface) 0%,var(--tide) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 6px rgba(10,22,40,.18)}
.viz-dropdown-label{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.2}
.viz-dropdown-desc{font-size:11px;color:var(--text-light);margin-top:2px;line-height:1.3}

/* ══════════════════════════════════════════════
   VISUALIZATION MODAL
══════════════════════════════════════════════ */
.viz-modal{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:1100px;display:flex;flex-direction:column;animation:slideUp .3s ease;margin:auto;max-height:92vh;overflow:hidden}
.viz-modal-body{overflow-y:auto;flex:1;padding:0;background:var(--sand);min-height:300px}
.viz-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-light);font-size:13px;gap:14px}
.viz-loading::before{content:'';width:28px;height:28px;border:3px solid rgba(74,158,187,.18);border-top-color:var(--seafoam);border-radius:50%;animation:spin .8s linear infinite}
.viz-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 20px;text-align:center}
.viz-placeholder-icon{font-size:42px;margin-bottom:16px;opacity:.55}
.viz-placeholder-title{font-family:'Libre Baskerville',serif;font-size:19px;color:var(--ocean-deep);font-weight:700;margin-bottom:8px}
.viz-placeholder-text{font-size:13px;color:var(--text-secondary);max-width:340px;line-height:1.65}

@media(max-width:820px){.viz-modal{max-height:100vh;border-radius:0}}
@media(max-width:600px){.viz-btn-label{display:none}.viz-topbar-btn{padding:7px 10px}}

/* ══════════════════════════════════════════════
   VISUALIZATION — BS SYSTEM CHARTS
══════════════════════════════════════════════ */
.viz-bs-wrap{display:flex;flex-direction:column;min-height:100%}
.viz-cohort-bar{display:flex;align-items:center;gap:12px;padding:13px 20px;background:var(--white);border-bottom:1px solid var(--border);flex-wrap:wrap}
.viz-cohort-bar-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}
.viz-cohort-pills{display:flex;gap:8px;flex-wrap:wrap}
.viz-cohort-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 13px;border-radius:20px;border:2px solid rgba(0,0,0,.1);background:var(--white);font-family:'IBM Plex Mono',monospace;font-size:11px;font-weight:600;cursor:pointer;transition:all var(--t);color:var(--text-light);opacity:.45;line-height:1}
.viz-cohort-pill.active{border-color:var(--ccolor,var(--seafoam));color:var(--ccolor,var(--ocean-surface));opacity:1;background:var(--pearl)}
.viz-cohort-pill-dot{width:8px;height:8px;border-radius:50%;background:var(--ccolor,var(--seafoam));flex-shrink:0}
.viz-pills-disabled{opacity:.3;pointer-events:none}
.viz-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px;align-items:start}
.viz-chart-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);padding:16px 18px 14px}
.viz-chart-title{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:12px;text-align:center}
.viz-chart-canvas-wrap{position:relative;height:200px}
.viz-chart-canvas-wrap-tall{position:relative;height:340px}
.viz-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}
.viz-empty-icon{font-size:36px;margin-bottom:12px;opacity:.5}
.viz-empty-text{font-size:14px;color:var(--text-secondary);max-width:280px;line-height:1.6}
.viz-filter-tabs{display:flex;background:var(--pearl);border-bottom:1px solid var(--border)}
.viz-filter-tab{padding:9px 20px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all var(--t);white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:'IBM Plex Sans',sans-serif;letter-spacing:.02em}
.viz-filter-tab:hover{color:var(--tide)}
.viz-filter-tab.active{color:var(--ocean-surface);border-bottom-color:var(--seafoam);background:var(--white)}
@media(max-width:820px){.viz-chart-grid{grid-template-columns:1fr;padding:12px}.viz-cohort-bar{padding:10px 14px}}
.viz-chart-card-full{grid-column:span 2}
.viz-al-inv-table{width:100%;border-collapse:collapse;font-size:13px}
.viz-al-inv-table th{padding:7px 12px;text-align:center;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);border-bottom:2px solid var(--border)}
.viz-al-inv-table th:first-child{text-align:left}
.viz-al-inv-table td{padding:7px 12px;text-align:center;border-bottom:1px solid var(--border)}
.viz-al-inv-sp{text-align:left!important;font-weight:600}
.viz-al-inv-cell{color:var(--text-light)}
.viz-al-inv-cell.has{color:var(--text);font-weight:600}
.viz-al-inv-total-cell{font-weight:700;color:var(--text)}
.viz-al-inv-totals td{font-weight:700;color:var(--text-secondary);border-top:2px solid var(--border);border-bottom:none}
.viz-al-cell-toggle-wrap{display:flex;gap:6px;margin-bottom:10px}
.viz-al-cell-btn{padding:4px 12px;border:1.5px solid var(--border);border-radius:20px;background:var(--white);font-size:11px;font-weight:600;cursor:pointer;color:var(--text-light);transition:all var(--t)}
.viz-al-cell-btn.active{border-color:var(--seafoam);color:var(--ocean-surface);background:var(--pearl)}
.viz-al-no-data{padding:24px;text-align:center;color:var(--text-light);font-size:13px}
.viz-sc-hr{border:none;border-top:1px solid var(--border);margin:0}
.viz-sc-loading{padding:20px 24px;font-size:13px;color:var(--text-light)}
.viz-sc-chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px;align-items:start}
@media(max-width:820px){.viz-sc-chart-grid{grid-template-columns:1fr;padding:12px}}
.viz-sc-formula{font-size:11px;font-weight:600;color:var(--text-primary);text-align:center;margin:-4px 0 12px;font-family:'IBM Plex Sans',sans-serif;white-space:nowrap}
.viz-ho-section-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);padding:4px 0 6px;border-bottom:1px solid var(--border);margin-bottom:10px}
.viz-vessel-pills{display:flex;flex-wrap:wrap;gap:5px;width:100%;max-height:130px;overflow-y:auto;align-content:flex-start;padding-top:8px}
@media(max-width:820px){.viz-chart-card-full{grid-column:span 1}}

/* ══════════════════════════════════════════════
   ALGAE FORM (al)
══════════════════════════════════════════════ */
/* ── ALGAE FORM ────────────────────────────────────────── */
.al-wrap{padding:20px 16px 48px;max-width:680px;margin:0 auto}
/* Landing — big centered category picker */
.al-landing-wrap{padding:20px 16px 48px;max-width:680px;margin:0 auto;display:flex;flex-direction:column;min-height:calc(100vh - 120px)}
.al-landing-cats{display:flex;gap:14px;align-items:center;padding:16px 0 2px}
.al-landing-cat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:28px 12px 24px;border-radius:16px;border:2px solid var(--border);background:var(--white);cursor:pointer;transition:all var(--t);color:var(--ocean-surface)}
.al-landing-cat:hover{border-color:var(--seafoam);background:var(--pearl);transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.al-landing-cat:active{transform:translateY(0);opacity:.7}
.al-landing-icon{display:flex;align-items:center;justify-content:center;height:68px}
.al-landing-icon svg{height:60px;width:auto}
.al-landing-label{font-size:16px;font-weight:700;color:var(--ocean-deep);font-family:'IBM Plex Sans',sans-serif;letter-spacing:.02em}
.al-landing-count{font-size:12px;color:var(--text-secondary);font-family:'IBM Plex Mono',monospace}
.al-hdr{display:flex;justify-content:center;align-items:flex-start;margin-bottom:20px;position:relative;padding-right:140px}
.al-hdr-title{font-family:'Libre Baskerville',serif;font-size:20px;font-weight:700;color:var(--ocean-deep);margin-bottom:4px}
.al-hdr-sub{font-size:13px;color:var(--text-secondary)}
.al-mode-toggle{display:flex;border-radius:10px;overflow:hidden;margin-bottom:0;transition:border-color var(--t)}
.al-toggle-culture{border:2px solid var(--ocean-surface)}
.al-toggle-health{border:2px solid #1a8a78}
.al-mode-btn{flex:1;padding:11px 14px;border:none;background:transparent;font-family:'IBM Plex Sans',sans-serif;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:background var(--t),color var(--t);min-width:0}
.al-toggle-culture .al-mode-btn{color:var(--ocean-surface)}
.al-toggle-culture .al-mode-btn+.al-mode-btn{border-left:2px solid var(--ocean-surface)}
.al-toggle-culture .al-mode-btn.active{background:var(--ocean-surface);color:var(--white)}
.al-toggle-health .al-mode-btn{color:#1a8a78}
.al-toggle-health .al-mode-btn+.al-mode-btn{border-left:2px solid #1a8a78}
.al-toggle-health .al-mode-btn.active{background:#1a8a78;color:var(--white)}
.al-mode-icon{display:flex;align-items:center;justify-content:center}
.al-mode-label{font-size:15px;font-weight:700;white-space:nowrap}
.al-mode-sub{font-size:11px;opacity:.8;white-space:normal;text-align:center;line-height:1.3}
.al-mode-stripe{height:4px;border-radius:2px;margin:14px 0 16px}
.al-stripe-culture{background:var(--ocean-surface)}
.al-stripe-health{background:#1a8a78}
.al-hdr-right-btns{position:absolute;right:0;top:0;display:flex;flex-direction:column;gap:8px;align-items:flex-end}
.al-new-btn{padding:9px 16px;background:var(--ocean-surface);color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background var(--t);white-space:nowrap}
.al-new-btn:hover{background:var(--tide)}
.al-spec-btn{padding:9px 16px;background:#2c6e49;color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:background var(--t);white-space:nowrap}
.al-spec-btn:hover{background:#1e5035}
.al-spec-modal{max-width:640px}
.al-spec-body{padding:0;display:flex;flex-direction:column;overflow:hidden}
.al-spec-phase1{display:flex;flex-direction:column;overflow:hidden}
.al-spec-filter-bar{display:flex;gap:6px;padding:12px 16px 10px;flex-shrink:0;border-bottom:1px solid var(--border)}
.al-spec-filter-btn{padding:6px 14px;border:1px solid var(--border);border-radius:20px;background:var(--white);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all var(--t)}
.al-spec-filter-btn.active{background:#2c6e49;border-color:#2c6e49;color:var(--white)}
.al-spec-vessel-list{overflow-y:auto;max-height:360px;padding:4px 0}
.al-spec-vessel-row{display:flex;align-items:center;gap:8px;padding:10px 16px;cursor:pointer;border-bottom:1px solid var(--border-light);transition:background var(--t)}
.al-spec-vessel-row:hover{background:var(--sand)}
.al-spec-vessel-nick{font-weight:600;color:var(--ocean-deep);min-width:58px;font-size:14px;font-family:'IBM Plex Sans',sans-serif}
.al-spec-vessel-num{color:var(--text-secondary);font-size:13px;min-width:34px;font-family:'IBM Plex Sans',sans-serif}
.al-spec-vessel-size{color:var(--text-secondary);font-size:12px;min-width:48px;font-family:'IBM Plex Sans',sans-serif}
.al-spec-vessel-strain{color:var(--text-secondary);font-size:12px;font-family:'IBM Plex Sans',sans-serif;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.al-spec-vessel-date{color:var(--text-light);font-size:12px;white-space:nowrap;font-family:'IBM Plex Sans',sans-serif}
.al-spec-empty{padding:24px 16px;color:var(--text-secondary);text-align:center;font-size:13px}
.al-spec-phase2{display:flex;flex-direction:column}
.al-spec-back-btn{background:none;border:none;color:#2c6e49;font-size:13px;font-weight:600;cursor:pointer;padding:8px 16px 4px;text-align:left;flex-shrink:0}
.al-spec-back-btn:hover{color:#1e5035}
.al-spec-session-hdr{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;padding:6px 16px 8px;border-bottom:1px solid var(--border);flex-shrink:0}
.al-spec-hdr-item{display:flex;flex-direction:column;padding:3px 4px}
.al-spec-hdr-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-light);font-weight:600}
.al-spec-hdr-val{font-size:13px;color:var(--ocean-deep);font-weight:600;margin-top:1px;font-family:'IBM Plex Sans',sans-serif}
.al-spec-vol-row{display:flex;align-items:center;gap:10px;padding:8px 16px;border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}
.al-spec-vol-lbl{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap}
.al-spec-vol-input{width:90px;padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:'IBM Plex Sans',sans-serif}
.al-spec-vol-input:focus{outline:none;border-color:#2c6e49;box-shadow:0 0 0 3px rgba(44,110,73,.15)}
.al-spec-vol-err{font-size:11px;color:var(--red)}
.al-spec-table-scroll{overflow-x:auto;padding:0 16px}
.al-spec-table{width:100%;border-collapse:collapse;font-size:13px;margin:6px 0;font-family:'IBM Plex Sans',sans-serif}
.al-spec-th{padding:6px 6px;background:var(--sand);font-weight:600;font-size:11px;text-align:center;border-bottom:2px solid var(--border);color:var(--text-secondary);white-space:nowrap;line-height:1.3;font-family:'IBM Plex Sans',sans-serif}
.al-spec-td{padding:2px 4px;border-bottom:1px solid var(--border-light);text-align:center;vertical-align:top}
.al-spec-td-input{vertical-align:top;padding:2px 4px}
.al-spec-td-dil{font-weight:600;color:var(--text-secondary);font-size:12px;font-family:'IBM Plex Sans',sans-serif;vertical-align:middle}
.al-spec-td-calc{color:var(--text-secondary);font-size:12px;font-family:'IBM Plex Sans',sans-serif;min-width:44px;vertical-align:middle}
.al-spec-input{padding:5px 4px;border:1px solid var(--border);border-radius:4px;font-size:13px;font-family:'IBM Plex Sans',sans-serif;text-align:center;display:block}
.al-spec-abs-input{width:70px}
.al-spec-cells-input{width:122px}
.al-spec-input:focus{outline:none;border-color:#2c6e49}
.al-spec-input.bs-input-err{border-color:var(--red);background:#fff5f5}
.al-spec-row-err{display:block;font-size:10px;color:var(--red);min-height:0;line-height:1.3;white-space:nowrap;font-family:'IBM Plex Sans',sans-serif}
.al-spec-err-msg{display:none;margin:6px 16px 0;padding:9px 12px;background:#fff0f0;border:1px solid var(--red);border-radius:var(--radius);color:var(--red);font-size:13px;font-family:'IBM Plex Sans',sans-serif;flex-shrink:0}
.al-spec-save-row{padding:10px 16px 12px;border-top:1px solid var(--border);flex-shrink:0}
.al-spec-save-btn{width:100%;padding:11px;background:#2c6e49;color:var(--white);border:none;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:background var(--t);font-family:'IBM Plex Sans',sans-serif}
.al-spec-save-btn:hover:not(:disabled){background:#1e5035}
.al-spec-save-btn:disabled{opacity:.6;cursor:default}
/* Category buttons */
.al-cat-bar{display:flex;gap:8px;margin-bottom:20px}
.al-cat-bar.has-sub-bar{margin-bottom:6px}
.al-sub-bar{display:flex;gap:8px;margin-bottom:16px}
.al-sub-slot{flex:1;display:flex;gap:4px}
.al-sub-btn{flex:1;padding:4px 2px;border-radius:6px;border:1.5px solid var(--border);background:var(--white);cursor:pointer;color:var(--text-secondary);font-size:10px;font-weight:600;font-family:'IBM Plex Sans',sans-serif;letter-spacing:.03em;transition:all var(--t)}
.al-sub-btn:hover{border-color:var(--seafoam);color:var(--ocean-surface)}
.al-sub-btn.active{border-color:var(--seafoam);background:var(--pearl);color:var(--ocean-deep)}
.al-cat-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 8px 5px;border-radius:10px;border:2px solid var(--border);background:var(--white);cursor:pointer;color:var(--text-secondary);font-size:11px;font-weight:600;font-family:'IBM Plex Sans',sans-serif;letter-spacing:.04em;transition:all var(--t);line-height:1}
.al-cat-icon{height:18px;display:flex;align-items:center;justify-content:center}
.al-cat-btn svg{height:16px;width:auto;display:block}
.al-cat-btn:hover{border-color:var(--seafoam);color:var(--ocean-surface)}
.al-cat-btn.active{border-color:var(--seafoam);background:var(--pearl);color:var(--ocean-deep);box-shadow:var(--shadow-sm)}
/* Mode-tinted borders on category/sub buttons */
.al-wrap-culture .al-landing-cat,.al-wrap-culture .al-cat-btn,.al-wrap-culture .al-sub-btn{border-color:rgba(26,58,92,0.22)}
.al-wrap-health .al-landing-cat,.al-wrap-health .al-cat-btn,.al-wrap-health .al-sub-btn{border-color:rgba(26,138,120,0.28)}
/* Inventory panels */
.al-panel{padding:0 2px}
.al-size-group{margin-bottom:16px}
.al-size-lbl{font-size:10px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--text-secondary);padding-bottom:6px;margin-bottom:10px;border-bottom:1px solid var(--border)}
.al-vessel-row{display:flex;flex-wrap:wrap;gap:12px 20px;align-items:flex-end}
.al-vessel{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:opacity var(--t),transform var(--t);opacity:.88}
.al-vessel:hover{opacity:1;transform:translateY(-4px)}
.al-vessel:active{transform:translateY(0);opacity:.65}
.al-flask-lbl{text-align:center;margin-top:4px;min-width:56px}
.al-flask-sp{font-size:10px;font-weight:700;color:var(--ocean-deep);font-family:'IBM Plex Mono',monospace;letter-spacing:.02em;margin-bottom:1px}
.al-flask-meta{font-size:9px;color:var(--text-secondary);line-height:1.5}
.al-flask-id{font-size:9px;color:var(--text-light);font-family:'IBM Plex Mono',monospace;letter-spacing:.02em}
.al-empty{padding:32px 0;color:var(--text-light);font-size:14px;text-align:center}
/* Bag grid */
.al-bag-grid{display:flex;flex-direction:column;gap:2px}
.al-bag-grid-row{padding:4px 4px 2px;border-radius:8px;transition:background .2s}
.al-bag-grid-row.highlighted{background:rgba(26,58,92,0.07);outline:1.5px solid var(--border)}
.al-bag-row-lbl{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:3px}
.al-bag-grid-row.highlighted .al-bag-row-lbl{color:var(--ocean-deep)}
.al-bag-row-cells{display:flex;justify-content:space-between;gap:4px}
.al-bag-cell{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1}
.al-bag-cell-occ{cursor:pointer;transition:opacity var(--t),transform var(--t)}
.al-bag-cell-occ:hover{opacity:.85;transform:translateY(-2px)}
.al-bag-cell-occ:active{transform:translateY(0);opacity:.65}
.al-bag-cell-empty svg{opacity:.18}
.al-bag-cell-lbl{font-size:8px;line-height:1.25;text-align:center;color:var(--text-secondary);font-weight:600;font-family:'IBM Plex Mono',monospace}
.al-bag-last-hc{color:#c0392b}
/* Vessel action modal */
.al-vessel-modal{max-width:520px}
#modal-al-vessel.al-modal-health .modal-header{background:#1a8a78 !important;border-bottom-color:#12665a !important}
#modal-al-vessel.al-modal-health .al-action-btn{color:#1a8a78}
#modal-al-vessel.al-modal-health .al-action-btn:hover{border-color:#1a8a78;background:rgba(26,138,120,.06)}
#modal-al-vessel.al-modal-health .al-action-selected{background:#1a8a78;border-color:#1a8a78;color:var(--white)}
#modal-al-vessel.al-modal-health .al-modal-sp{color:#1a8a78}
.al-modal-info{padding:20px 24px 16px;border-bottom:1px solid var(--border)}
.al-modal-info-top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:6px}
.al-modal-sp{font-size:18px;font-weight:700;color:var(--ocean-deep);font-family:'IBM Plex Sans',sans-serif}
.al-modal-num{font-size:15px;font-weight:600;color:var(--text-secondary);font-family:'IBM Plex Mono',monospace}
.al-modal-details{font-size:12px;color:var(--text-secondary);margin-bottom:4px;display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.al-modal-dot{color:var(--border)}
.al-modal-strain{font-size:11px;color:var(--text-light)}
.al-modal-actions-wrap{padding:18px 24px 24px}
/* Health check form */
.al-hc-form{padding:14px 20px 20px;display:flex;flex-direction:column;gap:14px}
.al-hc-section-lbl{font-size:11px;font-weight:700;letter-spacing:.03em;color:var(--text-secondary);margin-bottom:4px;display:flex;align-items:baseline;gap:5px}
.al-hc-section-sub{font-size:10px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--text-light)}
.al-hc-cell-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.al-hc-bottom{display:flex;align-items:flex-end;justify-content:space-between;gap:12px}
.al-hc-fields{display:flex;flex-direction:row;gap:8px}
.al-hc-field{display:flex;flex-direction:column;gap:3px}
.al-hc-lbl{font-size:11px;font-weight:600;color:var(--text-secondary)}
.al-hc-input{width:100%;padding:7px 8px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:'IBM Plex Mono',monospace;color:var(--text-primary);background:var(--white);outline:none;transition:border-color var(--t)}
.al-hc-input:focus{border-color:#1a8a78}
.al-hc-cell{text-align:center;padding:7px 4px}
.al-hc-sm{width:72px}
.al-hc-btns{display:flex;flex-direction:column;gap:6px;flex-shrink:0;align-items:stretch}
.al-hc-calc-btn,.al-hc-save-btn{padding:9px 20px;color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--t);white-space:nowrap}
.al-hc-calc-btn{background:#1a8a78}
.al-hc-calc-btn:hover{background:#12665a}
.al-hc-calc-btn:disabled{opacity:.6;cursor:default}
.al-hc-save-btn{background:var(--ocean-surface)}
.al-hc-save-btn:hover{background:var(--ocean-mid)}
.al-hc-save-btn:disabled{opacity:.6;cursor:default}
.al-hc-results-row{display:flex;gap:10px;padding-top:10px;border-top:1px solid var(--border)}
.al-hc-result-field{display:flex;flex-direction:column;gap:3px;flex:1}
.al-hc-result-box{padding:7px 8px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:'IBM Plex Mono',monospace;color:#1a8a78;background:var(--pearl);min-height:36px;font-weight:600}
.al-notes-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border:1.5px solid rgba(255,255,255,0.35);border-radius:var(--radius);background:transparent;color:var(--foam);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--t);white-space:nowrap}
.al-notes-btn:hover{background:rgba(255,255,255,0.12)}
.al-notes-btn.active{background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.6)}
.al-notes-panel{display:none;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--pearl)}
.al-notes-panel.open{display:block}
.al-notes-ta{width:100%;box-sizing:border-box;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:'IBM Plex Sans',sans-serif;resize:vertical;min-height:64px;background:var(--white);color:var(--text)}
.al-modal-actions-lbl{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:14px}
.al-action-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px;justify-content:center}
.al-action-group-label,.al-action-group-sizes{display:flex;gap:8px;align-items:center}
.al-action-btn-sub{display:block;font-size:10px;font-weight:400;opacity:.75;letter-spacing:.01em}
.al-action-btn{flex:1;min-width:72px;padding:11px 10px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--white);font-family:'IBM Plex Sans',sans-serif;font-size:13px;font-weight:600;color:var(--ocean-surface);cursor:pointer;transition:all var(--t);text-align:center}
.al-action-btn:hover{border-color:var(--seafoam);background:var(--pearl)}
.al-action-selected{background:var(--ocean-deep);color:var(--white);border-color:var(--ocean-deep);opacity:.85;cursor:default}
.al-view-only-notice{width:100%;text-align:center;padding:12px 0;color:var(--text-muted);font-size:.85rem;font-style:italic}
.al-action-dump{color:var(--error);border-color:rgba(180,50,50,.25)}
.al-action-dump:hover{background:rgba(180,50,50,.06);border-color:var(--error)}
.al-action-fed{color:var(--warning);border-color:rgba(230,126,34,.25)}
.al-action-fed:hover{background:rgba(230,126,34,.06);border-color:var(--warning)}
.al-action-done{color:var(--white);background:var(--success);border-color:var(--success);margin-bottom:8px}
.al-action-done:hover{background:#1a8a40;border-color:#1a8a40}
.al-action-done-outline{color:#2aaa58;background:transparent;border-color:#2aaa58}
.al-action-done-outline:hover{background:rgba(42,170,88,.08)}
.al-dump-confirm{display:flex;flex-direction:column;align-items:center;gap:14px;padding:28px 20px 20px}
.al-dump-vessel{opacity:.75}
.al-dump-lbl{font-size:13px;font-weight:700;color:var(--text-secondary);font-family:'IBM Plex Mono',monospace;letter-spacing:.04em}
.al-dump-btns{display:flex;gap:10px}
.al-action-bag-picker{padding:6px 0 4px}
.al-bag-picker-row{display:flex;gap:8px;align-items:center}
.al-picker-select{flex:1;min-width:0;font-size:13px;padding:6px 8px;height:38px}
.al-picker-place-btn{flex-shrink:0}
.al-action-cancel-outline{color:#cc3333;background:transparent;border-color:#cc3333}
.al-action-confirm{font-size:12px;color:var(--success);font-family:'IBM Plex Mono',monospace;font-weight:600;padding:4px 0 6px;letter-spacing:.02em;width:100%;text-align:center;white-space:nowrap}
/* New culture modal */
.al-new-form{padding:20px 24px 24px}
.al-new-field{margin-bottom:16px}
.al-new-label{display:block;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:6px}
.al-new-actions{display:flex;gap:10px;margin-top:24px}
/* Hatchery Operations — Pumping Water modal */
.ho-pump-modal{max-width:680px!important}
.ho-pump-body{padding:20px 20px 24px}
.ho-pump-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:repeat(5,auto);column-gap:12px;row-gap:10px;margin-bottom:20px}
.ho-pump-col{border-radius:10px;padding:16px 14px;grid-row:1 / span 5;display:grid;grid-template-rows:subgrid;align-content:start}
.ho-pump-col-river{background:#eef4fb;border:1.5px solid #c5d9ee}
.ho-pump-col-storage{background:#eef7f0;border:1.5px solid #b8dfc2}
.ho-pump-col-calc{background:#fdf8ee;border:1.5px solid #e8d8a8}
.ho-pump-col-title{font-size:12px;font-weight:700;letter-spacing:.01em;color:var(--ocean-deep);padding-bottom:8px;border-bottom:1px solid rgba(0,0,0,.08);margin-bottom:2px}
.ho-pump-field{display:flex;flex-direction:column;gap:4px}
.ho-pump-label-row{display:flex;align-items:baseline;gap:6px}
.ho-pump-lbl{font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--text-secondary)}
.ho-pump-lbl-sub{display:block;font-size:9px;font-weight:500;letter-spacing:0;color:var(--text-secondary);opacity:.75;margin-top:1px;font-style:italic}
.ho-pump-cvt{font-size:10px;color:var(--text-secondary);font-style:italic}
.ho-pump-sublbl{font-size:10px;color:var(--text-secondary);margin-top:-2px;margin-bottom:2px}
.ho-pump-input{width:100%;padding:8px 10px;border:1.5px solid rgba(0,0,0,.15);border-radius:7px;font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:var(--text-primary);background:var(--white);outline:none;box-sizing:border-box;transition:border-color var(--t)}
.ho-pump-input:focus{border-color:var(--seafoam)}
.ho-pump-readonly{background:#f0f2f4;color:var(--text-secondary);cursor:default}
.ho-pump-result{background:#fffdf5;color:var(--ocean-deep);font-weight:600;cursor:default}
.ho-pump-actions{display:flex;justify-content:flex-end;gap:10px}
.ho-pump-calc-btn{padding:11px 28px;background:var(--ocean-mid);color:var(--white);border:none;border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background var(--t)}
.ho-pump-calc-btn:hover:not(:disabled){background:var(--ocean-deep)}
.ho-pump-calc-btn:disabled{opacity:0.35;cursor:not-allowed}
.ho-pump-close-btn{padding:11px 24px;background:transparent;color:var(--text-secondary);border:1.5px solid var(--border);border-radius:var(--radius);font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--t)}
.ho-pump-close-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}
.ho-pump-input.ho-pump-error{border-color:#c0392b!important;background:#fff5f5!important}
.ho-pump-err-msg{font-size:10px;color:#c0392b;margin-top:3px;font-weight:500}
@media(max-width:600px){.ho-pump-grid{grid-template-columns:1fr}.ho-pump-modal{max-width:98vw!important}}
/* Hatchery Operations tide card */
.ho-tide-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:20px 24px 16px;margin-bottom:24px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.ho-tide-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.ho-tide-label{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}
.ho-tide-now{font-size:13px;color:var(--text-secondary);font-variant-numeric:tabular-nums}
.ho-tide-chart-wrap{position:relative;height:80px;margin-bottom:16px}
.ho-tide-chart-wrap canvas{width:100%!important;height:100%!important}
.ho-tide-loading{font-size:13px;color:var(--text-secondary);text-align:center;padding:12px 0}
.ho-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:600px){.ho-stat-row{grid-template-columns:repeat(2,1fr)}}
.ho-tide-stat{display:flex;flex-direction:column;gap:3px;padding:10px 12px;background:#f7f8f9;border-radius:10px}
.ho-stat-lbl{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary)}
.ho-stat-val{font-size:15px;font-weight:700;color:var(--ocean-deep);font-variant-numeric:tabular-nums}
.ho-stat-sub{font-size:12px;color:var(--text-secondary)}
.ho-stat-away{color:#4a9ebb;font-weight:600}
/* Hatchery Operations landing */
.ho-landing{display:flex;gap:32px;justify-content:center;align-items:flex-start;padding:0 24px 48px;flex-wrap:wrap}
.ho-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;padding:36px 28px;background:var(--white);border:2px solid var(--border);border-radius:14px;cursor:pointer;font-family:'IBM Plex Sans',sans-serif;width:200px;flex:0 0 200px;height:240px;transition:all var(--t);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.ho-btn:hover{border-color:var(--seafoam);box-shadow:0 6px 18px rgba(74,158,187,.18);transform:translateY(-3px)}
.ho-btn-icon{display:flex;align-items:center;justify-content:center}
.ho-btn-label{font-size:16px;font-weight:700;color:var(--ocean-deep);text-align:center;line-height:1.3}
/* Outdoor Nursery */
.on-back-btn{flex-shrink:0;background:#fff;border:2px solid #1a3a5c;border-radius:8px;padding:8px 18px;font-size:14px;font-weight:700;color:#1a3a5c;cursor:pointer;transition:all var(--t);white-space:nowrap;margin-top:4px}
.on-back-btn:hover{background:#1a3a5c;color:#fff}
.on-coming-soon{color:var(--text-light);font-size:15px;text-align:center;padding:60px 0}
.on-full-width{max-width:none!important;padding-top:8px!important;padding-bottom:16px!important;overflow-x:hidden;height:calc(100vh - 56px);display:flex;flex-direction:column;box-sizing:border-box;overflow-y:hidden}
.on-lb-page-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:8px;padding-bottom:10px;border-bottom:2px solid var(--border);flex-shrink:0}
.fm-page-header{padding-left:16px;padding-right:16px;margin-bottom:6px;padding-bottom:6px;align-items:center}
.fm-page-header .form-title{font-size:18px}
.fm-page-header .on-back-btn{padding:5px 12px;font-size:13px}
.on-lb-platform{background:#888b8e;border-radius:10px;padding:20px 20px 10px;display:flex;flex-direction:column;height:calc(100vh - 210px);width:calc(4 * (200vh - 189px) / 7 + 82px);margin:0 auto}
.on-fl-platform.on-lb-platform,.on-fs-platform.on-lb-platform{flex:1;min-height:0;height:auto}
.on-lb-tanks-row{display:flex;gap:14px;align-items:stretch;flex:1;min-height:0;justify-content:center}
.on-lb-tank{flex:1;background:#fff;border:1.5px solid #ccc;border-radius:6px;padding:8px 4px;display:flex;flex-direction:column;gap:6px;min-width:0;height:100%;max-width:calc((200vh - 189px) / 7)}
.on-lb-tank-label{font-size:11px;font-weight:700;text-align:center;color:#555;letter-spacing:.5px;text-transform:uppercase}
.on-lb-tank-body{display:flex;flex-direction:row;gap:3px;flex:1;min-height:0}
.on-lb-col{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}
.on-lb-silo-row{display:flex;align-items:center;justify-content:space-between;gap:3px;flex:1}
.on-lb-trough{width:calc((100vh - 282px) / 70);min-width:6px;max-width:16px;flex-shrink:0;background:#fff;border-left:1px solid #ddd;border-right:1px solid #ddd}
.on-lb-silo{border-radius:50%;border:2.5px solid #bbb;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;flex:0 0 auto;align-self:stretch;height:100%;aspect-ratio:1/1;max-width:calc(100% - 21px);transition:filter .15s,transform .15s;box-sizing:border-box}
.on-lb-silo:hover{filter:brightness(0.90);transform:scale(1.06)}
.on-silo-empty{background:#e8e5df;border-color:#bbb;color:#999}
.on-silo-oyster{background:#c8e6f5;color:#2a6090}
.on-silo-clam{background:#f0dfc0;color:#7a5030}
.on-silo-scallop{background:#f0b8d0;color:#7a1840}
.on-lb-silo.on-mesh-active{border-color:var(--mesh-color)}
.on-silo-grid{display:flex;flex-direction:column;justify-content:space-between;position:absolute;inset:12%;padding:4px 0;pointer-events:none}
.on-silo-top{font-size:7px;font-weight:600;line-height:1;white-space:nowrap;overflow:hidden}
.on-silo-bot{font-size:8px;font-weight:600;line-height:1;white-space:nowrap;overflow:hidden}
.on-lb-silo-strain{font-size:var(--lb-strain-fs,9px);text-align:center}
.on-lb-silo .on-silo-bot{font-size:var(--lb-bot-fs,8px)}
.on-lb-silo .on-silo-bot-sm{font-size:var(--lb-bot-sm-fs,8px)}
.on-silo-top b{font-weight:800}
.on-silo-mid{text-align:center;font-size:8px;font-weight:700;line-height:1.3;padding:1px 0}
.on-silo-empty-label{font-size:8px;font-weight:600;pointer-events:none;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap}
/* FL/FS bins are rectangles — tighter inset */
.on-fl-bin .on-silo-grid,.on-fs-silo .on-silo-grid{inset:6%}
.on-fl-bin .on-silo-top,.on-fs-silo .on-silo-top{font-size:12px}
.on-fl-bin .on-silo-mid,.on-fs-silo .on-silo-mid{font-size:13px}
.on-fl-bin .on-silo-bot,.on-fs-silo .on-silo-bot{font-size:11px}
.on-mesh-legend{display:flex;gap:16px;align-items:center;justify-content:center;padding:0 0 10px}
.on-mesh-legend-item{display:flex;align-items:center;gap:6px;font-size:10px;color:#fff;font-weight:600}
.on-mesh-legend-swatch{width:22px;height:14px;border-radius:3px;flex-shrink:0}
.on-lb-silo-num{font-size:8px;font-weight:700;color:#333;line-height:1;pointer-events:none;flex-shrink:0;min-width:14px}
.on-lb-num-left{text-align:right}
.on-lb-num-right{text-align:left}
.on-silo-selected{box-shadow:inset 0 0 0 3px #1a78e0,inset 0 0 0 100px rgba(26,120,224,0.18);position:relative;z-index:1}
.on-lb-silo.on-silo-selected{transform:scale(1.1)}
.on-silo-staged{box-shadow:0 0 0 3px #c9a84c,0 0 0 5px rgba(255,255,255,0.6);opacity:.72}
.on-silo-putback-target{outline:3px solid #22a045;outline-offset:3px;box-shadow:inset 0 0 0 100px rgba(34,160,69,0.18);cursor:pointer;animation:on-pulse-green 1.4s ease-in-out infinite}
@keyframes on-pulse-green{0%,100%{outline-color:#22a045}50%{outline-color:#5fd080}}
.on-select-btn{margin-left:auto;padding:6px 14px;border-radius:6px;border:2px solid #1a3a5c;background:#fff;color:#1a3a5c;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,color .15s}
.on-select-btn.active{background:#1a3a5c;color:#fff}
.on-select-btn-locked{cursor:default;opacity:.8}
.on-combine-btn{margin-left:auto;padding:6px 16px;border-radius:6px;border:none;background:#1a3a5c;color:#fff;font-size:13px;font-weight:700;cursor:pointer}
/* Staging screen */
.on-staging-list{display:flex;flex-direction:column;gap:12px;padding:16px 0;max-width:700px;margin:0 auto}
.on-staging-card{background:#fff;border:1.5px solid #ddd;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:opacity .2s}
.on-staging-card-done{opacity:.55}
.on-staging-card-grading{border-color:#1a78e0;background:#f0f6ff}
.on-staging-grading-tag{font-size:12px;font-weight:700;color:#1a78e0;white-space:nowrap}
.on-staging-card-top{display:flex;align-items:center;gap:12px}
.on-staging-check-wrap{flex-shrink:0}
.on-staging-check{width:18px;height:18px;cursor:pointer;accent-color:#1a3a5c}
.on-staging-chip{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;flex-shrink:0}
.on-staging-chip.on-silo-oyster,.on-staging-chip.fm-bag-oyster{background:#c8e6f5;color:#2a6090}
.on-staging-chip.on-silo-clam,.on-staging-chip.fm-bag-clam{background:#f0dfc0;color:#7a5030}
.on-staging-chip.on-silo-scallop,.on-staging-chip.fm-bag-scallop{background:#f0b8d0;color:#7a1840}
/* ON hub action buttons — keep for production on.js compatibility */
.on-hub-actions{display:flex;justify-content:center;padding:0 24px 32px;margin-top:-24px}
.on-place-cohort-btn{padding:11px 28px;background:#fff;border:2px solid #1a3a5c;border-radius:8px;color:#1a3a5c;font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;letter-spacing:.02em}
.on-staging-chip.on-silo-empty{background:#e8e5df;color:#999}
.on-staging-chip.on-silo-mixed{background:linear-gradient(135deg,#c8e6f5 50%,#f0dfc0 50%);color:#444}
.on-staging-chip.fm-bag-seed{background:#d8efc0;color:#3a6010}
.on-staging-chip.fm-bag-mussel{background:#d4b0e8;color:#4a1060}
.on-staging-card-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.on-staging-source{font-size:13px;font-weight:700;color:#1a3a5c}
.on-staging-detail{font-size:12px;color:#555}
.on-staging-done-tag{font-size:12px;font-weight:700;color:#2a7a44;white-space:nowrap}
.on-staging-actions{display:flex;gap:8px;flex-wrap:wrap;padding-left:30px}
.on-action-btn{padding:6px 14px;border-radius:6px;border:1.5px solid #1a3a5c;background:#fff;color:#1a3a5c;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}
.on-action-btn:hover{background:#1a3a5c;color:#fff}
.on-action-btn-primary{background:#1a3a5c;color:#fff}
.on-action-btn-primary:hover{background:#0f2540}
.on-action-btn-lg{padding:8px 20px;font-size:13px}
.on-action-btn-disabled{opacity:.4;cursor:not-allowed!important}
.on-undo-combine-btn{margin-left:auto;padding:4px 10px;border-radius:5px;border:1.5px solid #c9a84c;background:#fff;color:#a07828;font-size:11px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;flex-shrink:0}
.on-undo-combine-btn:hover{background:#c9a84c;color:#fff}
/* Grade screen */
.on-grade-body{max-width:700px;margin:0 auto;padding-bottom:24px}
.on-grade-rows{display:flex;flex-direction:column;gap:12px;margin-bottom:14px}
.on-grade-row{background:#fff;border:1.5px solid #ddd;border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.on-grade-row-label{font-size:11px;font-weight:700;color:#1a3a5c;text-transform:uppercase;letter-spacing:.06em}
.on-grade-row-fields{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.on-grade-select{flex:1;min-width:140px;padding:9px 12px;border:1.5px solid #ccc;border-radius:6px;font-size:14px;font-family:inherit;color:#1a2a3a;background:#fff;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234a6275' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px;cursor:pointer}
.on-grade-select:focus{border-color:#1a3a5c;outline:none;box-shadow:0 0 0 3px rgba(26,58,92,.1)}
.on-grade-row-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.on-grade-dir-toggle{display:flex;border:1.5px solid #ccc;border-radius:6px;overflow:hidden;flex-shrink:0}
.on-grade-dir-btn{padding:8px 14px;background:#fff;border:none;font-size:13px;font-weight:600;color:#555;cursor:pointer;transition:background .15s,color .15s;line-height:1;white-space:nowrap}
.on-grade-dir-btn.active{background:#1a3a5c;color:#fff}
.on-grade-dir-toggle .on-grade-dir-btn+.on-grade-dir-btn{border-left:1.5px solid #ccc}
.on-grade-vol-wrap{display:flex;align-items:center;gap:8px;flex-shrink:0}
.on-grade-unit-toggle{display:flex;border:1.5px solid #ccc;border-radius:6px;overflow:hidden}
.on-grade-unit-btn{padding:8px 13px;background:#fff;border:none;font-size:13px;font-weight:600;color:#555;cursor:pointer;transition:background .15s,color .15s;line-height:1}
.on-grade-unit-btn.active{background:#1a3a5c;color:#fff}
.on-grade-vol-input{width:110px;padding:9px 10px;border:1.5px solid #ccc;border-radius:6px;font-size:14px;font-family:inherit;color:#1a2a3a}
.on-grade-vol-input:focus{border-color:#1a3a5c;outline:none;box-shadow:0 0 0 3px rgba(26,58,92,.1)}
.on-grade-remove-btn{background:none;border:none;color:#bbb;font-size:18px;cursor:pointer;padding:4px 6px;line-height:1;transition:color .15s;flex-shrink:0}
.on-grade-remove-btn:hover{color:#c0392b}
.on-grade-remove-placeholder{width:30px;flex-shrink:0}
.on-grade-add-btn{width:100%;padding:12px;border:2px dashed #ccc;border-radius:8px;background:#fff;color:#888;font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}
.on-grade-add-btn:hover{border-color:#1a3a5c;color:#1a3a5c}
.on-grade-error{font-size:13px;color:#c0392b;font-weight:600;min-height:18px;text-align:center;margin-bottom:4px}
.on-grade-place-btn{width:100%;margin-top:10px;padding:11px;background:#1a3a5c;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;letter-spacing:.01em;transition:background .15s}
.on-grade-place-btn:hover{background:#2a5080}
/* Mesh picker inside placement confirm popup */
.on-place-mesh-wrap{margin:2px 0 16px;text-align:left}
.on-place-mesh-label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:5px;text-transform:uppercase;letter-spacing:.04em}
.on-place-mesh-select{width:100%;padding:9px 10px;border:1.5px solid #ccc;border-radius:7px;font-size:14px;background:#fff;color:#1a2a3a}
/* Confirm overlay */
.on-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:flex;align-items:center;justify-content:center}
.on-confirm-box{background:#fff;border-radius:12px;padding:28px 28px 24px;max-width:320px;width:90%;text-align:center;box-shadow:0 8px 32px rgba(0,0,0,.25)}
.on-confirm-box p{font-size:15px;color:#1a2a3a;margin-bottom:22px;line-height:1.5;font-weight:500}
.on-confirm-box p small{font-size:12px;font-weight:400;color:#555;line-height:1.6}
.on-confirm-box-btns{display:flex;gap:10px;justify-content:center}
.on-confirm-cancel-btn{padding:9px 22px;border-radius:6px;border:1.5px solid #ccc;background:#fff;color:#555;font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s}
.on-confirm-cancel-btn:hover{border-color:#999}
.on-confirm-yes-btn{padding:9px 22px;border-radius:6px;border:none;background:#1a3a5c;color:#fff;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s}
.on-confirm-yes-btn:hover{background:#0f2540}
/* Action form overlay (Discard / Sell / Transfer) */
.on-action-modal{background:#fff;border-radius:14px;padding:24px 24px 20px;max-width:340px;width:92%;box-shadow:0 8px 32px rgba(0,0,0,.25)}
.on-action-modal-title{font-size:16px;font-weight:700;color:#1a2a3a;margin-bottom:16px}
.on-action-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.on-action-label{font-size:12px;font-weight:600;color:#5a6a7a;text-transform:uppercase;letter-spacing:.03em}
.on-action-input{padding:9px 11px;border:1.5px solid #ccc;border-radius:7px;font-size:14px;color:#1a2a3a;background:#fff;width:100%;box-sizing:border-box}
.on-action-input:focus{outline:none;border-color:#1a3a5c}
.on-transfer-options{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.on-transfer-option{display:flex;align-items:center;gap:9px;font-size:14px;color:#1a2a3a;cursor:pointer}
.on-transfer-option input[type=radio]{accent-color:#1a3a5c;width:16px;height:16px;cursor:pointer}
/* Today's Actions log */
.on-lb-header-right{display:flex;align-items:center;gap:8px;margin-left:auto;flex-shrink:0}
.on-log-btn{padding:6px 13px;border-radius:6px;border:1.5px solid #1a3a5c;background:#fff;color:#1a3a5c;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;position:relative;display:flex;align-items:center;gap:5px;white-space:nowrap}
.on-log-btn:hover{background:#1a3a5c;color:#fff}
.on-log-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;background:#c0392b;color:#fff;border-radius:9px;font-size:10px;font-weight:800;padding:0 4px;line-height:1}
.on-log-body{padding:8px 14px 24px;max-width:800px;margin:0 auto;overflow-x:auto}
.on-log-table{width:100%;border-collapse:collapse;font-size:13px}
.on-log-th{padding:9px 12px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#5a6a7a;border-bottom:2px solid #d0e4ee;background:#f5f8fc}
.on-log-td{padding:11px 12px;border-bottom:1px solid #eaf0f8;vertical-align:middle;color:#1a2a3a}
.on-log-time-col   {width:48px;font-variant-numeric:tabular-nums;white-space:nowrap;color:#6a7a8a}
.on-log-startas-col{min-width:160px;font-family:'IBM Plex Mono',monospace;font-size:12px;color:#1a2a3a}
.on-log-action-col {width:90px;white-space:nowrap}
.on-log-endedas-col{min-width:140px;color:#2a3a4a;font-size:13px}
.on-log-ended-line {line-height:1.6;font-family:'IBM Plex Mono',monospace;font-size:12px}
.on-log-status-col {width:90px;text-align:right;white-space:nowrap}
.on-log-type-tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}
.on-log-type-grade   {background:#eaf5ea;color:#1a6e38}
.on-log-type-putback {background:#e8f4f8;color:#1a5c7a}
.on-log-type-discard {background:#fdecea;color:#8b0000}
.on-log-type-sell    {background:#fff8e6;color:#7a5000}
.on-log-type-transfer{background:#f3eeff;color:#4a1a8c}
.on-log-empty{padding:32px 12px;text-align:center;color:#8aa0b0;font-size:14px;font-style:italic}
.on-log-section-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#7a8a9a;padding:0 0 7px}
.on-log-table-active{margin-bottom:4px}
.on-log-active-silo{width:80px;font-weight:700;color:#1a2a3a;white-space:nowrap}
.on-log-active-detail{color:#2a3a4a}
.on-log-status-tag{display:inline-block;padding:3px 9px;border-radius:5px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}
.on-log-status-staged{background:#e8f4f8;color:#1a5c7a}
.on-log-status-grading{background:#e8f0ff;color:#1a3aa0;animation:on-log-pulse .9s ease-in-out infinite}
@keyframes on-log-pulse{0%,100%{opacity:1}50%{opacity:.6}}
/* Session tab nav — segmented control (Silos / Staging / Grade) */
.on-session-nav{display:flex;gap:3px;background:#dce4ee;border-radius:11px;padding:4px;margin:6px 14px 0;flex-shrink:0}
.on-session-tab{flex:1;padding:9px 8px;font-size:13px;font-weight:600;color:#5a6a7a;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s;white-space:nowrap;position:relative;-webkit-tap-highlight-color:transparent}
.on-session-tab.active{background:#1a3a5c;color:#fff;box-shadow:0 1px 5px rgba(0,0,0,.22)}
.on-session-tab:hover:not(:disabled):not(.active){background:rgba(255,255,255,.55);color:#1a3a5c}
.on-session-tab:disabled{color:#aab4be;cursor:default}
.on-session-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 4px;margin-left:4px;background:rgba(255,255,255,.3);color:#fff;font-size:11px;font-weight:700;border-radius:9px;vertical-align:middle}
.on-session-tab:not(.active) .on-session-badge{background:#1a3a5c;color:#fff}
.on-session-tab:disabled .on-session-badge{background:#c0cad4;color:#fff}
/* Hub badge (pending incoming transfers) */
.on-hub-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;background:#c0392b;color:#fff;border-radius:9px;font-size:10px;font-weight:800;padding:0 4px;line-height:1;margin-left:6px;vertical-align:middle}
/* Hub action buttons (Place new cohorts + Yield & Growth) */
.on-hub-actions{display:flex;justify-content:center;gap:14px;padding:0 24px 32px;margin-top:-24px;flex-wrap:wrap}
.on-place-cohort-btn{flex:1;max-width:280px;min-width:180px;padding:11px 20px;background:#fff;border:2px solid #1a3a5c;border-radius:8px;color:#1a3a5c;font-family:'IBM Plex Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;letter-spacing:.02em;text-align:center}
.on-place-cohort-btn:hover{background:#1a3a5c;color:#fff}
/* Daily Check hub button */
.on-hub-daily-check{display:flex;justify-content:center;padding:0 24px 40px;margin-top:-16px}
.on-daily-check-btn{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:20px;padding:0 40px;background:var(--white);border:2px solid var(--border);border-radius:14px;cursor:pointer;font-family:'IBM Plex Sans',sans-serif;width:450px;height:100px;max-width:100%;transition:all var(--t);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.on-daily-check-btn:hover{border-color:var(--seafoam);box-shadow:0 6px 18px rgba(74,158,187,.18);transform:translateY(-3px)}
.on-daily-check-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.on-daily-check-label{font-size:18px;font-weight:700;color:var(--ocean-deep)}
/* Daily Log form — viewport-filling, no scroll */
.dl-form.form-container{padding:20px 28px 0;max-width:100%;height:100%;display:flex;flex-direction:column;overflow:hidden}
.dl-form-header{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:12px;flex-shrink:0}
.dl-back-btn{position:absolute;left:0;top:0;background:#fff;border:2px solid #1a3a5c;border-radius:8px;padding:8px 18px;font-size:14px;font-weight:700;color:#1a3a5c;cursor:pointer;transition:all .15s;white-space:nowrap}
.dl-back-btn:hover{background:#1a3a5c;color:#fff}
.dl-body{flex:1;display:flex;flex-direction:column;gap:12px;width:100%;box-sizing:border-box;overflow:hidden;padding-bottom:20px}
.dl-checks{display:flex;flex-direction:column;gap:8px;flex-shrink:0;max-width:480px}
.dl-check-row{display:flex;align-items:center;gap:16px;cursor:pointer;padding:10px 18px;background:#f8fafc;border:2px solid #e0e8f0;border-radius:12px;transition:border-color .15s}
.dl-check-row:hover{border-color:#4a9ebb}
.dl-checkbox{width:32px;height:32px;cursor:pointer;accent-color:#4a9ebb;flex-shrink:0}
.dl-check-label{font-size:17px;font-weight:600;color:#1a3a5c}
.dl-speed-card{display:flex;flex-direction:column;gap:6px;padding:12px 18px;background:#f8fafc;border:2px solid #e0e8f0;border-radius:12px;flex-shrink:0}
.dl-speed-title{font-size:17px;font-weight:600;color:#1a3a5c}
.dl-speed-row{display:flex;align-items:center;gap:16px}
.dl-slider{flex:1;height:10px;cursor:pointer;accent-color:#4a9ebb}
.dl-speed-readout{display:flex;align-items:baseline;gap:5px;flex-shrink:0}
.dl-speed-val{font-size:24px;font-weight:800;color:#1a3a5c;min-width:54px;text-align:right}
.dl-speed-unit{font-size:14px;color:#666}
.dl-notes{width:100%;flex:1;height:0;min-height:220px;padding:14px 16px;font-size:16px;font-family:'IBM Plex Sans',sans-serif;border:2px solid #e0e8f0;border-radius:12px;resize:none;box-sizing:border-box;transition:border-color .15s}
.dl-notes:focus{outline:none;border-color:#4a9ebb}
.dl-actions{display:flex;gap:14px;flex-shrink:0}
.dl-btn{flex:1;padding:14px 0;font-size:18px;font-weight:700;font-family:'IBM Plex Sans',sans-serif;border-radius:12px;cursor:pointer;border:2px solid;transition:all .15s;letter-spacing:.02em}
.dl-btn-cancel{background:#fff;border-color:#1a3a5c;color:#1a3a5c}
.dl-btn-cancel:hover{background:#1a3a5c;color:#fff}
.dl-btn-save{background:#1a3a5c;border-color:#1a3a5c;color:#fff}
.dl-btn-save:hover{background:#0f2540;border-color:#0f2540}
.dl-btn:disabled{opacity:.5;cursor:not-allowed}
/* Place New Cohorts modal */
.on-pc-modal{max-width:500px}
.on-pc-body{padding:24px 28px 8px}
.on-pc-form{display:flex;flex-direction:column;gap:16px}
.on-pc-row{display:flex;flex-direction:column;gap:6px}
.on-pc-label{font-size:12px;font-weight:700;color:#1a3a5c;letter-spacing:.04em;text-transform:uppercase}
.on-pc-select{width:100%;padding:9px 12px;border:1.5px solid #ccc;border-radius:6px;font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:#1a2a3a;background:#fff;box-sizing:border-box}
.on-pc-input{padding:9px 12px;border:1.5px solid #ccc;border-radius:6px;font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:#1a2a3a;background:#fff;box-sizing:border-box}
.on-pc-vol-row{display:flex;gap:8px;align-items:center}
.on-pc-vol-input{flex:1;min-width:0}
.on-pc-unit-select{width:72px;padding:9px 8px;border:1.5px solid #ccc;border-radius:6px;font-family:'IBM Plex Sans',sans-serif;font-size:14px;color:#1a2a3a;background:#fff}
.on-pc-sieve-row{display:flex;flex-direction:column;gap:8px}
.on-pc-error{min-height:20px;font-size:13px;color:#c0392b;font-weight:600;padding:4px 0 0}
.on-pc-footer{display:flex;gap:10px;padding:16px 28px 20px;border-top:1px solid #e8ecf0;flex-shrink:0}
.on-pc-footer .btn-modal-primary{flex:1}
.on-pc-footer .btn-modal-cancel{flex-shrink:0}
/* Yield & Growth modal */
.on-yield-modal{max-width:520px}
.on-yield-body{padding:16px 28px 8px;overflow-y:auto;flex:1}
.on-yield-modal .on-pc-form{gap:10px}
.on-yield-modal .on-pc-input,.on-yield-modal .on-pc-select{padding-top:5px;padding-bottom:5px}
.on-yield-label{font-size:12px;font-weight:700;color:#1a3a5c;letter-spacing:.04em}
.on-yield-meta-row{display:flex;gap:10px}
.on-yield-meta-item{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.on-yield-readonly{font-size:14px;color:#1a2a3a;padding:8px 10px;background:#f4f7fa;border:1.5px solid #e0e6ed;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.on-yield-count-row{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap}
.on-yield-count-input{width:90px;flex-shrink:0}
.on-yield-qty-input{width:90px;flex-shrink:0}
/* Size row — direction toggle + sieve + label all on one line */
.on-yield-size-row{display:flex;align-items:center;gap:8px}
.on-yield-size-row .on-grade-dir-toggle{flex-shrink:0}
.on-yield-size-row .on-grade-dir-btn{padding:8px 10px;font-size:12px}
.on-yield-sieve-select{flex:1;min-width:0}
.on-yield-sieve-unit{flex-shrink:0;white-space:nowrap;font-size:12px;font-weight:600;color:#556}
.on-yield-ld-group{display:flex;flex-direction:column;gap:3px;align-items:center;flex-shrink:0}
.on-yield-ld-sublabel{font-size:11px;font-weight:700;color:#556;letter-spacing:.03em}
.on-yield-ld-input{width:80px}
/* Navy border on unselected toggles inside yield modal signals "tap to choose" */
.on-yield-modal .on-grade-dir-toggle{border-color:#1a3a5c}
.on-yield-modal .on-grade-dir-toggle .on-grade-dir-btn+.on-grade-dir-btn{border-left-color:#1a3a5c}
.on-yield-per-label{font-size:13px;font-weight:700;color:#556;flex-shrink:0}
.on-yield-unit-toggle{flex-shrink:0}
.on-yield-heights-row{margin-top:2px}
.on-yield-heights-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}
.on-yield-height-cell{display:flex;flex-direction:column;align-items:center;gap:2px}
.on-yield-height-label{font-size:10px;color:#aab;font-weight:600}
.on-yield-height-input{width:100%;padding:5px 4px;border:1.5px solid #ccc;border-radius:5px;font-family:'IBM Plex Sans',sans-serif;font-size:12px;color:#1a2a3a;background:#fff;box-sizing:border-box;text-align:center}
.on-yield-height-input:focus{border-color:#1a3a5c;outline:none;box-shadow:0 0 0 2px rgba(26,58,92,.1)}
.on-yield-notes{width:100%;padding:8px 10px;border:1.5px solid #ccc;border-radius:6px;font-size:14px;font-family:'IBM Plex Sans',sans-serif;color:#1a2a3a;background:#fff;resize:vertical;box-sizing:border-box;transition:border-color .15s}
.on-yield-notes:focus{border-color:#1a3a5c;outline:none;box-shadow:0 0 0 2px rgba(26,58,92,.1)}
.on-yield-entry+.on-yield-entry{margin-top:6px;padding-top:6px;border-top:1px dashed #d0e4ee}
.on-yield-add-btn{margin-top:6px;padding:5px 12px;font-size:12px;font-weight:600;font-family:'IBM Plex Sans',sans-serif;color:#1a3a5c;background:#eaf3f8;border:1.5px solid #b0cfe0;border-radius:6px;cursor:pointer;transition:background .15s}
.on-yield-add-btn:hover{background:#d4eaf5}
.on-yield-remove-btn{flex-shrink:0;padding:3px 8px;font-size:14px;font-weight:700;color:#999;background:none;border:none;cursor:pointer;line-height:1;transition:color .15s}
.on-yield-remove-btn:hover{color:#c0392b}
/* Pending transfer banner */
.on-pending-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff3cd;border:1.5px solid #e0a800;border-radius:8px;padding:10px 16px;margin:6px 14px 2px;flex-wrap:wrap}
.on-pending-banner-text{font-size:13px;color:#7a5000;flex:1;min-width:0}
.on-pending-banner-btn{padding:6px 14px;border-radius:6px;border:none;background:#1a3a5c;color:#fff;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0}
.on-pending-banner-btn:hover{background:#0f2540}
.on-lb-platform-footer{display:flex;justify-content:space-between;align-items:center;padding:6px 4px 0;color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em}
/* FLUPSY */
.on-fl-platform{background:#2a6496!important;padding:20px!important;width:fit-content!important;margin:0 auto}
.on-fl-tanks-row{display:flex;gap:14px;align-items:stretch;flex:1;min-height:0;justify-content:center}
.on-fl-flupsy{flex:0 1 auto;min-width:0;width:calc(50vh - 120px);overflow:hidden;background:repeating-linear-gradient(0deg,#a08060 0px,#a08060 18px,#7a5e40 19px,#7a5e40 20px);border-radius:6px;display:flex;flex-direction:column}
.on-fl-top-wood{height:43px;flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;padding:6px 8px}
.on-fl-flupsy-label{font-size:11px;font-weight:700;color:#f5eedd;letter-spacing:.5px;text-transform:uppercase;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.on-fl-body{flex:1;min-height:0;display:flex;flex-direction:row;align-items:center}
.on-fl-col{flex:1;min-height:0;display:flex;flex-direction:column;justify-content:center;align-self:stretch}
.on-fl-trough{flex:0 0 25%;background:#fff;align-self:stretch;display:flex;flex-direction:column}
.on-fl-trough-row{flex:1;display:flex;align-items:center;justify-content:space-between;padding:0 3px}
.on-fl-bin{flex:1;width:100%;background:#dff0fa;border:1.5px solid #5a9ab8;box-sizing:border-box;cursor:pointer;transition:filter .15s;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.on-fl-bin:hover{filter:brightness(0.90)}
.on-fl-col .on-fl-bin:not(:first-child){border-top:none}
.on-fl-bin-num{font-size:9px;font-weight:700;color:#000;line-height:1}
.on-fl-bot-wood{height:43px;flex-shrink:0}
.on-fl-remove-btn{background:none;border:none;color:rgba(255,255,255,.25);font-size:10px;cursor:pointer;padding:2px 4px;line-height:1;transition:color .15s}
.on-fl-remove-btn:hover{color:#e88}
.on-fl-confirm-text{font-size:10px;color:#ffd0c0;font-weight:600;flex:1}
.on-fl-cancel-btn{background:none;border:1px solid rgba(255,255,255,.4);border-radius:4px;color:#f5eedd;font-size:10px;cursor:pointer;padding:2px 6px;margin-right:4px}
.on-fl-confirm-btn{background:#c0392b;border:none;border-radius:4px;color:#fff;font-size:10px;cursor:pointer;padding:2px 6px}
.on-fl-top-add-btn{flex-shrink:0;background:none;border:1.5px solid var(--border);border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--ocean-deep);cursor:pointer;transition:all var(--t);white-space:nowrap;margin-top:4px}
.on-fl-top-add-btn:hover{border-color:var(--seafoam);color:var(--seafoam)}
/* Fiddler's Scallop Upwellers */
.on-fs-platform{background:#2a6496!important;padding:20px!important;width:fit-content!important;margin:0 auto}
.on-fs-upwellers-row{display:flex;gap:14px;align-items:stretch;flex:1;min-height:0;justify-content:center}
.on-fs-upweller{flex:0 1 auto;min-width:0;width:calc(50vh - 120px);overflow:hidden;background:repeating-linear-gradient(0deg,#a08060 0px,#a08060 18px,#7a5e40 19px,#7a5e40 20px);border-radius:6px;display:flex;flex-direction:column}
.on-fs-top-wood{height:43px;flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;padding:6px 8px}
.on-fs-upweller-label{font-size:11px;font-weight:700;color:#f5eedd;letter-spacing:.5px;text-transform:uppercase;text-shadow:0 1px 2px rgba(0,0,0,.4)}
.on-fs-body{flex:1;min-height:0;display:flex;flex-direction:row;align-items:center}
.on-fs-col{flex:1;min-height:0;display:flex;flex-direction:column;align-self:stretch;gap:4px}
.on-fs-trough{flex:0 0 25%;background:#fff;align-self:stretch;display:flex;flex-direction:column}
.on-fs-trough-row{flex:1;display:flex;align-items:center;justify-content:space-between;padding:0 3px}
.on-fs-silo{flex:1;width:100%;background:#e0eef8;border:1.5px solid #9ab8cc;box-sizing:border-box;cursor:pointer;transition:filter .15s;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.on-fs-silo:hover{filter:brightness(0.90)}
.on-fs-col .on-fs-silo:not(:first-child){border-top:none}
.on-fs-silo-num{font-size:10px;font-weight:700;color:#000;line-height:1}
.on-fs-bot-wood{height:43px;flex-shrink:0}
/* FS silo groups — each "silo" position is a group with a header + 5 tray cells */
/* A: black box around each group of 5 trays — all 4 sides always visible */
.on-fs-silo-group{flex:1;display:flex;flex-direction:column;border:3px solid #1a2a3a;box-sizing:border-box;overflow:hidden;min-height:0}
.on-fs-group-header{background:#2a4a5c;color:#fff;padding:2px 5px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;line-height:1.3;gap:4px}
.on-fs-group-label{font-size:10px;font-weight:700}
.on-fs-group-top-hint{font-size:8px;font-weight:600;opacity:.82;white-space:nowrap}
/* Tray cells inside a group: remove standalone border, add dashed dividers between trays */
.on-fs-silo-group .on-fs-silo{border:none;border-top:1px dashed #b0c8d8;flex:1;min-height:0}
.on-fs-silo-group .on-fs-silo:first-child{border-top:none}
/* FS tray content — dedicated layout bypassing on-silo-grid; species→grade→strain→volume→date */
/* FS tray: 2-col grid matching the main silo-grid layout — rows: sp+st / grade / vl+dt.
   align-content:space-between distributes rows across available height regardless of tray size.
   padding-left:18px clears the T1/T2 tray number label on the left edge. */
.on-fs-tray-content{position:absolute;inset:0;pointer-events:none;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto;align-content:space-evenly;padding:2px 6px 2px 14px}
.on-fs-tc-sp{grid-area:1/1;font-size:8px;font-weight:800;line-height:1;min-width:0;overflow:hidden;white-space:nowrap;align-self:start}
.on-fs-tc-st{grid-area:1/2;font-size:7px;font-weight:600;line-height:1;min-width:0;overflow:hidden;white-space:nowrap;text-align:right;align-self:end}
.on-fs-tc-gr{grid-area:2/1/2/3;text-align:center;font-size:7px;font-weight:700;line-height:1;white-space:nowrap;overflow:hidden}
.on-fs-tc-vl{grid-area:3/1;font-size:6.5px;font-weight:600;line-height:1;min-width:0;overflow:hidden;white-space:nowrap}
.on-fs-tc-dt{grid-area:3/2;font-size:6.5px;font-weight:600;line-height:1;min-width:0;overflow:hidden;white-space:nowrap;text-align:right}
/* B: 2px mesh ring inside tray cells — thin enough not to clip text */
.on-fs-silo-group .on-fs-silo.on-mesh-active{box-shadow:inset 0 0 0 2px var(--mesh-color)}
/* T1–T5 tray number label — vertically centred in left margin (left of silo-grid) */
.on-fs-tray-num{position:absolute;top:50%;left:2px;transform:translateY(-50%);font-size:8px;font-weight:800;color:rgba(0,0,0,.28);pointer-events:none;z-index:1;line-height:1}
/* Species bg overrides for FL/FS bins — compound selectors beat the base bin rules */
.on-fl-bin.on-silo-oyster,.on-fs-silo.on-silo-oyster{background:#c8e6f5}
.on-fl-bin.on-silo-clam,.on-fs-silo.on-silo-clam{background:#f0dfc0}
.on-fl-bin.on-silo-scallop,.on-fs-silo.on-silo-scallop{background:#f0b8d0}
.on-fl-bin.on-silo-empty,.on-fs-silo.on-silo-empty{background:#e8e5df}
/* Mesh ring on FL/FS uses inset box-shadow so each bin's ring is self-contained
   (border-color bleeds across the shared edge between stacked bins) */
.on-fl-bin.on-mesh-active,.on-fs-silo.on-mesh-active{box-shadow:inset 0 0 0 4px var(--mesh-color)}
/* Selection (no mesh): 9px blue ring + tint */
.on-fl-bin.on-silo-selected,.on-fs-silo.on-silo-selected{box-shadow:inset 0 0 0 9px #1a78e0,inset 0 0 0 100px rgba(26,120,224,0.25)}
/* Mesh + selected combined: mesh ring (4px, on top) stays visible; blue ring shows in the 4–9px band behind it */
.on-fl-bin.on-mesh-active.on-silo-selected,.on-fs-silo.on-mesh-active.on-silo-selected{box-shadow:inset 0 0 0 4px var(--mesh-color),inset 0 0 0 9px #1a78e0,inset 0 0 0 100px rgba(26,120,224,0.25)}
/* Maintenance modal */
#modal-ho-maintenance .simple-modal{max-width:800px!important;display:flex;flex-direction:column;max-height:calc(100vh - 40px)}
.ho-maint-body{padding:0;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.ho-maint-table-scroll{position:relative;flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}
.ho-maint-wrap{padding:10px 16px 0;flex:1;min-height:0;overflow-y:auto}
.ho-maint-table{width:100%;border-collapse:collapse;font-size:12px}
.ho-maint-th{padding:6px 8px;text-align:left;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-secondary);border-bottom:2px solid var(--border);white-space:nowrap}
.ho-maint-th-date{min-width:130px}.ho-maint-th-freq{min-width:175px}.ho-maint-th-days{min-width:130px;white-space:normal}
.ho-maint-row{border-bottom:1px solid var(--border)}
.ho-maint-row:last-child{border-bottom:none}
.ho-maint-row:hover{background:#f7f9fb}
.ho-maint-task-inp{border:1.5px solid transparent;border-radius:5px;padding:4px 6px;font-size:12px;font-family:inherit;color:var(--text-primary);background:transparent;min-width:100px;max-width:320px}
.ho-maint-task-inp:hover{border-color:var(--border)}.ho-maint-task-inp:focus{outline:none;border-color:var(--seafoam);background:var(--white)}
.ho-maint-date{border:1.5px solid var(--border);border-radius:5px;padding:4px 6px;font-size:11px;font-family:inherit;color:var(--text-primary);background:var(--white);width:100%}
.ho-maint-date:focus{outline:none;border-color:var(--seafoam)}
.ho-maint-freq-cell{padding:4px 6px}
.ho-maint-freq-row{display:flex;align-items:center;gap:4px}
.ho-maint-freq-pre{font-size:11px;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}
.ho-maint-freq-num{width:38px;border:1.5px solid var(--border);border-radius:5px;padding:3px 4px;font-size:11px;font-family:inherit;text-align:center}
.ho-maint-freq-num:focus{outline:none;border-color:var(--seafoam)}
.ho-maint-freq-unit{border:1.5px solid var(--border);border-radius:5px;padding:3px 4px;font-size:11px;font-family:inherit;color:var(--text-primary);background:var(--white);flex:1;min-width:0}
.ho-maint-freq-unit:focus{outline:none;border-color:var(--seafoam)}
.ho-maint-days{padding:4px 8px;font-weight:700;font-variant-numeric:tabular-nums;font-size:12px;color:var(--text-secondary);text-align:left}
.ho-maint-days.ok{color:#2e9e5b}.ho-maint-days.warn{color:#d08000}.ho-maint-days.overdue{color:#c0392b}
.ho-maint-days-num{font-weight:700}
.ho-maint-days-lbl{font-size:9px;font-weight:600;margin-left:3px;white-space:nowrap}
.ho-maint-add-btn{margin:6px 0 0;font-size:11px;font-weight:600;color:var(--seafoam);background:none;border:none;cursor:pointer;padding:4px 16px;flex-shrink:0}
.ho-maint-add-btn:hover{text-decoration:underline}
/* Alerts section */
.ho-maint-alerts-section{padding:8px 16px;border-top:1px solid var(--border);margin-top:4px;flex-shrink:0}
.ho-maint-alerts-title{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:3px}
.ho-maint-alerts-note{font-size:11px;color:var(--text-secondary);margin-bottom:8px}
.ho-maint-alert-row{display:flex;gap:6px;align-items:center;margin-bottom:6px}
.ho-maint-alert-name{border:1.5px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;font-family:inherit;width:140px;flex-shrink:0}
.ho-maint-alert-name:focus{outline:none;border-color:var(--seafoam)}
.ho-maint-alert-email{border:1.5px solid var(--border);border-radius:6px;padding:6px 10px;font-size:13px;font-family:inherit;flex:1;min-width:0}
.ho-maint-alert-freq,.ho-maint-alert-day,.ho-maint-alert-time{border:1.5px solid var(--border);border-radius:6px;padding:5px 4px;font-size:12px;font-family:inherit;color:var(--text-primary);background:var(--white);flex-shrink:0}
.ho-maint-alert-freq{width:82px}.ho-maint-alert-day{width:90px}.ho-maint-alert-time{width:78px}
.ho-maint-alert-freq:focus,.ho-maint-alert-day:focus,.ho-maint-alert-time:focus{outline:none;border-color:var(--seafoam)}
.ho-maint-alert-email:focus{outline:none;border-color:var(--seafoam)}
.ho-maint-alert-remove{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;padding:4px 6px;line-height:1;border-radius:4px;flex-shrink:0}
.ho-maint-alert-remove:hover{background:#fee;color:var(--error)}
.ho-maint-alert-add-btn{font-size:12px;font-weight:600;color:var(--seafoam);background:none;border:none;cursor:pointer;padding:4px 2px}
.ho-maint-alert-add-btn:hover{text-decoration:underline}
.ho-maint-actions{display:flex;gap:12px;justify-content:flex-end;padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0}

/* Farm — landscape-only full-height container */
.fm-form{display:flex;flex-direction:column;height:calc(100vh - 56px);overflow:hidden}
/* Farm location picker */
.fm-farm-picker{display:flex;gap:6px;padding:7px 12px;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}
.fm-farm-picker-btn{font-size:12px;font-weight:600;padding:4px 13px;border-radius:20px;border:1.5px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.fm-farm-picker-btn.active{background:#1a3a5c;color:#fff;border-color:#1a3a5c}
.fm-farm-picker-btn:not(.active):not([disabled]):hover{background:var(--sand);border-color:var(--text-secondary)}
.fm-farm-picker-btn[disabled]{opacity:0.35;cursor:default}
.fm-farm-platform{display:flex;flex-direction:column;flex:1;min-height:0;overflow:auto;position:relative}
.fm-overview-center-wrap{display:flex;justify-content:center;min-width:100%;flex-shrink:0}
/* Zoom slider bar */
.fm-zoom-bar{display:flex;align-items:center;gap:12px;padding:10px 20px 12px;background:#f0f3f6;border-top:2px solid #dde4ea;flex-shrink:0}
.fm-zoom-icon{color:#555;user-select:none;flex-shrink:0;line-height:1}
.fm-zoom-icon-sm{font-size:18px}
.fm-zoom-icon-lg{font-size:28px}
.fm-zoom-slider{flex:1;cursor:pointer;-webkit-appearance:none;appearance:none;height:10px;border-radius:5px;background:#c8d4de;outline:none}
.fm-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:52px;height:52px;border-radius:50%;background:#1a3a5c;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.fm-zoom-slider::-moz-range-thumb{width:52px;height:52px;border-radius:50%;background:#1a3a5c;cursor:pointer;border:none;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.fm-zoom-label{font-size:15px;font-weight:700;color:#1a3a5c;min-width:36px;text-align:right;flex-shrink:0}
/* Rotate prompt — visible only in portrait */
.fm-landscape-prompt{display:none;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;color:var(--text-secondary);font-size:15px;font-weight:600;padding:32px;gap:14px;line-height:1.5}
@media (orientation:portrait){.fm-landscape-prompt{display:flex}.fm-overview{display:none!important}}
/* Overview mini-map — centered, fixed-size pixel grid */
.fm-overview{display:flex;min-width:min-content;align-items:flex-start;justify-content:flex-start;padding:14px 20px 18px 20px;gap:0}
.fm-overview-field{display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0}
.fm-overview-field-lbl{font-size:13px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-secondary);text-align:center}
/* Bag pixel grid: 80 cols (farm rows) × 15 rows (bag positions), auto-flow column */
.fm-overview-wrap{position:relative;flex-shrink:0}
/* White grid background = white 1px gaps = visible bag outlines */
.fm-overview-grid{display:grid;grid-auto-flow:column;gap:1px;background:#fff}
/* Checkerboard grid uses sand background so ghost-quadrant gaps match the page */
.fm-overview-grid-check{background:var(--sand)}
.fm-ov-bag{flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:18%;position:relative}
/* Fallback species colors — used when no cohort color is assigned */
.fm-ov-empty{background:#dedad2}
.fm-ov-oyster{background:#7ab4d6}
.fm-ov-clam{background:#c89868}
.fm-ov-scallop{background:#d880b8}
.fm-ov-mussel{background:#a87ecc}
.fm-ov-seed{background:#90b858}
/* ── Grade overrides — highest visual priority ── */
/* Selects: liquid gold shimmer — animated gradient + pulsing glow. Dominates every other bag.
   --glow-a/--glow-b set by JS (_fmApplyDynamicSize) to scale with bag pixel size.
   filter:drop-shadow used instead of box-shadow — not clipped by parent overflow. */
.fm-ov-selects{
  --glow-a:2px;--glow-b:6px;
  background:linear-gradient(130deg,#ffe060 0%,#c87800 38%,#ffd040 62%,#d48800 100%)!important;
  background-size:300% 300%!important;
  border-color:#a86000!important;
  animation:fm-shift-s 3s ease-in-out infinite,fm-glow-s 1.8s ease-in-out infinite;
  z-index:3}
/* Petites: liquid emerald shimmer — animated gradient + pulsing glow. Distinct from gold. */
.fm-ov-petites{
  --glow-a:2px;--glow-b:6px;
  background:linear-gradient(130deg,#50f090 0%,#0b7820 38%,#6afaa0 62%,#0a6018 100%)!important;
  background-size:300% 300%!important;
  border-color:#085010!important;
  animation:fm-shift-p 3s ease-in-out infinite,fm-glow-p 2.1s ease-in-out infinite;
  z-index:3}
@keyframes fm-shift-s{0%,100%{background-position:0% 0%}50%{background-position:100% 100%}}
@keyframes fm-shift-p{0%,100%{background-position:0% 0%}50%{background-position:100% 100%}}
@keyframes fm-glow-s{
  0%,100%{filter:drop-shadow(0 0 var(--glow-a) rgba(255,185,20,.45))}
  50%    {filter:drop-shadow(0 0 var(--glow-b) rgba(255,215,50,.90))}}
@keyframes fm-glow-p{
  0%,100%{filter:drop-shadow(0 0 var(--glow-a) rgba(40,210,80,.45))}
  50%    {filter:drop-shadow(0 0 var(--glow-b) rgba(80,245,120,.90))}}
/* Putbacks: keep cohort color (inline style), thick rust border to signal graded */
.fm-ov-putbacks{box-shadow:inset 0 0 0 2px #a83010}
/* Mixed origin bags: charcoal neutral */
.fm-ov-mixed{background:#555!important}
/* ── Grade badges — overlay on bag ── */
.fm-ov-grade-badge{position:absolute;bottom:1px;right:1px;font-size:0;font-weight:900;line-height:1;pointer-events:none;border-radius:2px;padding:0 1px}
.fm-ov-badge-s{background:#b87010;color:#fff}
.fm-ov-badge-p{background:#1a8030;color:#fff}
.fm-ov-badge-pb{background:#a83010;color:#fff}
/* Selected bag highlight — bright white outline visible at any zoom level */
.fm-ov-bag.fm-ov-selected{outline:2px solid #fff;outline-offset:-1px;filter:brightness(1.3);z-index:2}
/* Staged bag highlight — amber ring shows bags currently in the staging queue */
.fm-ov-bag.fm-ov-staged{outline:2px solid #f5a623;outline-offset:-1px;z-index:1}
/* Ghost cell — blends into page background (checkerboard background quadrants) */
.fm-ov-ghost{background:var(--sand);pointer-events:none}
/* Serial number inside each overview bag — font size set dynamically by _fmApplyDynamicSize */
.fm-ov-serial{font-size:0;font-weight:700;color:rgba(255,255,255,0.85);line-height:1;white-space:nowrap;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,0.4)}
/* ── Cohort color picker (Add Cohort modal) ── */
.fm-color-picker{display:flex;flex-wrap:wrap;gap:8px;padding:4px 0}
.fm-color-swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:transform .1s,border-color .1s;flex-shrink:0}
.fm-color-swatch:hover{transform:scale(1.15)}
.fm-color-swatch-selected{border-color:#fff;outline:2px solid #1a3a5c;transform:scale(1.15)}
/* Select button in farm header — white like Actions, turns blue when active */
.fm-select-btn-active{background:#1a3a5c!important;color:#fff!important}
/* ── Cohort legend bar — between farm title and action buttons ── */
.fm-cohort-legend{flex:1;min-width:0;overflow-x:auto;display:flex;align-items:center;gap:5px;padding:0 10px;scrollbar-width:none}
.fm-cohort-legend::-webkit-scrollbar{display:none}
.fm-legend-chip{display:flex;align-items:center;gap:5px;background:rgba(10,22,40,.60);border-radius:4px;padding:3px 8px 3px 5px;white-space:nowrap;flex-shrink:0;font-size:11px;font-weight:600;color:#fff;line-height:1.2}
.fm-legend-swatch{width:14px;height:14px;border-radius:2px;flex-shrink:0}
/* ── Per-cohort zone labels — overlay inside each field grid ── */
/* pointer-events:none so clicks always reach the bags beneath */
.fm-zone-label{position:absolute;pointer-events:none;display:flex;align-items:center;justify-content:center;font-weight:800;color:rgba(255,255,255,0.82);text-shadow:0 1px 4px rgba(0,0,0,0.65),0 0 12px rgba(0,0,0,0.40);letter-spacing:.03em;overflow:hidden;white-space:nowrap;z-index:2}
/* Section label overlays — visual only, not clickable */
.fm-overview-labels{position:absolute;inset:0;pointer-events:none}
.fm-ov-label{position:absolute;top:0;bottom:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
/* Pill/button chip — only the text gets the background, not the full label area */
.fm-ov-label-text{font-size:11px;font-weight:700;color:#fff;text-align:center;line-height:1.45;pointer-events:none;background:rgba(0,0,0,0.48);border:1px solid rgba(255,255,255,0.28);border-radius:7px;padding:5px 9px;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
/* Gap between fields */
.fm-overview-gap{flex-shrink:0}
/* Drill overlay — absolute over fm-farm-platform, semi-transparent so overview shows through */
.fm-drill-overlay{position:absolute;inset:0;z-index:10;background:rgba(12,22,42,.8);display:flex;flex-direction:column}
/* Drill overlay header bar */
.fm-drill-bar{display:flex;align-items:center;gap:12px;padding:7px 14px;background:rgba(255,255,255,.97);border-bottom:1px solid var(--border);flex-shrink:0}
/* Farm View button — solid navy, stands out from white bar */
.fm-drill-farm-view{font-size:13px;font-weight:600;color:#fff;background:#1a3a5c;border:none;border-radius:7px;cursor:pointer;padding:5px 13px;flex-shrink:0}
.fm-drill-farm-view:hover{opacity:.88}
.fm-drill-title{font-size:14px;font-weight:700;color:var(--text-primary);flex:1}
.fm-drill-rows{font-size:11px;color:var(--text-secondary);flex-shrink:0}
/* Select button — outlined navy; becomes outlined red when in Cancel state */
.fm-drill-select-btn{font-size:13px;font-weight:600;padding:5px 13px;border-radius:7px;border:1.5px solid #1a3a5c;background:transparent;color:#1a3a5c;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s,border-color .15s}
.fm-drill-cancel-btn{font-size:13px;font-weight:600;padding:5px 13px;border-radius:7px;border:1.5px solid #c0392b;background:transparent;color:#c0392b;cursor:pointer;flex-shrink:0}
/* Stage N bags button — solid green, appears between title and Cancel when bags selected */
.fm-drill-stage-btn{font-size:13px;font-weight:700;padding:5px 14px;border-radius:7px;border:none;background:#2e7d32;color:#fff;cursor:pointer;flex-shrink:0}
/* Selected bag highlight */
.fm-drill-bag.fm-drill-selected{outline:2.5px solid #fff;outline-offset:-1px;filter:brightness(1.35);box-shadow:0 0 8px rgba(255,255,255,.55)}
/* Drill body — horizontally scrollable, 10px vertical padding keeps grid border visible */
.fm-drill-body{flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;display:flex;align-items:center;justify-content:center;padding:10px 20px;-webkit-overflow-scrolling:touch}
/* Drill grid — dark near-black background, bright border with outer glow */
.fm-drill-grid{display:grid;grid-auto-flow:column;gap:2px;background:#0e0e14;flex-shrink:0;border:2.5px solid rgba(255,255,255,.7);border-radius:3px;box-shadow:0 0 18px rgba(255,255,255,.12),0 0 6px rgba(255,255,255,.08)}
.fm-drill-bag{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;cursor:pointer}
.fm-drill-bag:active{filter:brightness(1.25)}
/* Drill-specific vivid bag colors — bright gradients + inner glow (separate from pastel overview colors) */
.fm-drill-col-empty  {background:#1e1e2a;box-shadow:inset 0 0 3px rgba(0,0,0,.4)}
.fm-drill-col-oyster {background:linear-gradient(140deg,#5deeff 0%,#1888d8 100%);box-shadow:inset 0 1px 3px rgba(255,255,255,.5),inset 0 0 6px rgba(80,230,255,.35)}
.fm-drill-col-clam   {background:linear-gradient(140deg,#ffd050 0%,#f07020 100%);box-shadow:inset 0 1px 3px rgba(255,255,255,.5),inset 0 0 6px rgba(255,190,50,.35)}
.fm-drill-col-scallop{background:linear-gradient(140deg,#ff70ea 0%,#c010a8 100%);box-shadow:inset 0 1px 3px rgba(255,255,255,.5),inset 0 0 6px rgba(255,80,220,.35)}
.fm-drill-col-mussel {background:linear-gradient(140deg,#b472ff 0%,#6020d0 100%);box-shadow:inset 0 1px 3px rgba(255,255,255,.5),inset 0 0 6px rgba(150,80,255,.35)}
.fm-drill-col-seed   {background:linear-gradient(140deg,#b0f040 0%,#58c010 100%);box-shadow:inset 0 1px 3px rgba(255,255,255,.5),inset 0 0 6px rgba(150,240,40,.35)}
/* Serial number inside each drill bag */
.fm-drill-serial{font-size:6px;font-weight:800;color:rgba(255,255,255,.95);text-shadow:0 1px 3px rgba(0,0,0,.7);line-height:1;text-align:center;white-space:nowrap;pointer-events:none}
.fm-drill-use{font-size:5.5px;color:rgba(255,255,255,.7);line-height:1;text-align:center;pointer-events:none}
/* Staging card — secondary bag list line (shown when lot has >3 bags) */
.fm-staging-baglist{font-size:10px;color:var(--text-secondary);line-height:1.35;word-break:break-word}
/* Sell/Transfer "Other" text input — hidden by default, shown via JS */
.fm-sell-other-input{display:none;margin-top:6px}
.fm-add-cohort-btn{background:var(--seafoam);color:#fff;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}
.fm-add-cohort-btn:hover{opacity:.9}
.ho-btn-disabled{opacity:1;cursor:default;pointer-events:none}
.ho-btn-disabled .ho-btn-label{color:#aaa}
/* Suppress any stale accordion caret if fm ever cached as accordion */
#nav-acc-fm .nav-accordion-arrow{display:none}
.fm-hub-sat-img{width:120px;height:120px;border-radius:8px;object-fit:cover;display:block}
.fm-hub-btn{width:320px;flex:0 0 320px;height:360px;padding:14px 10px}
.fm-hub-btn .fm-hub-sat-img{width:180px;height:180px}
.fm-hub-btn .ho-btn-label{font-size:20px}
.fm-hub-landing{padding-bottom:16px!important}
.fm-hub-coming-soon{font-size:11px;font-weight:400;opacity:.7}
/* ── Hub action rows ── */
.fm-hub-primary-row{display:flex;gap:10px;margin-top:16px}
.fm-hub-secondary-row{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap;justify-content:center}
.fm-hub-large-btn{flex:1;min-height:76px;padding:16px 14px;border-radius:12px;border:1.5px solid #d0dce6;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-size:16px;font-weight:700;color:#1a2a3a;cursor:pointer;transition:background .15s,border-color .15s}
.fm-hub-large-btn:active{background:#f0f6fa}
.fm-hub-large-btn .fm-hub-large-icon{font-size:26px;line-height:1}
.fm-hub-large-btn .fm-hub-large-label{font-size:15px;font-weight:700;text-align:center;line-height:1.2}
.fm-hub-large-btn.fm-ci-hub-btn{border-color:#5a9a8a!important;color:#2a6a5a!important}
.fm-hub-large-btn.fm-ci-hub-btn.fm-ci-done{border-color:#2e7d32!important;color:#2e7d32!important;background:#f0faf0!important}
.fm-hub-large-btn.fm-yg-hub-btn{border-color:#1a3a5c!important;color:#1a3a5c!important}
/* ── Check-in flip row ── */
.fm-ci-flip-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.fm-ci-flip-lbl{font-size:14px;font-weight:600;color:#1a2a3a;flex-shrink:0}
.fm-ci-flip-chk-sel{padding:7px 10px;border:1.5px solid #d0dce6;border-radius:8px;font-size:14px;color:#1a2a3a;background:#fff;-webkit-appearance:none;appearance:none;min-width:90px}
.fm-ci-flip-select{width:100%;padding:9px 12px;border:1.5px solid #d0dce6;border-radius:8px;font-size:14px;color:#1a2a3a;background:#fff;-webkit-appearance:none;appearance:none;margin-bottom:4px}
.fm-ci-flip-select:disabled{background:#f5f5f5;color:#bbb;cursor:not-allowed}
.fm-ci-flip-select:focus{outline:none;border-color:#1a3a5c}
/* ── Daily Farm Check-In modal ── */
.fm-checkin-overlay{position:fixed;inset:0;z-index:80;background:rgba(10,22,40,.72);display:flex;align-items:center;justify-content:center;padding:20px}
.fm-checkin-modal{background:#fff;border-radius:14px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 40px rgba(0,0,0,.28)}
.fm-checkin-header{padding:20px 24px 14px;border-bottom:1px solid #e8edf2;flex-shrink:0}
.fm-checkin-title{font-size:17px;font-weight:700;color:#1a2a3a}
.fm-checkin-body{padding:20px 24px;overflow-y:auto;flex:1}
.fm-ci-static-row{display:flex;gap:28px;margin-bottom:18px;flex-wrap:wrap}
.fm-ci-static-field{display:flex;flex-direction:column;gap:4px}
.fm-ci-static-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#8a9aaa}
.fm-ci-static-val{font-size:14px;font-weight:600;color:#1a2a3a}
.fm-ci-section{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#8a9aaa;margin:16px 0 8px}
.fm-ci-emp-list{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.fm-ci-emp-row{display:flex;align-items:center;gap:8px}
.fm-ci-emp-select{flex:1;padding:9px 12px;border:1.5px solid #d0dce6;border-radius:8px;font-size:14px;color:#1a2a3a;background:#fff;-webkit-appearance:none;appearance:none}
.fm-ci-emp-select:focus{outline:none;border-color:#1a3a5c}
.fm-ci-notes{width:100%;min-height:110px;padding:10px 12px;border:1.5px solid #d0dce6;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;box-sizing:border-box;margin-top:2px}
.fm-ci-notes:focus{outline:none;border-color:#1a3a5c}
.fm-checkin-footer{padding:14px 24px 20px;border-top:1px solid #e8edf2;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0}
.fm-ci-cancel-btn{padding:9px 20px;border-radius:8px;border:1.5px solid #ccc;background:#fff;color:#555;font-size:14px;font-weight:600;cursor:pointer}
.fm-ci-save-btn{padding:9px 22px;border-radius:8px;border:none;background:#1a3a5c;color:#fff;font-size:14px;font-weight:700;cursor:pointer}
/* ── Yield & Growth modal ── */
.fm-yg-overlay{position:fixed;inset:0;z-index:80;background:rgba(10,22,40,.72);display:flex;align-items:center;justify-content:center;padding:20px}
.fm-yg-modal{background:#fff;border-radius:14px;width:100%;max-width:700px;max-height:93vh;display:flex;flex-direction:column;box-shadow:0 8px 40px rgba(0,0,0,.28)}
.fm-yg-header{padding:18px 24px 12px;border-bottom:1px solid #e8edf2;flex-shrink:0}
.fm-yg-title{font-size:17px;font-weight:700;color:#1a2a3a}
.fm-yg-body{padding:20px 24px;overflow-y:auto;flex:1}
.fm-yg-meta{display:flex;gap:24px;margin-bottom:18px;flex-wrap:wrap}
.fm-yg-meta-field{display:flex;flex-direction:column;gap:4px}
.fm-yg-meta-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#8a9aaa}
.fm-yg-meta-val{font-size:14px;font-weight:600;color:#1a2a3a}
.fm-yg-section{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#8a9aaa;margin:16px 0 8px}
.fm-yg-bag-sel{display:flex;gap:10px;flex-wrap:wrap}
.fm-yg-sel{flex:1;min-width:110px;padding:9px 12px;border:1.5px solid #d0dce6;border-radius:8px;font-size:14px;color:#1a2a3a;background:#fff;-webkit-appearance:none;appearance:none}
.fm-yg-sel:disabled{background:#f5f5f5;color:#bbb;cursor:not-allowed}
.fm-yg-sel:focus{outline:none;border-color:#1a3a5c}
.fm-yg-count-row{display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:10px}
#fm-yg-counts-container{margin-bottom:4px}
.fm-yg-add-count-btn{background:none;border:1.5px dashed #b0c8d8;border-radius:7px;color:#4a7a9b;font-size:13px;font-weight:600;padding:6px 14px;cursor:pointer;margin-bottom:16px;width:100%}
.fm-yg-add-count-btn:hover{background:#f0f6fa;border-color:#1a3a5c;color:#1a3a5c}
.fm-yg-count-grp{display:flex;flex-direction:column;gap:5px}
.fm-yg-count-label{font-size:12px;font-weight:600;color:#5a7a8a}
.fm-yg-count-input{width:100px;padding:9px 12px;border:1.5px solid #d0dce6;border-radius:8px;font-size:16px;font-weight:600;text-align:center}
.fm-yg-count-input:focus{outline:none;border-color:#1a3a5c}
.fm-yg-survival-wrap{display:flex;flex-direction:column;gap:5px;padding-bottom:2px}
.fm-yg-survival-label{font-size:12px;font-weight:600;color:#5a7a8a}
.fm-yg-survival-display{font-size:28px;font-weight:800;color:#aaa;min-width:90px}
.fm-yg-heights-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:7px;margin-bottom:12px}
.fm-yg-height{padding:7px 4px;border:1.5px solid #d0dce6;border-radius:6px;font-size:14px;text-align:center;width:100%;box-sizing:border-box}
.fm-yg-height:focus{outline:none;border-color:#1a3a5c}
.fm-yg-notes{width:100%;min-height:70px;padding:10px 12px;border:1.5px solid #d0dce6;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;box-sizing:border-box}
.fm-yg-notes:focus{outline:none;border-color:#1a3a5c}
.fm-yg-footer{padding:14px 24px 20px;border-top:1px solid #e8edf2;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-shrink:0}
.fm-yg-err{font-size:13px;color:#c0392b;font-weight:600;flex:1}
.fm-yg-cancel-btn{padding:9px 20px;border-radius:8px;border:1.5px solid #ccc;background:#fff;color:#555;font-size:14px;font-weight:600;cursor:pointer}
.fm-yg-save-btn{padding:9px 22px;border-radius:8px;border:none;background:#1a3a5c;color:#fff;font-size:14px;font-weight:700;cursor:pointer}
/* ── Farm cohort modals ── */
.on-pc-static{font-size:14px;color:#1a2a3a;padding:2px 0}
/* Place New Bags modal */
.fm-place-bags-modal{max-width:600px;width:96%}
.fm-place-bags-body{max-height:60vh;overflow-y:auto}
.fm-pb-ranges-header{display:flex;align-items:center;justify-content:space-between;margin:16px 0 6px}
.fm-pb-ranges-title{font-size:13px;font-weight:700;color:#1a2a3a}
.fm-pb-add-range-btn{font-size:12px;font-weight:600;color:#1a3a5c;background:none;border:1.5px solid #1a3a5c;border-radius:6px;padding:4px 12px;cursor:pointer}
.fm-pb-add-range-btn:hover{background:#1a3a5c;color:#fff}
.fm-pb-range-labels{display:grid;grid-template-columns:120px 80px 80px 1fr 28px;gap:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#888;margin-bottom:4px}
.fm-pb-range-row{display:grid;grid-template-columns:120px 80px 80px 1fr 28px;gap:6px;align-items:center;margin-bottom:6px}
.fm-pb-range-sel{padding:7px 8px;border:1.5px solid #ccc;border-radius:6px;font-size:13px;font-family:inherit;color:#1a2a3a;background:#fff;width:100%}
.fm-pb-range-num{padding:7px 6px;border:1.5px solid #ccc;border-radius:6px;font-size:13px;font-family:inherit;color:#1a2a3a;width:100%;text-align:center}
.fm-pb-range-num-sm{width:44px}
.fm-pb-bag-range{display:flex;align-items:center;gap:4px;font-size:13px;color:#555}
.fm-pb-remove-btn{background:none;border:none;color:#bbb;font-size:16px;cursor:pointer;padding:0;line-height:1;transition:color .15s}
.fm-pb-remove-btn:hover{color:#c0392b}
.fm-pb-total{font-size:13px;font-weight:700;color:#1a3a5c;margin-top:12px;text-align:right}
/* Bag squares — kept for detail view (Chunk 2) */
.fm-bag{width:30px;height:30px;border-radius:4px;border:1.5px solid #ccc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,box-shadow .1s;flex-shrink:0}
.fm-bag:active{transform:scale(.9)}
.fm-bag.fm-bag-empty{background:#efefeb;border-color:#ccc}
.fm-bag.fm-bag-oyster{background:#c8e6f5;border-color:#5a9abf;color:#2a6090}
.fm-bag.fm-bag-clam{background:#f0dfc0;border-color:#b08040;color:#7a5030}
.fm-bag.fm-bag-scallop{background:#f0b8d0;border-color:#c06080;color:#7a1840}
.fm-bag.fm-bag-seed{background:#d8efc0;border-color:#78a040;color:#3a6010}
.fm-bag.fm-bag-mussel{background:#d4b0e8;border-color:#9060c0;color:#4a1060}
.fm-bag.fm-selected{box-shadow:0 0 0 2.5px var(--seafoam);border-color:var(--seafoam)}
.fm-bag-label{font-size:7px;font-weight:700;line-height:1;pointer-events:none;white-space:nowrap;overflow:hidden}
/* Session tab nav */
.fm-tab-nav{display:flex;border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0}
.fm-tab-btn{flex:1;padding:8px 4px;font-size:12px;font-weight:600;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-bottom:2px solid transparent}
.fm-tab-btn.active{color:var(--seafoam);border-bottom-color:var(--seafoam)}
/* Staging screen */
.fm-staging-screen{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.fm-staging-header{padding:8px 12px;font-size:13px;font-weight:600;color:var(--text-primary);background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}
.fm-selected-list{flex:1;overflow-y:auto;padding:8px 10px}
.fm-selected-item{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--bg);border-radius:8px;margin-bottom:4px;font-size:13px}
.fm-selected-item-label{font-weight:600}
.fm-selected-item-meta{font-size:11px;color:var(--text-secondary)}
.fm-staging-actions{padding:10px 12px;display:flex;gap:8px;flex-wrap:wrap;border-top:1px solid var(--border);background:var(--white);flex-shrink:0}
/* Grade screen */
.fm-grade-screen{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.fm-grade-header{padding:8px 12px;font-size:13px;font-weight:600;background:var(--white);border-bottom:1px solid var(--border);flex-shrink:0}
.fm-grade-body{flex:1;overflow-y:auto;padding:10px 12px}
.fm-grade-row{display:flex;gap:8px;align-items:center;margin-bottom:8px;flex-wrap:wrap}
.fm-grade-row select,.fm-grade-row input{border:1.5px solid var(--border);border-radius:6px;padding:5px 6px;font-size:13px;font-family:inherit;color:var(--text-primary);background:var(--white)}
.fm-grade-row select:focus,.fm-grade-row input:focus{outline:none;border-color:var(--seafoam)}
.fm-grade-count{width:70px}
.fm-grade-add{font-size:12px;font-weight:600;color:var(--seafoam);background:none;border:none;cursor:pointer;padding:4px 0;margin-top:2px}
.fm-grade-add:hover{text-decoration:underline}
.fm-grade-actions{padding:10px 12px;display:flex;gap:8px;border-top:1px solid var(--border);background:var(--white);flex-shrink:0}
/* Confirm overlay */
.fm-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:600;display:flex;align-items:center;justify-content:center}
.fm-confirm-box{background:var(--white);border-radius:14px;padding:20px 22px;max-width:320px;width:90%;box-shadow:0 8px 32px rgba(0,0,0,.18)}
.fm-confirm-title{font-size:15px;font-weight:700;margin-bottom:8px}
.fm-confirm-msg{font-size:13px;color:var(--text-secondary);margin-bottom:16px}
.fm-confirm-btns{display:flex;gap:10px;justify-content:flex-end}
/* Action overlay (Discard / Sell / Transfer) */
.fm-action-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:600;display:flex;align-items:flex-end;justify-content:center}
.fm-action-sheet{background:var(--white);border-radius:16px 16px 0 0;padding:18px 18px 28px;width:100%;max-width:480px;max-height:80vh;overflow-y:auto}
.fm-action-sheet-title{font-size:14px;font-weight:700;margin-bottom:12px}
.fm-action-field{margin-bottom:10px}
.fm-action-field label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary);margin-bottom:3px;text-transform:uppercase;letter-spacing:.05em}
.fm-action-field input,.fm-action-field select,.fm-action-field textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:7px 10px;font-size:13px;font-family:inherit;color:var(--text-primary);background:var(--white);box-sizing:border-box}
.fm-action-field input:focus,.fm-action-field select:focus,.fm-action-field textarea:focus{outline:none;border-color:var(--seafoam)}
.fm-action-btns{display:flex;gap:10px;margin-top:14px}
/* Today's Actions log */
.fm-log{flex:1;overflow-y:auto;padding:8px 10px}
.fm-log-entry{padding:7px 10px;border-radius:8px;background:var(--bg);margin-bottom:5px;font-size:12px}
.fm-log-time{font-size:10px;color:var(--text-secondary);margin-bottom:2px}
.fm-log-desc{font-weight:600;color:var(--text-primary)}
.fm-log-meta{font-size:11px;color:var(--text-secondary)}
.fm-log-empty{text-align:center;color:var(--text-secondary);font-size:13px;padding:30px 0}
/* Pending transfer banner */
.fm-pending-banner{background:#fff7e0;border-bottom:1px solid #e0c860;padding:8px 12px;font-size:12px;font-weight:600;color:#7a6000;display:flex;align-items:center;gap:8px;flex-shrink:0}
.fm-pending-banner button{margin-left:auto;font-size:12px;font-weight:700;background:var(--seafoam);color:#fff;border:none;border-radius:6px;padding:4px 12px;cursor:pointer}
/* Add New Cohort modal */
.fm-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:flex;align-items:flex-end;justify-content:center}
.fm-modal-sheet{background:var(--white);border-radius:16px 16px 0 0;padding:20px 18px 32px;width:100%;max-width:520px;max-height:85vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.fm-modal-title{font-size:16px;font-weight:700}
.fm-modal-field{display:flex;flex-direction:column;gap:4px}
.fm-modal-field label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary)}
.fm-modal-field select,.fm-modal-field input{border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;color:var(--text-primary);background:var(--white)}
.fm-modal-field select:focus,.fm-modal-field input:focus{outline:none;border-color:var(--seafoam)}
.fm-modal-btns{display:flex;gap:10px;margin-top:4px}
/* ── Grade lot cards ── */
.fm-grade-card{border-left:4px solid #a78bfa}
.fm-grade-chip{border-radius:12px;padding:4px 10px;font-size:11px;font-weight:700;flex-shrink:0;white-space:nowrap;display:inline-flex;align-items:center}
.fm-grade-chip-selects{background:#16a34a;color:#fff}
.fm-grade-chip-petites{background:#2563eb;color:#fff}
.fm-grade-chip-putbacks{background:#6b7280;color:#fff}
/* ── Grade distribution modal ── */
.fm-grade-modal{min-width:min(480px,90vw)}
.fm-grade-modal-rows{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.fm-grade-modal-row{background:#f6f6f6;border-radius:10px;padding:12px 14px}
.fm-grade-modal-row-label{font-size:14px;font-weight:700;color:#1a2a3a;margin-bottom:8px}
.fm-grade-modal-row-fields{display:flex;gap:12px}
.fm-grade-modal-row-field{flex:1}
.fm-grade-tally{font-size:13px;color:#888;margin-top:10px;text-align:right}
/* ── Split modal ── */
.fm-split-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:flex;align-items:center;justify-content:center;padding:16px}
.fm-split-modal{background:#fff;border-radius:14px;width:min(600px,92%);max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.25)}
.fm-split-header{padding:18px 20px 14px;border-bottom:1px solid #ebebeb}
.fm-split-title{display:block;font-size:17px;font-weight:700;color:#1a2a3a}
.fm-split-subtitle{display:block;font-size:12px;color:#888;margin-top:3px}
.fm-split-groups{display:flex;gap:8px;padding:12px 20px;flex-wrap:wrap;align-items:center}
.fm-split-group-tab{padding:6px 14px;border-radius:20px;border:2px solid var(--split-color,#2563eb);color:var(--split-color,#2563eb);background:transparent;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}
.fm-split-group-tab.fm-split-tab-active{background:var(--split-color,#2563eb);color:#fff}
.fm-split-add-tab{padding:6px 14px;border-radius:20px;border:2px dashed #ccc;color:#aaa;background:transparent;font-size:13px;cursor:pointer}
.fm-split-instructions{font-size:11px;color:#999;padding:0 20px 8px}
.fm-split-bags-area{flex:1;overflow-y:auto;padding:0 20px 8px}
.fm-split-row-block{margin-bottom:10px}
.fm-split-row-hdr{font-size:12px;font-weight:700;color:#666;padding:4px 8px;cursor:pointer;margin-bottom:5px;border-radius:4px;user-select:none;background:#f5f5f5}
.fm-split-row-hdr:active{opacity:.7}
.fm-split-tiles{display:flex;flex-wrap:wrap;gap:5px}
.fm-split-bag-tile{width:34px;height:34px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;cursor:pointer;user-select:none;transition:opacity .1s}
.fm-split-bag-tile:active{opacity:.65}
.fm-split-footer{padding:14px 20px;border-top:1px solid #ebebeb;display:flex;justify-content:flex-end;gap:10px}
.fm-split-footer button:disabled{opacity:.4;cursor:default;pointer-events:none}
/* ── Placement mode ── */
.fm-place-banner{display:flex;align-items:center;justify-content:space-between;background:rgba(34,211,238,.1);border:1px solid rgba(34,211,238,.3);border-radius:8px;padding:10px 16px;margin-bottom:10px;font-size:14px;color:#22d3ee;flex-wrap:wrap;gap:8px}
.fm-place-banner strong{color:#fff}
.fm-place-banner-cancel{background:transparent;border:1px solid rgba(34,211,238,.4);color:#22d3ee;border-radius:6px;padding:5px 12px;font-size:13px;cursor:pointer;white-space:nowrap}
.fm-place-banner-cancel:hover{background:rgba(34,211,238,.1)}
.fm-drill-bag-place-target{cursor:pointer!important;animation:fm-place-glow 1.2s ease-in-out infinite}
@keyframes fm-place-glow{0%,100%{box-shadow:0 0 0 1.5px #22d3ee,0 0 6px #22d3ee}50%{box-shadow:0 0 0 1.5px rgba(34,211,238,.3),0 0 2px rgba(34,211,238,.3)}}
