/* ════════════════════════════════════════════
   FIDELIS GO — styles.css
   Extracted from index_html.html (Phase 1)
   All visual styles for the entire platform
════════════════════════════════════════════ */

/* ── CSS VARIABLES ── */
:root {
  --blue:      #2B45F5;
  --blue-dk:   #1a30d4;
  --blue-lt:   #EEF1FF;
  --blue-mid:  #c7cefc;
  --black:     #0D0E12;
  --g900:      #111827;
  --g700:      #374151;
  --g500:      #6B7280;
  --g400:      #9CA3AF;
  --g200:      #E5E7EB;
  --g100:      #F3F4F6;
  --white:     #FFFFFF;
  --green:     #16A34A;
  --green-lt:  #DCFCE7;
  --yellow:    #CA8A04;
  --yellow-lt: #FEF9C3;
  --red:       #DC2626;
  --red-lt:    #FEE2E2;
  --border:    #E5E7EB;
  --r:         10px;
  --rlg:       14px;
  --sh:        0 1px 3px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
  --shmd:      0 4px 16px rgba(0,0,0,0.1),0 2px 4px rgba(0,0,0,0.05);
  --font:      'Inter', sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font);background:var(--g100);color:var(--g900);font-size:15px;line-height:1.6;min-height:100vh;}

/* ── SETUP SCREEN ── */
#setup-screen{display:none;position:fixed;inset:0;background:var(--g900);z-index:9999;overflow-y:auto;padding:40px 20px;}
.setup-inner{max-width:700px;margin:0 auto;}
.setup-logo{height:48px;margin-bottom:32px;}
.setup-title{font-size:28px;font-weight:700;color:var(--white);margin-bottom:8px;letter-spacing:-0.02em;}
.setup-sub{font-size:15px;color:var(--g400);margin-bottom:32px;}
.step-box{background:#1a1c24;border:1px solid #2e3040;border-radius:var(--rlg);padding:24px;margin-bottom:16px;}
.step-num{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--blue);color:var(--white);border-radius:50%;font-size:13px;font-weight:700;margin-bottom:12px;}
.step-title{font-size:16px;font-weight:600;color:var(--white);margin-bottom:8px;}
.step-desc{font-size:13px;color:var(--g400);line-height:1.7;margin-bottom:14px;}
.step-desc a{color:var(--blue-mid);text-decoration:none;}
.step-desc a:hover{text-decoration:underline;}
.code-block{background:#0d0e12;border:1px solid #2e3040;border-radius:6px;padding:12px 14px;font-family:monospace;font-size:13px;color:#7dd3fc;margin:10px 0;}
.cfg-field{margin-bottom:12px;}
.cfg-field label{display:block;font-size:12px;font-weight:600;letter-spacing:0.05em;text-transform:uppercase;color:var(--g400);margin-bottom:5px;}
.cfg-field input{width:100%;background:#0d0e12;border:1.5px solid #2e3040;border-radius:7px;color:var(--white);font-family:monospace;font-size:14px;padding:10px 12px;outline:none;transition:border-color 0.15s;}
.cfg-field input:focus{border-color:var(--blue);}
.setup-btn{background:var(--blue);color:var(--white);border:none;border-radius:8px;padding:12px 28px;font-size:15px;font-weight:600;cursor:pointer;width:100%;margin-top:8px;}
.setup-btn:hover{background:var(--blue-dk);}
.setup-note{font-size:12px;color:var(--g500);margin-top:8px;text-align:center;}

/* ── AUTH SCREEN ── */
#auth-screen{display:flex;position:fixed;inset:0;background:var(--g100);z-index:500;align-items:center;justify-content:center;}
.auth-card{background:var(--white);border:1px solid var(--border);border-radius:var(--rlg);padding:36px;width:100%;max-width:400px;box-shadow:var(--shmd);}
.auth-logo{height:44px;margin-bottom:24px;}
.auth-title{font-size:22px;font-weight:700;margin-bottom:4px;letter-spacing:-0.02em;}
.auth-sub{font-size:14px;color:var(--g500);margin-bottom:24px;}
.auth-role-tabs{display:flex;background:var(--g100);border-radius:8px;padding:3px;gap:2px;margin-bottom:20px;}
.auth-role-tab{flex:1;padding:7px;border:none;border-radius:6px;background:transparent;font-size:13px;font-weight:600;color:var(--g500);cursor:pointer;transition:all 0.15s;}
.auth-role-tab.active{background:var(--white);color:var(--blue);box-shadow:var(--sh);}
.auth-field{margin-bottom:14px;}
.auth-field label{display:block;font-size:13px;font-weight:600;color:var(--g700);margin-bottom:5px;}
.auth-field input{width:100%;background:var(--white);border:1.5px solid var(--g200);border-radius:8px;color:var(--g900);font-family:var(--font);font-size:14px;padding:10px 14px;outline:none;transition:border-color 0.15s;}
.auth-field input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,69,245,0.1);}
.auth-btn{width:100%;background:var(--blue);color:var(--white);border:none;border-radius:8px;padding:11px;font-size:14px;font-weight:600;cursor:pointer;margin-top:4px;}
.auth-btn:hover{background:var(--blue-dk);}
.auth-err{font-size:13px;color:var(--red);margin-top:8px;display:none;}

/* ── MAIN APP ── */
#app{display:none;}
#app.show{display:block;}

/* ── HEADER ── */
header{background:var(--white);border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;box-shadow:var(--sh);}
.h-logo{height:44px;}
.h-right{display:flex;align-items:center;gap:12px;}
.h-user{font-size:13px;color:var(--g500);}
.h-user strong{color:var(--g900);}
.accent-bar{height:3px;background:linear-gradient(90deg,var(--blue),#6C80FF);}

/* ── LAYOUT ── */
.app-layout{display:flex;min-height:calc(100vh - 67px);}

/* ── SIDEBAR ── */
.sidebar{width:220px;background:var(--white);border-right:1px solid var(--border);padding:16px 12px;flex-shrink:0;position:sticky;top:67px;height:calc(100vh - 67px);overflow-y:auto;}
.sidebar-section{font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;color:var(--g400);padding:6px 8px;margin-bottom:4px;margin-top:12px;}
.sidebar-section:first-child{margin-top:0;}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:8px;font-size:14px;font-weight:500;color:var(--g700);cursor:pointer;transition:all 0.12s;border:none;background:transparent;width:100%;text-align:left;}
.nav-item:hover{background:var(--g100);color:var(--g900);}
.nav-item.active{background:var(--blue-lt);color:var(--blue);font-weight:600;}
.nav-icon{font-size:16px;width:20px;text-align:center;}

/* ── CONTENT ── */
.content{flex:1;padding:28px 24px;overflow-x:hidden;}

/* ── PAGE HEADER ── */
.page-hdr{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:24px;}
.page-title{font-size:24px;font-weight:700;letter-spacing:-0.02em;}
.page-title span{color:var(--blue);}
.page-sub{font-size:14px;color:var(--g500);margin-top:2px;}

/* ── CARDS ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--rlg);padding:22px;box-shadow:var(--sh);margin-bottom:16px;}
.card-title{font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:var(--g400);margin-bottom:16px;}

/* ── STATS ── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:14px;margin-bottom:24px;}
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:18px;box-shadow:var(--sh);}
.stat-num{font-size:34px;font-weight:700;letter-spacing:-0.03em;line-height:1;margin-bottom:4px;}
.stat-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--g500);}
.c-blue{color:var(--blue);}
.c-green{color:var(--green);}
.c-yellow{color:var(--yellow);}
.c-red{color:var(--red);}

/* ── TABLES ── */
.tbl{width:100%;border-collapse:collapse;}
.tbl th{font-size:11px;font-weight:700;letter-spacing:0.07em;text-transform:uppercase;color:var(--g400);text-align:left;padding:0 12px 10px;border-bottom:1.5px solid var(--border);}
.tbl td{padding:12px 12px;border-bottom:1px solid var(--g100);font-size:14px;vertical-align:middle;}
.tbl tr:last-child td{border-bottom:none;}
.tbl tr:hover td{background:var(--g100);}
.tbl-action{background:transparent;border:1.5px solid var(--g200);border-radius:6px;color:var(--g700);font-size:12px;font-weight:600;padding:4px 10px;cursor:pointer;}
.tbl-action:hover{border-color:var(--blue);color:var(--blue);}
.tbl-action.danger:hover{border-color:var(--red);color:var(--red);}

/* ── AVATAR ── */
.avatar{width:32px;height:32px;border-radius:8px;background:var(--blue-lt);color:var(--blue);display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-right:8px;vertical-align:middle;flex-shrink:0;}
.avatar-lg{width:44px;height:44px;border-radius:10px;font-size:16px;}

/* ── BADGES ── */
.badge{font-size:11px;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;padding:3px 9px;border-radius:99px;display:inline-block;}
.badge-complete{background:var(--green-lt);color:var(--green);}
.badge-pending{background:var(--yellow-lt);color:var(--yellow);}
.badge-active{background:var(--blue-lt);color:var(--blue);}
.badge-admin{background:#f3e8ff;color:#7c3aed;}
.badge-overdue{background:var(--red-lt);color:var(--red);}

/* ── PROGRESS ── */
.prog-wrap{background:var(--g200);border-radius:99px;height:6px;overflow:hidden;}
.prog-fill{height:100%;background:var(--blue);border-radius:99px;transition:width 0.4s;}

/* ── BUTTONS ── */
.btn{font-family:var(--font);font-weight:600;font-size:14px;padding:9px 20px;border-radius:8px;border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all 0.15s;}
.btn-primary{background:var(--blue);color:var(--white);border-color:var(--blue);}
.btn-primary:hover{background:var(--blue-dk);}
.btn-secondary{background:var(--white);color:var(--g700);border-color:var(--g200);box-shadow:var(--sh);}
.btn-secondary:hover{border-color:var(--g400);}
.btn-success{background:var(--green);color:var(--white);border-color:var(--green);}
.btn-danger{background:transparent;color:var(--red);border-color:var(--red-lt);}
.btn-danger:hover{background:var(--red-lt);}
.btn-sm{font-size:13px;padding:7px 14px;}
.btn-full{width:100%;justify-content:center;}

/* ── FORMS ── */
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--g700);margin-bottom:5px;}
.field-hint{font-size:12px;color:var(--g400);margin-top:4px;}
input[type=text],input[type=url],input[type=email],input[type=password],textarea,select{width:100%;background:var(--white);border:1.5px solid var(--g200);border-radius:8px;color:var(--g900);font-family:var(--font);font-size:14px;padding:10px 14px;outline:none;transition:border-color 0.15s;}
input:focus,textarea:focus,select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,69,245,0.1);}
textarea{resize:vertical;min-height:90px;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:640px){.grid-2{grid-template-columns:1fr;}}

/* ── MODAL ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(13,14,18,0.5);backdrop-filter:blur(2px);z-index:200;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.open{display:flex;}
.modal{background:var(--white);border-radius:var(--rlg);padding:30px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 20px 60px rgba(0,0,0,0.2);}
.modal-title{font-size:20px;font-weight:700;letter-spacing:-0.02em;margin-bottom:4px;}
.modal-sub{font-size:13px;color:var(--g500);margin-bottom:22px;}
.modal-close{position:absolute;top:18px;right:18px;background:var(--g100);border:none;color:var(--g500);font-size:16px;cursor:pointer;width:30px;height:30px;border-radius:6px;display:flex;align-items:center;justify-content:center;}
.modal-close:hover{background:var(--g200);}
.divider{height:1px;background:var(--border);margin:18px 0;}

/* ── SESSION ITEM ── */
.session-item{background:var(--white);border:1.5px solid var(--border);border-radius:var(--rlg);padding:16px 20px;margin-bottom:10px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:all 0.15s;box-shadow:var(--sh);}
.session-item:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,69,245,0.08);}
.session-code{font-size:13px;font-weight:700;letter-spacing:0.1em;color:var(--blue);background:var(--blue-lt);padding:2px 9px;border-radius:5px;}

/* ── CUSTOMER ITEM ── */
.customer-item{background:var(--white);border:1.5px solid var(--border);border-radius:var(--rlg);padding:16px 20px;margin-bottom:10px;display:flex;align-items:center;gap:14px;box-shadow:var(--sh);transition:all 0.15s;}
.customer-item:hover{border-color:var(--blue);}

/* ── WORKER FLOW ── */
.worker-step{display:none;}
.worker-step.active{display:block;}

/* ── Step tracker ── */
.step-track{display:flex;align-items:flex-start;margin-bottom:24px;width:100%;padding:14px 16px;background:var(--g100);border-radius:12px;}
.step-item{display:flex;flex-direction:column;align-items:center;gap:5px;flex:1;position:relative;}
.step-item-connector{flex:1;height:2px;background:var(--g200);margin-top:13px;align-self:flex-start;}
.step-item-connector.done{background:var(--blue);}
.step-dot{width:28px;height:28px;border-radius:50%;background:var(--g200);border:2px solid var(--g200);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--g400);flex-shrink:0;transition:all 0.2s;}
.step-dot.done{background:var(--blue);border-color:var(--blue);color:var(--white);}
.step-dot.cur{background:var(--white);border-color:var(--blue);color:var(--blue);box-shadow:0 0 0 4px rgba(43,69,245,0.12);}
.step-lbl{font-size:10px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:0.04em;white-space:nowrap;}
.step-lbl.done{color:var(--blue);}
.step-lbl.cur{color:var(--blue);}

/* ── Session info banner ── */
.session-banner{background:linear-gradient(135deg,#1a2fd4 0%,#2B45F5 100%);border-radius:14px;padding:16px 20px;margin-bottom:20px;color:white;display:flex;align-items:center;gap:14px;}
.session-banner-icon{width:40px;height:40px;background:rgba(255,255,255,0.15);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.session-banner-title{font-size:15px;font-weight:700;color:white;line-height:1.3;}
.session-banner-sub{font-size:12px;color:rgba(255,255,255,0.75);margin-top:2px;}
.session-banner-badge{margin-left:auto;background:rgba(255,255,255,0.2);border-radius:99px;padding:4px 10px;font-size:11px;font-weight:700;color:white;white-space:nowrap;flex-shrink:0;}

/* ── Video container ── */
.video-card{background:var(--white);border-radius:16px;box-shadow:0 4px 16px rgba(0,0,0,0.10);overflow:hidden;margin-bottom:16px;border:1px solid var(--border);}
.video-wrap{position:relative;width:100%;overflow:hidden;background:var(--black);padding-bottom:min(56.25%, 55vh);}
.video-wrap iframe,.video-wrap>div[id]{position:absolute;top:0;left:0;width:100%;height:100%;border:none;}
@media(max-width:768px){.video-wrap{padding-bottom:56.25%;}}

/* ── Sticky watch progress footer ── */
#w-sticky-bar{position:fixed;bottom:0;left:0;right:0;z-index:400;background:var(--white);border-top:2px solid var(--border);padding:10px 20px 12px;box-shadow:0 -4px 20px rgba(0,0,0,0.10);display:none;}
#w-sticky-bar.visible{display:block;}
.sticky-bar-inner{max-width:600px;margin:0 auto;}
.sticky-bar-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;}
.sticky-bar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--g500);}
.sticky-bar-pct{font-size:13px;font-weight:700;color:var(--blue);}
.sticky-bar-track{background:var(--g200);border-radius:99px;height:7px;overflow:hidden;margin-bottom:8px;}
.sticky-bar-fill{height:100%;width:0%;background:var(--blue);border-radius:99px;transition:width 0.8s;}
#ws-2 .worker-step-inner{padding-bottom:90px;}
.video-card-footer{padding:12px 16px;border-top:1px solid var(--g100);background:var(--g100);}
.ack-item{display:flex;align-items:flex-start;gap:12px;padding:13px;background:var(--g100);border-radius:8px;margin-bottom:10px;cursor:pointer;border:1.5px solid transparent;transition:border-color 0.15s;}
.ack-item:hover{border-color:var(--blue-mid);}
.ack-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--blue);cursor:pointer;margin-top:2px;}
.ack-item label{font-size:14px;line-height:1.5;cursor:pointer;color:var(--g700);}
.name-btn{width:100%;background:var(--white);border:1.5px solid var(--border);border-radius:10px;color:var(--g900);font-family:var(--font);font-size:14px;padding:13px 16px;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;transition:all 0.15s;box-shadow:var(--sh);}
.name-btn:hover{border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,69,245,0.08);}
.name-btn.completed{opacity:0.5;cursor:not-allowed;background:var(--g100);}
.success-screen{text-align:center;padding:40px 20px;}
.success-icon{width:70px;height:70px;background:var(--green-lt);border:2px solid #86efac;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 22px;}

/* ── QR ── */
.qr-box{background:var(--white);padding:12px;border-radius:8px;display:inline-block;border:1px solid var(--border);}
.link-row{display:flex;align-items:center;gap:8px;background:var(--g100);border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;font-size:12px;color:var(--g700);word-break:break-all;}
.copy-btn{flex-shrink:0;background:var(--white);border:1.5px solid var(--border);border-radius:6px;color:var(--g700);font-size:12px;font-weight:600;padding:4px 10px;cursor:pointer;}
.copy-btn:hover{background:var(--blue-lt);color:var(--blue);border-color:var(--blue-mid);}

/* ── EMPTY ── */
.empty-state{text-align:center;padding:56px 20px;}
.empty-icon{font-size:40px;margin-bottom:12px;opacity:0.35;}

/* ── LOADING ── */
.loading{text-align:center;padding:48px;color:var(--g400);font-size:14px;}
.spinner{display:inline-block;width:24px;height:24px;border:2px solid var(--g200);border-top-color:var(--blue);border-radius:50%;animation:spin 0.7s linear infinite;margin-bottom:12px;}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--g900);color:var(--white);border-radius:10px;padding:12px 18px;font-size:14px;font-weight:500;z-index:9999;transform:translateY(80px);opacity:0;transition:all 0.25s;pointer-events:none;box-shadow:var(--shmd);display:flex;align-items:center;gap:10px;}
.toast.show{transform:translateY(0);opacity:1;}
.toast-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0;}

/* ── WORKER MODE ── */
#worker-mode{display:none;min-height:100vh;}
#worker-mode.show{display:block;}
.worker-header{background:var(--white);border-bottom:1px solid var(--border);height:64px;display:flex;align-items:center;padding:0 24px;box-shadow:var(--sh);}
.worker-header img{height:40px;}
.worker-main{max-width:600px;margin:0 auto;padding:24px 20px;}

/* ── QUIZ ── */
.quiz-option{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--white);border:1.5px solid var(--border);border-radius:10px;margin-bottom:10px;cursor:pointer;font-size:14px;font-weight:500;transition:all 0.15s;text-align:left;width:100%;}
.quiz-option:hover{border-color:var(--blue);background:var(--blue-lt);}
.quiz-option.selected{border-color:var(--blue);background:var(--blue-lt);color:var(--blue);}
.quiz-option.correct{border-color:var(--green);background:var(--green-lt);color:var(--green);}
.quiz-option.incorrect{border-color:var(--red);background:var(--red-lt);color:var(--red);}

/* ── SIGNATURE ── */
#w-sig-canvas{border:2px solid var(--border);border-radius:10px;background:var(--white);cursor:crosshair;touch-action:none;display:block;width:100%;}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .sidebar{display:none;}
  .worker-main{padding:16px 14px;}
  .step-track{padding:10px 12px;}
  .step-lbl{display:none;}
  .session-banner{padding:12px 14px;}
  .session-banner-badge{display:none !important;}
  .sidebar.mobile-open{display:block;position:fixed;top:67px;left:0;height:calc(100vh - 67px);z-index:90;box-shadow:4px 0 24px rgba(0,0,0,0.12);}
  .sidebar-overlay{display:none;position:fixed;inset:0;top:67px;background:rgba(13,14,18,0.35);z-index:89;}
  .sidebar-overlay.show{display:block;}
  .content{padding:16px 14px 90px;}
  header{padding:0 16px;}
  .h-hamburger{display:none !important;}
  .col-hide-mobile{display:none !important;}
  .tbl{font-size:13px;}
  .tbl td, .tbl th{padding:10px 8px;}
  .stat-card{padding:14px 10px;}
  .stat-num{font-size:24px;}
  .session-item{cursor:pointer;transition:background 0.15s,transform 0.1s;-webkit-tap-highlight-color:transparent;}
  .session-item:active{background:var(--g100);transform:scale(0.98);}
  .customer-item{cursor:pointer;transition:background 0.15s;-webkit-tap-highlight-color:transparent;}
  .customer-item:active{background:var(--g50);}

  /* ── BOTTOM TAB BAR ── */
  #mobile-tab-bar{
    display:flex;
    position:fixed;bottom:0;left:0;right:0;
    height:64px;
    background:var(--white);
    border-top:1px solid var(--border);
    z-index:100;
    box-shadow:0 -4px 16px rgba(0,0,0,0.08);
    padding-bottom:env(safe-area-inset-bottom);
  }
  .mob-tab{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:3px;border:none;background:transparent;cursor:pointer;
    color:var(--g400);font-size:10px;font-weight:600;letter-spacing:0.02em;
    padding:8px 4px;transition:color 0.15s;
    -webkit-tap-highlight-color:transparent;
    min-width:0;
  }
  .mob-tab .mob-tab-icon{font-size:20px;line-height:1;transition:transform 0.15s;}
  .mob-tab:active .mob-tab-icon{transform:scale(0.88);}
  .mob-tab.active{color:var(--blue);}
  .mob-tab.active .mob-tab-icon{filter:none;}
  .mob-tab-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:56px;}
}

@media(max-width:480px){
  .worker-header{height:52px;padding:0 14px;}
  .worker-header img{height:28px;}
  .worker-main{padding:12px 12px 24px;max-width:100%;}
  .step-track{padding:8px 10px;gap:0;}
  .step-dot{width:28px;height:28px;font-size:11px;}
  .step-item-connector{height:2px;}
  #w-code{font-size:28px !important;letter-spacing:0.12em !important;padding:14px 10px !important;}
  .btn-full{font-size:15px;padding:14px 16px;min-height:52px;}
  .field input, .field select{font-size:16px !important;padding:13px 12px;min-height:48px;}
  .field label{font-size:13px;margin-bottom:6px;}
  #ws-1-matched .card{padding:20px 16px;}
  #ws-1-matched-name{font-size:20px !important;}
  .session-banner{padding:10px 12px;gap:10px;}
  .session-banner-title{font-size:14px;}
  .session-banner-sub{font-size:12px;}
  #ws-2 .worker-step-inner{padding-bottom:110px;}
  #w-sticky-bar{padding:8px 14px 16px;}
  .sticky-bar-inner{max-width:100%;}
  #w-watched-btn{font-size:16px;padding:14px;min-height:52px;}
  .sticky-bar-pct{font-size:14px;}
  .quiz-option{padding:14px 12px;font-size:14px;min-height:52px;}
  #w-sig-canvas{width:100% !important;height:160px !important;}
  .success-screen{padding:20px 12px;}
  .success-icon{font-size:48px;}
  .success-screen .btn{min-height:52px;font-size:15px;}
  .success-screen > div[style*="flex"]{flex-direction:column;gap:10px;}
  .success-screen .btn{width:100%;}
  .card{padding:16px 14px;}
  #self-enroll-form .grid-2,
  #self-enroll-form [style*="grid-template-columns"]{display:flex !important;flex-direction:column !important;gap:10px !important;}
  .page-title{font-size:20px;}
  .page-sub{font-size:13px;}
}

@media(min-width:769px){
  .h-hamburger{display:none !important;}
  .sidebar-overlay{display:none!important;}
  #mobile-tab-bar{display:none !important;}
}
