/* Inline CSS extracted from charter_portal_v3.html */

:root{
    /* Charter Mfg brand — directly from chartermfg.com */
    --charter-orange:#E07724;
    --charter-orange-dk:#C25E12;
    --charter-orange-lt:#F18E3F;
    --charter-orange-pale:#FEF0E2;

    --bg-dark-1:#1A0F08;   /* near black brown */
    --bg-dark-2:#3A2418;   /* brown */
    --bg-dark-3:#5C3820;   /* lighter brown for gradient */

    --gray-bar:#E8E8E8;
    --gray-bar-line:#B8B8B8;
    --gray-section:#F0F0F0;

    --text-black:#1A1A1A;
    --text-body:#333333;
    --text-mute:#6B6B6B;
    --text-light:#9A9A9A;

    --border:#D8D8D8;
    --border-soft:#E6E6E6;
    --white:#FFFFFF;

    --status-green:#3F8B4E;
    --status-amber:#C68822;
    --status-red:#B83A28;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html,body{font-family:'Open Sans',-apple-system,sans-serif;color:var(--text-body);background:var(--white);line-height:1.55;-webkit-font-smoothing:antialiased;font-size:14px}
  body{min-height:100vh;display:flex;flex-direction:column}
  button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
  a{color:inherit;text-decoration:none}
  .mono{font-family:'Roboto Mono',monospace}

  /* ============ DARK HEADER (matches chartermfg.com) ============ */
  .masthead{
    background:
      radial-gradient(ellipse at 50% 90%, rgba(224,119,36,.35) 0%, transparent 55%),
      radial-gradient(ellipse at 20% 50%, rgba(224,119,36,.12) 0%, transparent 40%),
      linear-gradient(180deg, var(--bg-dark-1) 0%, #2C1810 100%);
    position:relative;
    border-bottom:none;
  }
  .masthead-inner{max-width:1280px;margin:0 auto;padding:0 30px;display:flex;align-items:center;justify-content:center;gap:48px;height:128px;position:relative}

  /* Charter logo — concentric orange rings around black badge */
  .charter-logo{position:absolute;left:50%;top:0;transform:translateX(-50%);width:112px;height:128px;display:flex;align-items:center;justify-content:center}
  .logo-rings{position:relative;width:108px;height:108px;display:flex;align-items:center;justify-content:center}
  .ring{position:absolute;border-radius:50%;border:1px solid var(--charter-orange);opacity:.85}
  .ring.r1{width:108px;height:108px;opacity:.4}
  .ring.r2{width:96px;height:96px;opacity:.55}
  .ring.r3{width:86px;height:86px;opacity:.7}
  .ring.r4{width:78px;height:78px;opacity:.85}
  .ring.r5{width:72px;height:72px;opacity:1;border-width:1.5px}
  .logo-badge{
    position:relative;
    width:64px;height:64px;
    background:#0A0604;
    border-radius:12px;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 0 0 1px rgba(224,119,36,.6), 0 4px 12px rgba(0,0,0,.6);
    z-index:2;
  }
  .logo-badge .word{
    color:#fff;
    font-family:'Open Sans';
    font-weight:700;
    font-size:9.5px;
    letter-spacing:.16em;
    line-height:1;
  }

  /* Primary nav — left and right of logo */
  .nav-left,.nav-right{display:flex;align-items:center;gap:32px;font-family:'Open Sans';font-weight:600;font-size:14.5px;letter-spacing:.05em;text-transform:uppercase}
  .nav-left{margin-right:140px}
  .nav-right{margin-left:140px}
  .nav-left a,.nav-right a{color:#fff;transition:color .15s;padding:6px 0;position:relative}
  .nav-left a:hover,.nav-right a:hover{color:var(--charter-orange)}
  .nav-left a.active,.nav-right a.active{color:var(--charter-orange)}

  /* Search top right (positioned absolute like chartermfg) */
  .masthead-search{position:absolute;right:30px;top:38px;display:flex;align-items:center;height:32px;border:1px solid #555;background:rgba(0,0,0,.3)}
  .masthead-search input{height:30px;width:200px;background:transparent;border:none;padding:0 12px;color:#fff;font-size:13px;font-family:inherit;outline:none}
  .masthead-search input::placeholder{color:#999}
  .masthead-search button{width:34px;height:30px;background:#444;color:#fff;display:flex;align-items:center;justify-content:center;border-left:1px solid #555}
  .masthead-search button:hover{background:var(--charter-orange)}

  /* User chip top left */
  .user-chip{position:absolute;left:30px;top:34px;display:flex;align-items:center;gap:10px;padding:5px 12px 5px 5px;background:rgba(0,0,0,.3);border:1px solid #555;color:#fff;font-size:12.5px}
  .user-chip:hover{border-color:var(--charter-orange)}
  .user-avatar{width:28px;height:28px;border-radius:50%;background:var(--charter-orange);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:11px}
  .user-chip .name{font-weight:600}
  .user-chip .acct{color:#bbb;font-size:11px;display:block;margin-top:1px}

  /* ============ SECONDARY NAV (light gray with pipe separators) ============ */
  .subnav{background:var(--gray-bar);border-bottom:1px solid var(--gray-bar-line)}
  .subnav-inner{max-width:1280px;margin:0 auto;padding:0 30px;height:46px;display:flex;align-items:center;justify-content:center;gap:0;font-size:13px;letter-spacing:.06em;text-transform:uppercase;font-weight:600}
  .subnav-inner a{color:var(--text-black);padding:0 24px;transition:color .15s;display:flex;align-items:center;height:46px}
  .subnav-inner a:hover{color:var(--charter-orange)}
  .subnav-inner a.active{color:var(--charter-orange)}
  .subnav-inner .pipe{color:var(--gray-bar-line);font-weight:300}

  /* ============ ORANGE BANNER STRIP (signature element) ============ */
  .banner-strip{
    background:
      linear-gradient(135deg, var(--charter-orange-lt) 0%, var(--charter-orange) 50%, var(--charter-orange-dk) 100%);
    position:relative;
    overflow:hidden;
    border-top:4px solid #4A3020;
    border-bottom:4px solid #4A3020;
  }
  /* Subtle texture lines */
  .banner-strip::before{
    content:"";position:absolute;inset:0;
    background:
      repeating-linear-gradient(90deg, transparent 0, transparent 60px, rgba(0,0,0,.04) 60px, rgba(0,0,0,.04) 61px),
      repeating-linear-gradient(45deg, transparent 0, transparent 4px, rgba(255,255,255,.025) 4px, rgba(255,255,255,.025) 5px);
    pointer-events:none;
  }
  .banner-inner{
    max-width:1280px;margin:0 auto;padding:0 30px;
    min-height:170px;
    display:flex;align-items:center;gap:36px;
    position:relative;z-index:1;
  }
  .banner-photo{
    width:160px;height:160px;border-radius:50%;
    background:#1a1a1a;
    border:4px solid #fff;
    box-shadow:0 4px 14px rgba(0,0,0,.25);
    flex-shrink:0;
    position:relative;
    overflow:hidden;
    background-image:
      radial-gradient(ellipse at 50% 30%, #C8A88F 0%, #8B6B52 28%, transparent 50%),
      radial-gradient(ellipse at 50% 55%, #4A3424 0%, #2A1810 50%, transparent 70%),
      linear-gradient(180deg, #5A3520 0%, #1A0E08 100%);
  }
  /* Hard-hat silhouette overlay */
  .banner-photo::before{
    content:"";position:absolute;left:50%;top:18%;transform:translateX(-50%);
    width:80px;height:48px;
    background:#fff;
    border-radius:40px 40px 8px 8px;
    box-shadow:0 2px 6px rgba(0,0,0,.4);
  }
  .banner-photo::after{
    content:"";position:absolute;left:50%;top:42%;transform:translateX(-50%);
    width:96px;height:6px;
    background:#fff;
    border-radius:2px;
    box-shadow:0 2px 4px rgba(0,0,0,.4);
  }
  .banner-text{flex:1;font-family:'Open Sans'}
  .banner-text h1{
    font-size:34px;font-weight:700;line-height:1.18;
    color:#0E0500;font-style:italic;letter-spacing:-.005em;
  }
  .banner-text h1 .white-line{color:#fff;display:block}
  .banner-meta{
    position:absolute;right:30px;bottom:20px;
    display:flex;align-items:center;gap:14px;
    color:#fff;font-size:12px;font-weight:600;
    text-transform:uppercase;letter-spacing:.1em;
    background:rgba(0,0,0,.3);padding:8px 14px;
    border:1px solid rgba(255,255,255,.25);
  }
  .banner-meta .live{display:inline-flex;align-items:center;gap:7px}
  .banner-meta .live::before{content:"";width:7px;height:7px;border-radius:50%;background:#7CFF8E;box-shadow:0 0 6px rgba(124,255,142,.9)}

  /* ============ MAIN ============ */
  .container{max-width:1280px;margin:0 auto;padding:42px 30px 60px;width:100%;flex:1}

  /* SECTION HEADER — uppercase orange + orange rule (signature pattern) */
  .section-header{margin-bottom:24px;padding-bottom:14px;border-bottom:1px solid var(--charter-orange);position:relative}
  .section-header h2{
    font-family:'Open Sans';font-weight:700;font-size:22px;
    text-transform:uppercase;letter-spacing:.04em;
    color:var(--charter-orange);
  }
  .section-header .extras{position:absolute;right:0;top:0;display:flex;align-items:center;gap:14px;font-size:13px;color:var(--text-mute)}
  .section-header .extras a{color:var(--charter-orange);font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:12px}
  .section-header .extras a:hover{color:var(--charter-orange-dk)}

  /* ============ KPI ROW ============ */
  .kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:48px}
  .kpi{background:#fff;padding:24px 26px;position:relative;transition:background .15s;cursor:pointer}
  .kpi:hover{background:#FAFAFA}
  .kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-mute);font-weight:700;margin-bottom:10px}
  .kpi-value{font-family:'Open Sans';font-weight:800;font-size:38px;line-height:1.05;color:var(--text-black);margin-bottom:10px;letter-spacing:-.015em}
  .kpi-value .unit{font-size:14px;color:var(--text-mute);font-weight:400;margin-left:6px;letter-spacing:0}
  .kpi-foot{display:flex;align-items:center;justify-content:space-between;font-size:12px;padding-top:12px;border-top:1px solid var(--border-soft)}
  .delta{display:inline-flex;align-items:center;gap:4px;font-weight:700;font-size:12px}
  .delta.up{color:var(--status-green)}
  .delta.down{color:var(--status-red)}
  .delta.neutral{color:var(--text-mute)}
  .kpi-foot .ctx{color:var(--text-mute);font-size:11.5px}
  /* Orange accent triangle in corner of first KPI */
  .kpi.accent::after{
    content:"";position:absolute;top:0;right:0;
    width:0;height:0;
    border-style:solid;
    border-width:0 18px 18px 0;
    border-color:transparent var(--charter-orange) transparent transparent;
  }

  /* ============ MAIN GRID ============ */
  .grid{display:grid;grid-template-columns:1fr 320px;gap:32px;margin-bottom:48px}

  /* ============ PANEL ============ */
  .panel{background:#fff;border:1px solid var(--border)}
  .panel-head{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;background:#FAFAFA}
  .panel-title{font-family:'Open Sans';font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-black);display:flex;align-items:center;gap:10px}
  .panel-title .count{background:var(--charter-orange);color:#fff;font-family:'Roboto Mono';font-size:11px;padding:1px 8px;font-weight:600;letter-spacing:.02em}
  .panel-link{font-size:11.5px;color:var(--charter-orange);font-weight:700;text-transform:uppercase;letter-spacing:.06em}
  .panel-link:hover{color:var(--charter-orange-dk)}

  /* TABS */
  .tabs{display:flex;border-bottom:1px solid var(--border);background:#fff}
  .tab{padding:13px 18px;font-size:12px;font-weight:700;color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em;position:relative;transition:color .15s}
  .tab.active{color:var(--charter-orange)}
  .tab.active::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--charter-orange)}
  .tab:hover:not(.active){color:var(--text-black)}
  .tab .num{margin-left:6px;color:var(--text-light);font-weight:600}
  .tab.active .num{color:var(--charter-orange)}

  /* PIPELINE */
  .pipe-strip{padding:22px 24px;background:#FAFAFA;border-bottom:1px solid var(--border)}
  .pipe-row{display:flex;align-items:flex-start;justify-content:space-between;position:relative}
  .pipe-row::before{content:"";position:absolute;top:13px;left:6%;right:6%;height:2px;background:var(--border);z-index:0}
  .pipe{display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;flex:1}
  .pipe-dot{width:28px;height:28px;border-radius:50%;background:#fff;border:2px solid var(--border);color:var(--text-mute);display:flex;align-items:center;justify-content:center;font-family:'Roboto Mono';font-weight:700;font-size:11.5px;margin-bottom:8px}
  .pipe.done .pipe-dot{background:var(--status-green);border-color:var(--status-green);color:#fff}
  .pipe.active .pipe-dot{background:var(--charter-orange);border-color:var(--charter-orange);color:#fff;box-shadow:0 0 0 4px rgba(224,119,36,.18)}
  .pipe-lbl{font-size:11.5px;font-weight:700;color:var(--text-black);text-transform:uppercase;letter-spacing:.04em;text-align:center}
  .pipe.active .pipe-lbl{color:var(--charter-orange)}
  .pipe-ct{font-family:'Roboto Mono';font-size:11px;color:var(--text-mute);margin-top:3px;font-weight:500}

  /* DATA TABLE */
  .data-table{width:100%;border-collapse:collapse}
  .data-table th{text-align:left;padding:11px 22px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute);background:#FAFAFA;border-bottom:1px solid var(--border)}
  .data-table td{padding:14px 22px;border-bottom:1px solid var(--border-soft);font-size:13px;vertical-align:middle}
  .data-table tr:last-child td{border-bottom:none}
  .data-table tbody tr{transition:background .12s;cursor:pointer}
  .data-table tbody tr:hover{background:#FFF8F1}
  .ord-num{font-family:'Roboto Mono';font-weight:600;color:var(--text-black);font-size:12.5px}
  .ord-num .sub{display:block;font-family:'Open Sans';font-weight:400;font-size:11.5px;color:var(--text-mute);margin-top:2px;letter-spacing:0}
  .mtl{font-weight:600;color:var(--text-black);font-size:13.5px}
  .mtl .sub{display:block;font-weight:400;font-size:11.5px;color:var(--text-mute);margin-top:2px}
  .num{font-family:'Roboto Mono';font-weight:500;font-size:13px;color:var(--text-black)}
  .num .u{color:var(--text-mute);margin-left:3px;font-size:11px}

  /* Status badges (orange-family, since that's the brand) */
  .badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border:1px solid}
  .badge::before{content:"";width:6px;height:6px;border-radius:50%}
  .badge.melt{background:#FFE4D4;color:#9A3F0A;border-color:#F2A878}
  .badge.melt::before{background:#C25E12}
  .badge.roll{background:var(--charter-orange-pale);color:var(--charter-orange-dk);border-color:var(--charter-orange-lt)}
  .badge.roll::before{background:var(--charter-orange)}
  .badge.proc{background:#FFF4D6;color:#8A6810;border-color:#E5C46A}
  .badge.proc::before{background:#C68822}
  .badge.ready{background:#E8E8E8;color:var(--text-black);border-color:#B8B8B8}
  .badge.ready::before{background:#555}
  .badge.ship{background:#DEF0E3;color:#1F6233;border-color:#7BC093}
  .badge.ship::before{background:var(--status-green)}

  .bar{width:96px;height:6px;background:var(--border);overflow:hidden}
  .bar-fill{height:100%;background:var(--charter-orange)}
  .bar-fill.green{background:var(--status-green)}
  .bar-text{display:block;font-size:10.5px;color:var(--text-mute);margin-top:4px;font-family:'Roboto Mono';font-weight:500}

  .promise{font-family:'Roboto Mono';font-weight:600;font-size:12px;color:var(--text-black)}
  .promise .days{display:block;font-size:10.5px;color:var(--text-mute);margin-top:2px;font-weight:500}

  .row-actions{display:flex;gap:2px}
  .row-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--text-mute);transition:all .12s}
  .row-btn:hover{background:var(--charter-orange-pale);color:var(--charter-orange)}

  .table-foot{padding:13px 22px;display:flex;justify-content:space-between;align-items:center;background:#FAFAFA;border-top:1px solid var(--border);font-size:12px;color:var(--text-mute)}

  /* ============ SIDE STACK ============ */
  .side{display:flex;flex-direction:column;gap:28px}

  /* ALERTS */
  .alerts .alert{padding:14px 22px;display:flex;gap:11px;border-bottom:1px solid var(--border-soft);transition:background .12s;cursor:pointer}
  .alerts .alert:last-child{border-bottom:none}
  .alerts .alert:hover{background:#FFF8F1}
  .alert-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px;border:1px solid}
  .alert-icon.orange{background:var(--charter-orange-pale);color:var(--charter-orange-dk);border-color:var(--charter-orange-lt)}
  .alert-icon.green{background:#DEF0E3;color:var(--status-green);border-color:#7BC093}
  .alert-icon.amber{background:#FFF4D6;color:var(--status-amber);border-color:#E5C46A}
  .alert-icon.red{background:#FBE0DC;color:var(--status-red);border-color:#E5907F}
  .alert-body{flex:1;min-width:0}
  .alert-title{font-size:13px;font-weight:600;color:var(--text-black);line-height:1.4;margin-bottom:3px}
  .alert-meta{font-size:11.5px;color:var(--text-mute);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
  .alert-meta .sep{color:var(--border)}
  .alert-meta .em{color:var(--charter-orange);font-weight:700;font-family:'Roboto Mono'}

  /* QUICK LINKS */
  .ql{padding:11px 22px;display:flex;align-items:center;gap:13px;border-bottom:1px solid var(--border-soft);transition:all .12s;cursor:pointer;position:relative}
  .ql:last-child{border-bottom:none}
  .ql:hover{background:#FFF8F1;padding-left:28px}
  .ql-icon{width:32px;height:32px;background:var(--white);border:1px solid var(--border);color:var(--text-black);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .12s}
  .ql:hover .ql-icon{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .ql-text{flex:1;min-width:0}
  .ql-lbl{font-size:13px;font-weight:600;color:var(--text-black)}
  .ql-desc{font-size:11.5px;color:var(--text-mute);margin-top:1px}

  /* DOCS */
  .doc{padding:12px 22px;display:flex;align-items:center;gap:12px;transition:background .12s;cursor:pointer;border-bottom:1px solid var(--border-soft)}
  .doc:last-child{border-bottom:none}
  .doc:hover{background:#FFF8F1}
  .doc-tag{width:36px;height:44px;background:#fff;border:1.5px solid var(--text-black);font-family:'Roboto Mono';font-weight:700;font-size:9px;color:var(--text-black);display:flex;align-items:flex-end;justify-content:center;padding-bottom:5px;flex-shrink:0;position:relative;letter-spacing:.04em}
  .doc-tag::before{content:"";position:absolute;top:0;right:0;width:9px;height:9px;background:var(--text-black);clip-path:polygon(0 0,100% 0,100% 100%)}
  .doc-tag.coa{border-color:var(--status-green);color:var(--status-green)}
  .doc-tag.coa::before{background:var(--status-green)}
  .doc-tag.bol{border-color:var(--charter-orange);color:var(--charter-orange)}
  .doc-tag.bol::before{background:var(--charter-orange)}
  .doc-tag.inv{border-color:var(--status-amber);color:var(--status-amber)}
  .doc-tag.inv::before{background:var(--status-amber)}
  .doc-tag.prc{border-color:var(--charter-orange-dk);color:var(--charter-orange-dk)}
  .doc-tag.prc::before{background:var(--charter-orange-dk)}
  .doc-info{flex:1;min-width:0}
  .doc-name{font-size:13px;font-weight:600;color:var(--text-black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .doc-meta{font-size:11.5px;color:var(--text-mute);font-family:'Roboto Mono';margin-top:2px}

  /* ============ BOTTOM ROW ============ */
  .bottom-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:32px;margin-bottom:48px}

  /* CHART */
  .chart-wrap{padding:24px}
  .chart-legend{display:flex;gap:18px;margin-bottom:18px;flex-wrap:wrap}
  .leg{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text-black);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
  .leg-sq{width:11px;height:11px}
  .chart-area{display:flex;align-items:flex-end;gap:12px;height:160px;padding-top:10px;border-bottom:1px solid var(--border);padding-bottom:10px;position:relative}
  .chart-area::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-soft)}
  .chart-area::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--border-soft)}
  .bar-day{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}
  .bar-stack{width:80%;max-width:36px;display:flex;flex-direction:column;justify-content:flex-end;height:100%;overflow:hidden}
  .bar-seg{transition:opacity .15s;cursor:pointer}
  .bar-seg:hover{opacity:.8}
  .chart-labels{display:flex;gap:12px;margin-top:10px}
  .chart-labels span{flex:1;text-align:center;font-size:11px;color:var(--text-mute);font-family:'Roboto Mono';font-weight:500;text-transform:uppercase}
  .chart-foot{display:flex;justify-content:space-between;padding-top:14px;margin-top:8px;border-top:1px solid var(--border);font-size:12px;color:var(--text-mute)}
  .chart-foot strong{color:var(--text-black);font-weight:800;font-size:15px;letter-spacing:-.005em}

  /* ACTIVITY */
  .feed{padding:8px 22px 18px}
  .feed-item{display:flex;gap:12px;padding:11px 0;position:relative}
  .feed-item:not(:last-child)::after{content:"";position:absolute;left:11px;top:32px;bottom:-8px;width:1px;background:var(--border)}
  .feed-dot{width:24px;height:24px;border-radius:50%;background:#fff;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;color:var(--text-mute)}
  .feed-item.charter .feed-dot{background:var(--charter-orange);border-color:var(--charter-orange);color:#fff}
  .feed-item.you .feed-dot{background:var(--text-black);border-color:var(--text-black);color:#fff}
  .feed-body{flex:1;font-size:12.5px;line-height:1.5;color:var(--text-body)}
  .feed-body .who{font-weight:700;color:var(--text-black)}
  .feed-body em{font-style:normal;font-weight:700;color:var(--text-black);font-family:'Roboto Mono';font-size:12px}
  .feed-time{font-size:11px;color:var(--text-mute);margin-top:3px;font-family:'Roboto Mono'}

  /* TEAM */
  .team-item{padding:14px 22px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-soft)}
  .team-item:last-child{border-bottom:none}
  .team-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--bg-dark-3),var(--bg-dark-1));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;border:2px solid var(--charter-orange-pale)}
  .team-info{flex:1;min-width:0}
  .team-name{font-size:13.5px;font-weight:700;color:var(--text-black)}
  .team-role{font-size:11.5px;color:var(--text-mute);margin-top:2px;display:flex;align-items:center;gap:7px}
  .role-tag{background:var(--charter-orange);color:#fff;padding:2px 7px;font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.05em}
  .team-actions{display:flex;gap:2px}

  /* ============ ORANGE CTA BANNER (recreated from chartermfg) ============ */
  .cta-banner{
    background:var(--charter-orange);
    padding:30px 36px;
    display:flex;align-items:center;justify-content:space-between;gap:24px;
    margin-bottom:48px;
    color:#fff;
    position:relative;
    border-left:6px solid var(--bg-dark-1);
  }
  .cta-banner h3{
    font-family:'Open Sans';font-style:italic;font-weight:700;
    font-size:24px;line-height:1.25;color:#fff;
  }
  .cta-banner h3 em{font-style:normal;color:#0A0604}
  .cta-banner .cta-actions{display:flex;gap:12px;flex-shrink:0}

  /* BUTTONS — Charter style (orange uppercase, rectangular) */
  .btn{
    padding:14px 28px;font-family:'Open Sans';font-weight:700;font-size:12.5px;
    text-transform:uppercase;letter-spacing:.08em;
    display:inline-flex;align-items:center;gap:10px;transition:background .15s;
    border:none;color:#fff;
  }
  .btn-primary{background:var(--charter-orange)}
  .btn-primary:hover{background:var(--charter-orange-dk)}
  .btn-dark{background:var(--bg-dark-1)}
  .btn-dark:hover{background:#000}
  .btn-white{background:#fff;color:var(--charter-orange)}
  .btn-white:hover{background:#0A0604;color:#fff}

  /* ============ CHATBOT ============ */
  .chatbot{position:fixed;bottom:24px;right:24px;z-index:100}
  .chat-fab{
    width:56px;height:56px;background:var(--charter-orange);color:#fff;
    border-radius:50%;display:flex;align-items:center;justify-content:center;
    box-shadow:0 8px 24px rgba(224,119,36,.4),0 4px 8px rgba(0,0,0,.15);
    cursor:pointer;transition:all .2s;position:relative;
  }
  .chat-fab:hover{background:var(--charter-orange-dk);transform:translateY(-2px)}
  .chat-fab::after{content:"";position:absolute;top:4px;right:4px;width:11px;height:11px;background:#7CFF8E;border:2px solid var(--white);border-radius:50%}

  /* ============ FOOTER ============ */
  .footer{background:var(--bg-dark-1);color:#bbb;margin-top:auto;position:relative}
  .footer::before{
    content:"";position:absolute;top:0;left:0;right:0;height:4px;
    background:var(--charter-orange);
  }
  .footer-top{max-width:1280px;margin:0 auto;padding:48px 30px 32px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:36px}
  .footer-brand .fb-logo{display:flex;align-items:center;gap:14px;margin-bottom:18px}
  .fb-logo .logo-rings{width:64px;height:64px}
  .fb-logo .ring.r1{width:64px;height:64px}
  .fb-logo .ring.r2{width:56px;height:56px}
  .fb-logo .ring.r3{width:50px;height:50px}
  .fb-logo .ring.r4{width:46px;height:46px}
  .fb-logo .ring.r5{width:42px;height:42px}
  .fb-logo .logo-badge{width:38px;height:38px;border-radius:7px}
  .fb-logo .logo-badge .word{font-size:6px}
  .fb-logo .fb-text .name{color:#fff;font-weight:700;font-size:18px;display:block;letter-spacing:.02em}
  .fb-logo .fb-text .tag{color:#999;font-size:11.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;margin-top:2px;display:block}
  .footer-tag{font-size:13px;color:#bbb;line-height:1.65}
  .footer-addr{font-size:12px;color:#999;line-height:1.65;margin-top:14px}
  .footer-addr strong{color:var(--charter-orange);font-weight:700;display:block;margin-bottom:2px;font-size:13px}
  .footer h4{font-family:'Open Sans';font-size:12px;font-weight:700;color:var(--charter-orange);text-transform:uppercase;letter-spacing:.12em;margin-bottom:16px}
  .footer ul{list-style:none;display:flex;flex-direction:column;gap:9px}
  .footer ul a{font-size:13px;color:#bbb;transition:color .15s}
  .footer ul a:hover{color:var(--charter-orange)}
  .footer-bottom{border-top:1px solid #3A2418;background:#0A0604}
  .footer-bottom-inner{max-width:1280px;margin:0 auto;padding:18px 30px;display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:#777;flex-wrap:wrap;gap:14px}
  .fb-links{display:flex;gap:20px}
  .fb-links a{color:#999;text-transform:uppercase;letter-spacing:.05em;font-weight:600;font-size:11px}
  .fb-links a:hover{color:var(--charter-orange)}

  /* ============ RESPONSIVE ============ */
  @media (max-width:1100px){
    .nav-left,.nav-right{display:none}
    .charter-logo{position:relative;left:auto;transform:none}
    .masthead-inner{justify-content:center;height:96px}
    .grid{grid-template-columns:1fr}
    .kpi-row{grid-template-columns:repeat(2,1fr)}
    .bottom-grid{grid-template-columns:1fr}
    .footer-top{grid-template-columns:1fr 1fr}
    .banner-meta{position:relative;right:auto;bottom:auto;margin-top:14px}
  }
  @media (max-width:720px){
    .masthead-search,.user-chip,.section-header .extras{display:none}
    .container{padding:24px 18px 40px}
    .kpi-row{grid-template-columns:1fr}
    .banner-inner{flex-direction:column;text-align:center;padding:24px}
    .banner-text h1{font-size:24px}
    .cta-banner{flex-direction:column;text-align:left}
    .footer-top{grid-template-columns:1fr}
  }

  /* ================================================================ */
  /* === Additions for Open Orders + Shipments & Trips pages       === */
  /* === (Selectors that conflict with the home page are skipped   === */
  /* ===  so the home page renders unchanged.)                     === */
  /* ================================================================ */

  input,select{font-family:inherit;color:var(--text-body)}

  /* Banner sub-line (used on Open Orders + Shipments banners) */
  .banner-text .sub{margin-top:6px;color:#fff;font-weight:600;font-size:14px;letter-spacing:.04em;text-transform:uppercase}
  .banner-text .sub strong{color:#0E0500;font-weight:800}

  /* ============ FILTER TOOLBAR (Open Orders + Shipments) ============ */
  .toolbar{background:#FAFAFA;border:1px solid var(--border);padding:18px 22px;margin-bottom:0;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
  .toolbar-search{flex:1;min-width:240px;max-width:380px;position:relative}
  .toolbar-search input{width:100%;height:38px;border:1px solid var(--border);background:#fff;padding:0 14px 0 38px;font-size:13.5px;outline:none;transition:border-color .15s}
  .toolbar-search input:focus{border-color:var(--charter-orange);box-shadow:0 0 0 3px rgba(224,119,36,.12)}
  .toolbar-search svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-mute)}
  .filter-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .filter-select{height:38px;border:1px solid var(--border);background:#fff;padding:0 32px 0 14px;font-size:13px;font-weight:600;color:var(--text-black);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B6B6B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;outline:none}
  .filter-select:hover{border-color:var(--text-mute)}
  .filter-select:focus{border-color:var(--charter-orange)}
  .toolbar-spacer{flex:1}
  .toolbar-btn{height:38px;padding:0 16px;border:1px solid var(--border);background:#fff;font-size:12px;font-weight:700;color:var(--text-black);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:7px;transition:all .12s}
  .toolbar-btn:hover{border-color:var(--charter-orange);color:var(--charter-orange)}
  .toolbar-btn.primary{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .toolbar-btn.primary:hover{background:var(--charter-orange-dk);border-color:var(--charter-orange-dk);color:#fff}

  /* ============ SAVED SEARCHES (Open Orders) ============ */
  .saved-row{background:#fff;border:1px solid var(--border);border-top:none;padding:12px 22px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:13px}
  .saved-row .lbl{color:var(--text-mute);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:11px;margin-right:4px}
  .chip{display:inline-flex;align-items:center;gap:8px;padding:5px 11px;background:var(--charter-orange-pale);border:1px solid var(--charter-orange-lt);color:var(--charter-orange-dk);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s}
  .chip:hover{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .chip .x{opacity:.5;font-size:13px;line-height:1}
  .chip.active{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .chip-count{background:rgba(255,255,255,.3);padding:1px 6px;font-family:'Roboto Mono';font-size:10.5px}
  .chip-add{background:#fff;color:var(--text-mute);border:1px dashed var(--border)}
  .chip-add:hover{color:var(--charter-orange);border-color:var(--charter-orange);background:#fff}

  /* ============ ACTIVE FILTER PILLS (Open Orders) ============ */
  .active-filters{background:#fff;border:1px solid var(--border);border-top:none;padding:10px 22px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12px}
  .active-filters .lbl{color:var(--text-mute);font-weight:600;font-size:11.5px}
  .filter-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 4px 3px 10px;background:#fff;border:1px solid var(--border);font-size:11.5px;font-weight:600;color:var(--text-black)}
  .filter-pill strong{color:var(--charter-orange);font-weight:700}
  .filter-pill button{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-mute);background:transparent;border-radius:50%}
  .filter-pill button:hover{background:var(--charter-orange);color:#fff}
  .filter-clear{margin-left:auto;color:var(--charter-orange);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:11px}
  .filter-clear:hover{color:var(--charter-orange-dk)}

  /* ============ TABLE WRAPPER + bulk header (Open Orders) ============ */
  .table-wrap{border:1px solid var(--border);border-top:none;background:#fff;margin-bottom:32px}
  .table-head-row{padding:14px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:#FAFAFA;font-size:12.5px;color:var(--text-mute)}
  .table-head-row strong{color:var(--text-black);font-weight:700}
  .table-head-row .bulk-actions{display:none;align-items:center;gap:10px}
  .table-head-row.has-selection .bulk-actions{display:flex}
  .table-head-row.has-selection .count-info{color:var(--charter-orange);font-weight:700}
  .bulk-btn{height:30px;padding:0 12px;border:1px solid var(--border);background:#fff;font-size:11.5px;font-weight:700;color:var(--text-black);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:6px}
  .bulk-btn:hover{border-color:var(--charter-orange);color:var(--charter-orange)}

  /* ============ DATA TABLE additions (Open Orders) ============ */
  .data-table th.sort{cursor:pointer;user-select:none;position:sticky;top:0}
  .data-table th.sort:hover{color:var(--text-black)}
  .data-table th.sort::after{content:" ↕";opacity:.5}
  .data-table th.sort-asc::after{content:" ↑";opacity:1;color:var(--charter-orange)}
  .data-table th.sort-desc::after{content:" ↓";opacity:1;color:var(--charter-orange)}
  .data-table tbody tr.selected{background:var(--charter-orange-pale)}
  .data-table tbody tr.selected:hover{background:#FCE4CB}
  .check{width:16px;height:16px;border:1.5px solid var(--border);background:#fff;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:all .12s}
  .check:hover{border-color:var(--charter-orange)}
  .check.checked{background:var(--charter-orange);border-color:var(--charter-orange);color:#fff}

  .heat-num{font-family:'Roboto Mono';font-weight:500;font-size:11.5px;color:var(--charter-orange-dk);background:var(--charter-orange-pale);padding:2px 7px;display:inline-block;letter-spacing:.02em}
  .ship-to{font-weight:600;color:var(--text-black);font-size:12.5px}
  .ship-to .sub{display:block;font-weight:400;font-size:11px;color:var(--text-mute);margin-top:2px}
  .mill-tag{display:inline-block;padding:2px 7px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-family:'Open Sans'}
  .mill-tag.sk{background:#FFE4D4;color:#9A3F0A}
  .mill-tag.cl{background:#FFEFD9;color:#8A5500}
  .mill-tag.rs{background:#E5D8CC;color:#4A3020}

  .badge.hold{background:#FBE0DC;color:#7A1F0F;border-color:#E5907F}
  .badge.hold::before{background:var(--status-red)}
  .badge.booked{background:#E8E8E8;color:var(--text-mute);border-color:#B8B8B8}
  .badge.booked::before{background:#999}

  .bar-fill.red{background:var(--status-red)}
  .promise.late{color:var(--status-red)}
  .promise.today{color:var(--charter-orange-dk)}

  /* ============ PAGINATION (Open Orders) ============ */
  .pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;background:#FAFAFA;border-top:1px solid var(--border);font-size:12.5px;color:var(--text-mute)}
  .pagination .info{color:var(--text-mute)}
  .pagination .info strong{color:var(--text-black);font-weight:700}
  .pager{display:flex;align-items:center;gap:2px}
  .pager-btn{min-width:32px;height:32px;padding:0 8px;border:1px solid var(--border);background:#fff;font-size:12.5px;font-weight:600;color:var(--text-black);display:inline-flex;align-items:center;justify-content:center;transition:all .12s}
  .pager-btn:hover:not(:disabled){border-color:var(--charter-orange);color:var(--charter-orange)}
  .pager-btn.active{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .pager-btn:disabled{opacity:.4;cursor:not-allowed}
  .per-page{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-mute)}
  .per-page select{height:28px;border:1px solid var(--border);background:#fff;padding:0 26px 0 10px;font-size:12px;font-weight:600;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B6B6B' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}

  /* ============ STATUS TABS (Shipments) ============ */
  .status-tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:0}
  .status-tab{background:#FAFAFA;padding:18px 22px;cursor:pointer;text-align:left;transition:all .15s;position:relative}
  .status-tab:hover{background:#fff}
  .status-tab.active{background:#fff}
  .status-tab.active::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--charter-orange)}
  .status-tab-label{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-mute);font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:7px}
  .status-tab-label .dot{width:8px;height:8px;border-radius:50%}
  .status-tab-label .dot.green{background:var(--status-green)}
  .status-tab-label .dot.orange{background:var(--charter-orange)}
  .status-tab-label .dot.amber{background:var(--status-amber)}
  .status-tab-label .dot.gray{background:#999}
  .status-tab-label .dot.red{background:var(--status-red)}
  .status-tab-value{font-weight:800;font-size:26px;line-height:1;color:var(--text-black);letter-spacing:-.015em}
  .status-tab.active .status-tab-value{color:var(--charter-orange)}
  .status-tab-sub{font-size:11.5px;color:var(--text-mute);margin-top:4px}

  /* ============ VIEW TOGGLE (Shipments) ============ */
  .view-toggle{display:flex;border:1px solid var(--border);background:#fff;height:38px}
  .view-toggle button{padding:0 14px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-mute);display:flex;align-items:center;gap:6px;border-right:1px solid var(--border);transition:all .12s}
  .view-toggle button:last-child{border-right:none}
  .view-toggle button.active{background:var(--charter-orange);color:#fff}
  .view-toggle button:hover:not(.active){color:var(--charter-orange)}

  /* ============ SHIPMENT GRID (Shipments) ============ */
  .ship-grid{display:grid;grid-template-columns:1fr 380px;gap:28px;margin-bottom:36px;margin-top:32px}

  /* ============ TRIP CARDS (Shipments) ============ */
  .trips-list{display:flex;flex-direction:column;gap:14px}
  .trip-card{background:#fff;border:1px solid var(--border);transition:all .15s;cursor:pointer}
  .trip-card:hover{border-color:var(--charter-orange);box-shadow:0 4px 12px rgba(224,119,36,.08)}
  .trip-card.active-trip{border-left:4px solid var(--charter-orange)}

  .trip-head{padding:14px 20px;display:flex;align-items:center;justify-content:space-between;gap:14px;border-bottom:1px solid var(--border-soft);background:#FAFAFA;flex-wrap:wrap}
  .trip-head-left{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
  .trip-id{font-family:'Roboto Mono';font-weight:700;font-size:15px;color:var(--text-black);letter-spacing:.02em}
  .trip-id .pre{color:var(--text-mute);font-weight:500;font-size:11.5px;text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:1px}
  .trip-divider{width:1px;height:24px;background:var(--border)}
  .trip-meta{display:flex;flex-direction:column;font-size:11.5px}
  .trip-meta .lbl{color:var(--text-mute);text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:10.5px}
  .trip-meta .val{color:var(--text-black);font-weight:600;font-family:'Roboto Mono';font-size:12.5px;margin-top:1px}

  .badge.arrived{background:#E5D8CC;color:#4A3020;border-color:#A8866C}
  .badge.arrived::before{background:#4A3020}
  .badge.scheduled{background:var(--charter-orange-pale);color:var(--charter-orange-dk);border-color:var(--charter-orange-lt)}
  .badge.scheduled::before{background:var(--charter-orange)}
  .badge.appt{background:#FFF4D6;color:#8A6810;border-color:#E5C46A}
  .badge.appt::before{background:var(--status-amber)}
  .badge.delivered{background:#E8E8E8;color:var(--text-black);border-color:#B8B8B8}
  .badge.delivered::before{background:#555}
  .badge.delayed{background:#FBE0DC;color:#7A1F0F;border-color:#E5907F}
  .badge.delayed::before{background:var(--status-red)}

  .trip-body{padding:18px 20px 16px;display:flex;align-items:center;gap:20px;flex-wrap:wrap}
  .route{flex:1;min-width:0;display:flex;align-items:center;gap:0;position:relative}
  .route-point{display:flex;flex-direction:column;gap:2px;min-width:0;flex-shrink:0;max-width:38%}
  .route-point .city{font-weight:700;font-size:14px;color:var(--text-black);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .route-point .addr{font-size:11.5px;color:var(--text-mute);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .route-point .time{font-family:'Roboto Mono';font-size:11.5px;color:var(--text-black);font-weight:600;margin-top:3px}
  .route-point.dest{text-align:right}
  .route-line{flex:1;height:32px;position:relative;display:flex;align-items:center;min-width:80px}
  .route-line::before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background:var(--border);transform:translateY(-50%)}
  .route-line .progress-line{position:absolute;top:50%;left:0;height:2px;background:var(--charter-orange);transform:translateY(-50%);transition:width .3s}
  .route-line .truck{position:absolute;top:50%;transform:translate(-50%,-50%);width:26px;height:26px;background:var(--charter-orange);color:#fff;display:flex;align-items:center;justify-content:center;border:3px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.2);border-radius:50%;z-index:2}
  .route-line .dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:50%;background:#fff;border:2px solid var(--border);z-index:1}
  .route-line .dot.start{left:0;background:var(--text-black);border-color:var(--text-black)}
  .route-line .dot.end{right:0;left:auto;transform:translate(50%,-50%);background:#fff;border-color:var(--text-mute)}
  .route-line .dot.end.done{background:var(--status-green);border-color:var(--status-green)}

  .trip-metrics{display:flex;align-items:center;gap:20px;flex-shrink:0;padding-left:8px;border-left:1px solid var(--border-soft)}
  .metric{text-align:center}
  .metric-val{font-family:'Roboto Mono';font-weight:700;font-size:15px;color:var(--text-black);line-height:1}
  .metric-val.eta-soon{color:var(--charter-orange)}
  .metric-val.late{color:var(--status-red)}
  .metric-lbl{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-mute);font-weight:700;margin-top:4px}

  .trip-foot{padding:12px 20px;background:#FCFAF7;border-top:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
  .orders-on-trip{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px}
  .orders-on-trip .lbl{color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;font-weight:700;font-size:10.5px;margin-right:2px}
  .order-pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;background:#fff;border:1px solid var(--border);font-family:'Roboto Mono';font-size:11.5px;font-weight:600;color:var(--text-black)}
  .order-pill:hover{border-color:var(--charter-orange);color:var(--charter-orange-dk)}
  .order-pill .wt{color:var(--text-mute);font-weight:500}
  .trip-actions{display:flex;gap:6px}
  .tact-btn{height:30px;padding:0 11px;border:1px solid var(--border);background:#fff;font-size:11px;font-weight:700;color:var(--text-black);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:5px}
  .tact-btn:hover{border-color:var(--charter-orange);color:var(--charter-orange)}
  .tact-btn.primary{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .tact-btn.primary:hover{background:var(--charter-orange-dk);color:#fff}

  /* ============ SIDE COLUMN (Shipments) ============ */
  /* Note: .panel/.panel-head/.panel-title/.panel-link are already defined for the home page */
  .side{display:flex;flex-direction:column;gap:20px;position:sticky;top:20px;height:fit-content}

  /* ============ MAP MOCKUP (Shipments) ============ */
  .map-frame{position:relative;height:280px;background:linear-gradient(135deg, #E8E0D4 0%, #D4C8B6 100%);overflow:hidden}
  .map-frame::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(28deg, transparent 0, transparent 40px, rgba(0,0,0,.04) 40px, rgba(0,0,0,.04) 41px),repeating-linear-gradient(-15deg, transparent 0, transparent 70px, rgba(0,0,0,.05) 70px, rgba(0,0,0,.05) 71px),radial-gradient(ellipse at 30% 30%, rgba(180,200,150,.4) 0%, transparent 35%),radial-gradient(ellipse at 70% 70%, rgba(150,180,200,.3) 0%, transparent 30%)}
  .map-road{position:absolute;top:30%;left:0;width:100%;height:3px;background:#fff;transform:rotate(8deg);box-shadow:0 0 0 1px rgba(0,0,0,.1)}
  .map-road-2{position:absolute;top:65%;left:0;width:100%;height:3px;background:#fff;transform:rotate(-12deg);box-shadow:0 0 0 1px rgba(0,0,0,.1)}
  .map-pin{position:absolute;width:32px;height:32px;transform:translate(-50%,-100%);z-index:3}
  .map-pin::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:24px;background:var(--charter-orange);border-radius:50%;border:3px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.3)}
  .map-pin::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:0;border-style:solid;border-width:10px 6px 0 6px;border-color:var(--charter-orange) transparent transparent transparent}
  .map-pin.mill::before{background:var(--text-black);width:18px;height:18px;border-radius:0;top:3px}
  .map-pin.mill::after{border-top-color:var(--text-black);bottom:6px}
  .map-pin .badge-num{position:absolute;top:3px;left:50%;transform:translateX(-50%);color:#fff;font-weight:700;font-size:11px;font-family:'Open Sans';z-index:1}
  .map-pin.mill .badge-num{color:#fff;font-size:9px;top:5px}
  .map-pin .pulse{position:absolute;top:2px;left:50%;transform:translateX(-50%);width:24px;height:24px;border-radius:50%;background:var(--charter-orange);opacity:.4;animation:mapPulse 2s infinite}
  @keyframes mapPulse{0%{transform:translateX(-50%) scale(1);opacity:.4}100%{transform:translateX(-50%) scale(2.5);opacity:0}}
  .map-route{position:absolute;top:50%;left:25%;width:50%;height:2px;background:none;z-index:2}
  .map-route::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(90deg, var(--charter-orange) 0, var(--charter-orange) 6px, transparent 6px, transparent 11px);transform:rotate(18deg);transform-origin:left center}
  .map-controls{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);box-shadow:0 2px 4px rgba(0,0,0,.06);z-index:5}
  .map-controls button{width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--text-black);border-bottom:1px solid var(--border);font-weight:700;font-size:14px}
  .map-controls button:last-child{border-bottom:none}
  .map-controls button:hover{background:var(--charter-orange);color:#fff}
  .map-legend{position:absolute;bottom:10px;left:10px;display:flex;gap:10px;background:rgba(255,255,255,.95);padding:6px 10px;font-size:10.5px;font-weight:600;border:1px solid var(--border);z-index:5}
  .map-legend .item{display:flex;align-items:center;gap:5px;color:var(--text-black)}
  .map-legend .dot-mill{width:8px;height:8px;background:var(--text-black)}
  .map-legend .dot-trip{width:8px;height:8px;border-radius:50%;background:var(--charter-orange)}

  /* ============ TODAY LIST (Shipments side panels) ============ */
  .today-list{padding:4px 0}
  .today-item{padding:12px 18px;border-bottom:1px solid var(--border-soft);display:flex;align-items:flex-start;gap:11px;cursor:pointer;transition:background .12s}
  .today-item:last-child{border-bottom:none}
  .today-item:hover{background:#FFF8F1}
  .today-time{font-family:'Roboto Mono';font-weight:700;font-size:13px;color:var(--charter-orange-dk);min-width:60px;line-height:1.2}
  .today-time .ampm{font-size:10px;font-weight:600;color:var(--text-mute);display:block;margin-top:1px;letter-spacing:.04em}
  .today-info{flex:1;min-width:0}
  .today-trip{font-family:'Roboto Mono';font-weight:700;font-size:12px;color:var(--text-black)}
  .today-dest{font-size:11.5px;color:var(--text-body);margin-top:1px}
  .today-status{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:3px;display:inline-flex;align-items:center;gap:5px}
  .today-status.ontime{color:var(--status-green)}
  .today-status.delayed{color:var(--status-red)}
  .today-status::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}

  /* ============ APPOINTMENT ALERT (Shipments needs-action panel) ============ */
  .appt-needed{padding:14px 18px;background:#FFF4D6;border-left:3px solid var(--status-amber);border-bottom:1px solid var(--border)}
  .appt-needed strong{color:#8A6810;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:3px}
  .appt-needed p{font-size:12.5px;color:var(--text-body);margin-bottom:8px}
  .appt-needed button{font-size:11px;font-weight:700;color:var(--status-amber);text-transform:uppercase;letter-spacing:.06em}

  /* Responsive overrides for new pages */
  @media (max-width:1100px){
    .status-tabs{grid-template-columns:repeat(2,1fr)}
    .ship-grid{grid-template-columns:1fr}
    .side{position:static}
    .data-table{font-size:12px}
  }
  @media (max-width:720px){
    .kpi-row,.status-tabs{grid-template-columns:1fr}
    .toolbar{padding:14px}
    .trip-body{flex-direction:column;align-items:flex-start}
    .trip-metrics{border-left:none;border-top:1px solid var(--border-soft);padding-left:0;padding-top:12px;width:100%;justify-content:space-between}
  }

  /* ================================================================ */
  /* === Additions for the Documents page                          === */
  /* === (Selectors are unique to this page; no overrides of home.) === */
  /* ================================================================ */

  /* Doc-tag color tokens (re-using the same hex values as the existing palette
     but exposed under explicit doc-* names so the documents page can extend
     to spec/pod/cert without polluting the global tokens) */
  :root{
    --doc-spec:#3D6FCD;
    --doc-pod:#7A4FA8;
    --doc-cert:#1F8A8A;
  }

  /* Three new doc-tag variants for the Documents page table */
  .doc-tag.spec{border-color:var(--doc-spec);color:var(--doc-spec)}
  .doc-tag.spec::before{background:var(--doc-spec)}
  .doc-tag.pod{border-color:var(--doc-pod);color:var(--doc-pod)}
  .doc-tag.pod::before{background:var(--doc-pod)}
  .doc-tag.cert{border-color:var(--doc-cert);color:var(--doc-cert)}
  .doc-tag.cert::before{background:var(--doc-cert)}

  /* Doc-cell layout inside a table cell: tag + info side-by-side */
  .doc-cell{display:flex;align-items:center;gap:14px}
  .doc-info .doc-name{font-weight:700;color:var(--text-black);font-size:13.5px;line-height:1.3}
  .doc-info .doc-name .new{display:inline-block;color:#fff;background:var(--status-green);padding:1px 6px;font-size:9px;letter-spacing:.06em;font-weight:700;margin-left:6px;vertical-align:middle;text-transform:uppercase}

  /* Order-reference pill used in the "Related" column */
  .so-ref{font-family:'Roboto Mono';font-size:11.5px;color:var(--charter-orange-dk);background:var(--charter-orange-pale);padding:2px 7px;display:inline-block;font-weight:500}

  /* "Added" date column with relative time below */
  .added{font-family:'Roboto Mono';font-size:12px;color:var(--text-black);font-weight:500;white-space:nowrap}
  .added .ago{display:block;font-size:11px;color:var(--text-mute);margin-top:2px;font-weight:400}

  /* Action buttons in the Documents table — distinct class names so they
     don't override the icon-button .row-btn used by the home OrdersPanel. */
  .doc-actions{display:flex;gap:6px;justify-content:flex-end}
  .doc-action-btn{height:30px;padding:0 12px;border:1px solid var(--border);background:#fff;font-size:11.5px;font-weight:700;color:var(--text-black);text-transform:uppercase;letter-spacing:.05em;display:inline-flex;align-items:center;gap:6px;transition:all .12s}
  .doc-action-btn:hover{border-color:var(--charter-orange);color:var(--charter-orange)}
  .doc-action-btn.primary{background:var(--charter-orange);color:#fff;border-color:var(--charter-orange)}
  .doc-action-btn.primary:hover{background:var(--charter-orange-dk);color:#fff}

  /* Responsive hide-md class for the Documents table on narrow screens */
  @media (max-width:720px){
    .data-table th.hide-md,.data-table td.hide-md{display:none}
    .doc-actions{flex-direction:column;gap:4px}
  }

  /* ================================================================ */
  /* === Masthead user-chip: login + logout states                 === */
  /* ================================================================ */

  /* The .user-chip wrapper can now be either a <div> (logged in) or an <a>
     (logged out). Strip the default link underline + inherited link color. */
  a.user-chip,a.user-chip:hover{text-decoration:none;color:#fff}

  /* Wrapper for the name/acct pair — same layout as the unnamed div before */
  .user-chip__info{display:flex;flex-direction:column}

  /* Inline icon-only logout link, sits to the right of name/acct */
  .user-chip__logout{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;margin-left:6px;color:#bbb;border-left:1px solid #555;padding-left:6px;transition:color .15s}
  .user-chip__logout:hover{color:var(--charter-orange)}

  /* Anonymous-state avatar — grey background so it reads as "not signed in" */
  .user-avatar--anon{background:#444}
