/* TurboMate App Styles */

:root{
  --bg:#0d1117;
  --card:#161b27;
  --card2:#1c2333;
  --border:rgba(99,120,180,0.15);
  --accent:#6366f1;
  --accent2:#8b5cf6;
  --green:#10b981;
  --orange:#f97316;
  --purple:#a855f7;
  --red:#ef4444;
  --yellow:#f59e0b;
  --text:#e8edf5;
  --muted:#8892a4;
  --muted2:#4d5a70;
  --glow:rgba(99,102,241,0.15);
  --sidebar-bg:#0d1117;
}
body.light-mode{
  --bg:#f4f6fb;
  --card:#ffffff;
  --card2:#eef1f8;
  --border:#dde3f0;
  --accent:#6366f1;
  --accent2:#8b5cf6;
  --text:#0f172a;
  --muted:#475569;
  --muted2:#94a3b8;
  --glow:rgba(99,102,241,0.08);
}
body.light-mode .bnav{background:#ffffff;border-top:1px solid #dde3f0;box-shadow:0 -4px 20px rgba(59,130,246,0.06);}
body.light-mode .top-nav{background:#f0f4ff;border-bottom:1px solid #dde3f0;}
body.light-mode .job-card{box-shadow:0 2px 8px rgba(0,0,0,0.06);}
body.light-mode .btn-primary{box-shadow:0 4px 14px rgba(59,130,246,0.3);}
body.light-mode .search-wrap{background:#fff;box-shadow:0 2px 8px rgba(0,0,0,0.05);}
body.light-mode .chip{background:#e8edf8;border-color:#dde3f0;color:#475569;}
body.light-mode .chip.active-chip{background:#6366f1;color:#fff;border-color:#6366f1;}
body.light-mode #auth-email,body.light-mode #auth-pass{background:#fff;border-color:#dde3f0;color:#0f172a;}
body.light-mode .form-input,body.light-mode .form-textarea{background:#fff;border-color:#dde3f0;color:#0f172a;}
body.light-mode .mate-fab{box-shadow:0 4px 16px rgba(59,130,246,0.35);}
body.light-mode .act-btn{box-shadow:0 2px 8px rgba(0,0,0,0.06);}
body.light-mode .qa-card{box-shadow:0 2px 8px rgba(0,0,0,0.05);}
body.light-mode .empty-card{background:#fff;}
body.light-mode #theme-toggle{background:#fff;border-color:#dde3f0;}
html.light-mode-pre body{--bg:#f0f4ff;--card:#ffffff;--card2:#e8edf8;--border:#dde3f0;--text:#0f172a;--muted:#475569;--muted2:#94a3b8;}

/* Login page centred on tablet+ */
@media(min-width:768px){
  #page-login:not([style*="display: none"]):not([style*="display:none"]){
    max-width:100vw !important;
    margin-left:0 !important;
    width:100vw !important;
    min-height:100vh !important;
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    position:fixed !important;
    top:0;left:0;right:0;bottom:0;
    z-index:200;
    background:var(--bg) !important;
  }
  #page-login[style*="display: none"],
  #page-login[style*="display:none"]{
    display:none !important;
    position:static !important;
  }
  #page-login > *{width:100%;max-width:440px;}
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
body{background:var(--bg);color:var(--text);font-family:'Inter',sans-serif;min-height:100vh;overflow-x:hidden;}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(ellipse 80% 50% at 20% -10%,rgba(99,102,241,0.08) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(139,92,246,0.06) 0%,transparent 60%);pointer-events:none;z-index:0;}
#app-shell{max-width:430px;margin:0 auto;position:relative;min-height:100vh;}

/* ── TABLET + DESKTOP (768px+) ── */
@media (min-width:768px){
  #app-shell{max-width:100%;margin:0;}
  .bnav{
    position:fixed !important;left:0 !important;top:0 !important;bottom:0 !important;
    transform:none !important;width:240px !important;max-width:240px !important;
    height:100vh !important;flex-direction:column !important;justify-content:flex-start !important;
    align-items:stretch !important;padding:0 12px 24px !important;
    background:rgba(13,17,23,0.97) !important;
    border-right:1px solid rgba(99,120,180,0.12) !important;
    border-top:none !important;gap:2px !important;overflow-y:auto;
    box-shadow:4px 0 32px rgba(0,0,0,0.4);z-index:100;
    backdrop-filter:blur(12px);
  }
  .bnav::before{content:''  !important;display:none !important;}
  .bnav-logo-wrap{display:flex !important;}
  .bni{
    flex-direction:row !important;justify-content:flex-start !important;
    gap:12px !important;padding:10px 14px !important;border-radius:12px !important;
    flex:none !important;width:100% !important;min-height:auto !important;
  }
  .bni:hover{background:var(--card2) !important;}
  .bni-icon{font-size:1.1rem !important;width:22px !important;text-align:center !important;flex-shrink:0 !important;}
  .bni-lbl{font-size:0.88rem !important;letter-spacing:0 !important;text-transform:none !important;color:var(--muted) !important;font-weight:500 !important;}
  .page{margin-left:240px !important;width:calc(100vw - 240px) !important;max-width:none !important;padding-bottom:40px !important;overflow-x:hidden !important;}
  .job-card-wrap{margin-left:28px !important;margin-right:28px !important;overflow:hidden !important;}
  .top-nav{padding:20px 28px 16px !important;}
  .stat-card{margin:0 28px 20px !important;}
  .qa-grid{grid-template-columns:repeat(4,1fr) !important;padding:0 28px 4px !important;gap:12px !important;}
  .act-grid{grid-template-columns:repeat(4,1fr) !important;padding:0 28px !important;gap:12px !important;}
  .sec-hdr{padding:20px 28px 12px !important;}
  .form-group{margin:0 28px 16px !important;}
  .btn-main{width:calc(100% - 56px) !important;margin:0 28px !important;}
  .btn-sub{width:calc(100% - 56px) !important;margin:10px 28px 0 !important;}
  .chips{padding:0 28px 14px !important;}
  .empty-card{margin:0 28px !important;}
  .det-row{padding:14px 28px !important;}
  .search-wrap{margin:14px 28px !important;}
  .cal-grid{padding:0 28px 8px !important;gap:3px !important;}
  .cal-cell{min-height:70px !important;}
  .cal-month-header{padding:12px 28px 8px !important;}
  .cal-view-tabs{padding:14px 28px 10px !important;}
  .fab{right:32px !important;bottom:40px !important;}
  .mate-fab{right:32px !important;bottom:108px !important;}
  #toast{left:calc(240px + ((100vw - 240px) / 2)) !important;transform:translateX(-50%) !important;}
  .mate-panel{left:240px !important;width:calc(100vw - 240px) !important;max-width:none !important;transform:translateY(100%) !important;}
  .mate-panel.open{transform:translateY(0) !important;}
  #h-pending-sync,#h-finance-teaser{margin-left:28px !important;margin-right:28px !important;}
  #mil-trip-list > div,#exp-list > div{margin-left:28px !important;margin-right:28px !important;}
  .stat-big{font-size:3rem !important;}
  .stat-num{font-size:1.5rem !important;}
}
@media (min-width:1024px){
  .bnav{width:260px !important;max-width:260px !important;}
  .page{margin-left:260px !important;width:calc(100vw - 260px) !important;}
  .mate-panel{left:260px !important;width:calc(100vw - 260px) !important;}
  #toast{left:calc(260px + ((100vw - 260px) / 2)) !important;}
  .top-nav{padding:22px 40px 18px !important;}
  .stat-card{margin:0 40px 24px !important;}
  .qa-grid{padding:0 40px 4px !important;}
  .act-grid{padding:0 40px !important;}
  .sec-hdr{padding:22px 40px 14px !important;}
  .job-card-wrap{margin-left:40px !important;margin-right:40px !important;}
  .form-group{margin:0 40px 16px !important;}
  .btn-main{width:calc(100% - 80px) !important;margin:0 40px !important;}
  .btn-sub{width:calc(100% - 80px) !important;margin:10px 40px 0 !important;}
  .chips{padding:0 40px 14px !important;}
  .empty-card{margin:0 40px !important;}
  .det-row{padding:14px 40px !important;}
  .search-wrap{margin:14px 40px !important;}
  .cal-grid{padding:0 40px 8px !important;}
  .cal-cell{min-height:80px !important;}
  .cal-month-header{padding:14px 40px 10px !important;}
  .cal-view-tabs{padding:14px 40px 10px !important;}
  #h-pending-sync,#h-finance-teaser{margin-left:40px !important;margin-right:40px !important;}
  #mil-trip-list > div,#exp-list > div{margin-left:40px !important;margin-right:40px !important;}
  .fab{right:48px !important;} .mate-fab{right:48px !important;}
  .stat-big{font-size:3.2rem !important;}
}

.page{display:none !important;min-height:100vh;padding-bottom:80px;animation:fadeIn 0.2s ease;}
.page.active{display:block !important;}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}
.top-nav{padding:18px 20px 14px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:rgba(13,17,23,0.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:50;border-bottom:1px solid rgba(99,120,180,0.1);}
.nav-back{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:8px 14px;color:var(--text);font-family:'Inter',sans-serif;font-size:0.85rem;font-weight:600;cursor:pointer;}
.nav-title{font-size:1rem;font-weight:700;}
.nav-btn{background:var(--accent);border:none;border-radius:10px;padding:8px 14px;color:#fff;font-family:'Inter',sans-serif;font-size:0.85rem;font-weight:600;cursor:pointer;}
.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:0.68rem;font-weight:700;letter-spacing:0.5px;}
.badge-New{background:rgba(99,102,241,0.15);color:#818cf8;}
.badge-InProgress{background:rgba(249,115,22,0.15);color:#f97316;}
.badge-Complete{background:rgba(34,197,94,0.15);color:#22c55e;}
.badge-Quoted{background:rgba(168,85,247,0.15);color:#a855f7;}
.badge-Won{background:rgba(234,179,8,0.15);color:#eab308;}
.badge-Cancelled{background:rgba(239,68,68,0.15);color:#ef4444;}
.form-group{margin:0 20px 16px;}
.form-label{font-size:0.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:7px;display:block;}
.form-input,.form-textarea{width:100%;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:13px 16px;color:var(--text);font-family:'Inter',sans-serif;font-size:0.95rem;outline:none;}
.form-input:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(99,102,241,0.12);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted2);}
.form-textarea{resize:none;min-height:90px;}
.btn-main{width:calc(100% - 40px);margin:0 20px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:14px;padding:15px;color:#fff;font-family:'Inter',sans-serif;font-size:1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 20px rgba(99,102,241,0.3);transition:opacity 0.2s,transform 0.15s;}
.btn-sub{width:calc(100% - 40px);margin:10px 20px 0;background:var(--card);border:1px solid var(--border);border-radius:14px;padding:13px;color:var(--text);font-family:'Inter',sans-serif;font-size:0.95rem;font-weight:600;cursor:pointer;}
.bnav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:430px;background:rgba(13,17,23,0.95);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top:1px solid rgba(99,120,180,0.12);height:80px;display:flex;align-items:center;justify-content:space-around;padding:0 10px 10px;z-index:100;}
.bni{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:8px 12px;flex:1;border:none;background:none;font-family:'Inter',sans-serif;}
.bni-icon{font-size:1.2rem;}
.bni-lbl{font-size:0.6rem;font-weight:600;color:var(--muted2);text-transform:uppercase;letter-spacing:0.5px;}
.fab{position:fixed;bottom:90px;right:calc(50% - 215px + 20px);width:56px;height:56px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:1.8rem;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(59,130,246,0.45);z-index:98;}
.mate-fab{position:fixed;bottom:158px;right:calc(50% - 215px + 20px);width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;color:#fff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(168,85,247,0.5);z-index:98;}
#toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--card2);border:1px solid var(--border);color:var(--text);padding:11px 20px;border-radius:12px;font-size:0.85rem;opacity:0;transition:all 0.3s;pointer-events:none;z-index:999;font-family:'Inter',sans-serif;white-space:nowrap;}
.search-wrap{margin:14px 20px;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:11px 16px;display:flex;align-items:center;gap:10px;}
.search-wrap input{background:none;border:none;outline:none;color:var(--text);font-family:'Inter',sans-serif;font-size:0.9rem;flex:1;}
.chips{display:flex;gap:8px;padding:0 20px 14px;overflow-x:auto;scrollbar-width:none;}
.chip{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:0.78rem;font-weight:600;color:var(--muted2);cursor:pointer;white-space:nowrap;font-family:'Inter',sans-serif;}
.chip.active{background:rgba(99,102,241,0.15);border-color:var(--accent);color:var(--accent);}
.job-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px 16px;margin:0 20px 10px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:border-color 0.2s,box-shadow 0.2s;}
.job-icon{width:44px;height:44px;border-radius:12px;background:rgba(249,115,22,0.12);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.job-info{flex:1;min-width:0;}
.job-name{font-size:0.92rem;font-weight:700;margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.job-meta{font-size:0.75rem;color:var(--muted2);}
.job-right{text-align:right;flex-shrink:0;}
.job-date{font-size:0.7rem;color:var(--muted2);margin-top:4px;}
.sec-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 10px;}
.sec-title{font-size:1rem;font-weight:700;}
.sec-link{font-size:0.82rem;color:var(--accent);font-weight:600;cursor:pointer;}
.empty-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:24px;margin:0 20px 10px;text-align:center;color:var(--muted2);font-size:0.88rem;}
.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.stat-card{margin:0 20px 18px;background:linear-gradient(135deg,#1a1f3a 0%,#1e2456 40%,#2d1b69 100%);border-radius:20px;padding:22px;border:1px solid rgba(99,102,241,0.2);box-shadow:0 8px 32px rgba(99,102,241,0.15),inset 0 1px 0 rgba(255,255,255,0.05);}
.stat-big{font-size:2.6rem;font-weight:800;color:#fff;letter-spacing:-1px;line-height:1;margin-bottom:4px;}
.stat-row{display:flex;border-top:1px solid rgba(255,255,255,0.1);padding-top:14px;}
.stat-item{flex:1;text-align:center;}
.stat-num{font-size:1.3rem;font-weight:700;color:#fff;display:block;line-height:1;margin-bottom:3px;}
.stat-lbl{font-size:0.66rem;color:rgba(255,255,255,0.5);}
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 20px 4px;}
.qa-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;cursor:pointer;transition:border-color 0.2s,transform 0.15s,box-shadow 0.2s;}
.qa-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:9px;}
.qa-title{font-size:0.88rem;font-weight:700;margin-bottom:2px;}
.qa-desc{font-size:0.7rem;color:var(--muted2);}
.det-row{display:flex;justify-content:space-between;align-items:center;padding:13px 20px;border-bottom:1px solid var(--border);}
.det-lbl{font-size:0.82rem;color:var(--muted2);}
.det-val{font-size:0.88rem;font-weight:600;text-align:right;max-width:55%;}
.act-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 20px;margin-bottom:14px;}
.act-btn{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:14px;display:flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;font-family:'Inter',sans-serif;}
/* MATE */
.mate-panel{position:fixed;bottom:0;left:50%;transform:translateX(-50%) translateY(100%);width:100%;max-width:430px;height:85vh;background:#0d1117;border-radius:24px 24px 0 0;border-top:1px solid #2e2e2e;display:flex;flex-direction:column;z-index:200;transition:transform 0.3s cubic-bezier(0.34,1.4,0.64,1);overflow:hidden;}
.mate-panel.open{transform:translateX(-50%) translateY(0);}
.mate-hdr{padding:14px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #1f2937;flex-shrink:0;}
.mate-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#7c3aed,#a855f7);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;flex-shrink:0;}
.mate-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;scroll-behavior:smooth;}
.mate-msg-u{display:flex;justify-content:flex-end;margin-bottom:10px;}
.mate-msg-b{display:flex;gap:8px;align-items:flex-start;margin-bottom:10px;}
.bubble-u{background:#7c3aed;color:#fff;padding:9px 13px;border-radius:18px 18px 4px 18px;font-size:0.87rem;line-height:1.5;max-width:80%;font-family:'Inter',sans-serif;}
.bubble-b{background:#1f2937;color:#f9fafb;padding:9px 13px;border-radius:18px 18px 18px 4px;font-size:0.87rem;line-height:1.5;max-width:85%;font-family:'Inter',sans-serif;border:1px solid #374151;}
.mate-ft{padding:12px 16px;border-top:1px solid #1f2937;flex-shrink:0;}
.mate-indicator{text-align:center;font-size:0.75rem;color:#6b7280;margin-bottom:8px;min-height:16px;font-family:'Inter',sans-serif;}
.mate-input-row{display:flex;gap:8px;align-items:center;}
.mic-btn{width:42px;height:42px;border-radius:50%;background:#1f2937;border:2px solid #374151;color:#f9fafb;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.2s;}
.mate-input-wrap{flex:1;background:#1f2937;border:1px solid #374151;border-radius:12px;padding:9px 13px;}
.mate-input-wrap input{background:none;border:none;outline:none;color:#f9fafb;font-family:'Inter',sans-serif;font-size:0.88rem;width:100%;}
.send-btn{width:42px;height:42px;border-radius:50%;background:#7c3aed;border:none;color:#fff;font-size:1rem;cursor:pointer;flex-shrink:0;}
.m-dot{width:6px;height:6px;border-radius:50%;background:#7c3aed;animation:mdot 1.2s infinite;display:inline-block;margin:0 2px;}
.m-dot:nth-child(2){animation-delay:0.2s;}
.m-dot:nth-child(3){animation-delay:0.4s;}
@keyframes mdot{0%,60%,100%{transform:translateY(0);}30%{transform:translateY(-5px);}}
@keyframes vpulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(1.3);}}
::-webkit-scrollbar{width:0;}

/* ── CALENDAR STYLES ── */
.cal-view-tabs{display:flex;gap:6px;padding:14px 20px 10px;overflow-x:auto;scrollbar-width:none;}
.cal-tab{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:7px 16px;font-size:0.78rem;font-weight:700;color:var(--muted2);cursor:pointer;white-space:nowrap;font-family:'Inter',sans-serif;}
.cal-tab.active{background:rgba(59,130,246,0.15);border-color:var(--accent);color:var(--accent);}
.cal-month-header{display:flex;align-items:center;justify-content:space-between;padding:10px 20px 6px;}
.cal-nav-btn{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:7px 14px;color:var(--text);font-family:'Inter',sans-serif;font-size:0.9rem;font-weight:700;cursor:pointer;}
.cal-month-title{font-size:1.05rem;font-weight:800;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:0 16px 8px;}
.cal-day-hdr{text-align:center;font-size:0.6rem;font-weight:700;color:var(--muted2);padding:4px 0;text-transform:uppercase;letter-spacing:0.5px;}
.cal-cell{min-height:44px;border-radius:10px;padding:4px 2px 2px;cursor:pointer;position:relative;transition:background 0.15s;}
.cal-cell:hover{background:var(--card2);}
.cal-cell.today .cal-date{background:var(--accent);color:#fff;border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 2px;}
.cal-cell.other-month .cal-date{color:var(--muted2);opacity:0.4;}
.cal-date{font-size:0.72rem;font-weight:700;text-align:center;margin-bottom:2px;}
.cal-dot-row{display:flex;justify-content:center;gap:2px;flex-wrap:wrap;}
.cal-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.cal-event-strip{border-radius:4px;padding:1px 4px;font-size:0.58rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:1px 0;width:100%;cursor:pointer;}
.cal-week-row{display:flex;align-items:stretch;min-height:60px;border-bottom:1px solid var(--border);}
.cal-week-time{width:48px;flex-shrink:0;font-size:0.62rem;color:var(--muted2);padding:4px 6px;text-align:right;font-weight:600;border-right:1px solid var(--border);}
.cal-week-cells{flex:1;display:grid;grid-template-columns:repeat(7,1fr);gap:0;}
.cal-week-cell{border-right:1px solid var(--border);padding:2px;min-height:50px;cursor:pointer;position:relative;}
.cal-week-cell:last-child{border-right:none;}
.cal-week-cell:hover{background:var(--card2);}
.cal-week-event{border-radius:4px;padding:2px 4px;font-size:0.6rem;font-weight:700;margin:1px 0;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;}
.cal-day-slot{border-bottom:1px solid var(--border);padding:4px 20px;min-height:52px;display:flex;gap:8px;align-items:flex-start;cursor:pointer;}
.cal-day-slot:hover{background:var(--card2);}
.cal-day-time{width:48px;font-size:0.7rem;font-weight:700;color:var(--muted2);flex-shrink:0;padding-top:4px;}
.cal-day-content{flex:1;}
.cal-event-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:10px 14px;margin:4px 0;}
.cal-event-card .ev-title{font-size:0.88rem;font-weight:700;}
.cal-event-card .ev-meta{font-size:0.72rem;color:var(--muted2);margin-top:2px;}

/* Event modal */
.ev-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:500;display:flex;align-items:flex-end;justify-content:center;}
.ev-modal{background:var(--card);border-radius:24px 24px 0 0;width:100%;max-width:430px;padding:24px 20px 40px;max-height:92vh;overflow-y:auto;}
.ev-modal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
.ev-modal-title{font-size:1.1rem;font-weight:800;}
.ev-modal-close{background:var(--card2);border:1px solid var(--border);border-radius:10px;padding:6px 12px;color:var(--muted2);font-size:1rem;cursor:pointer;}

/* Reminder settings */
.reminder-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--card2);border-radius:12px;margin-bottom:10px;}
.reminder-toggle{width:44px;height:24px;border-radius:12px;background:var(--border);border:none;cursor:pointer;position:relative;transition:background 0.2s;flex-shrink:0;}
.reminder-toggle.on{background:var(--accent);}
.reminder-toggle::after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;top:3px;left:3px;transition:transform 0.2s;}
.reminder-toggle.on::after{transform:translateX(20px);}

/* ── Enhanced component polish ── */
.job-card:hover{border-color:rgba(99,102,241,0.3);box-shadow:0 4px 20px rgba(99,102,241,0.08);}
.qa-card:hover{border-color:rgba(99,102,241,0.25);transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,0.1);}
.btn-main:hover{opacity:0.9;transform:translateY(-1px);}
.btn-main:active{transform:translateY(0);}
.bni:hover .bni-lbl{color:var(--text)!important;}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;}
/* Sidebar active item glow */
@media(min-width:768px){
  .bni:hover{background:rgba(99,102,241,0.08)!important;}
}
/* Subtle page background texture */
.page{position:relative;}
