*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--ink:#F8FBFF;--muted:#A8B7CC;--glass:rgba(11,22,38,0.62);--glass-strong:rgba(12,25,44,0.78);--line:rgba(136,204,255,0.22);--blue:#42C8FF;--blue2:#1E6FFF;--green:#42E8B4;--shadow:0 24px 70px rgba(0,0,0,0.42)}
body{font-family:'Plus Jakarta Sans',sans-serif;background:#020711;min-height:100vh;display:flex;justify-content:center;color:var(--ink);overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;background:radial-gradient(circle at 50% -10%,rgba(53,172,255,0.35),transparent 34%),radial-gradient(circle at 14% 22%,rgba(0,88,180,0.25),transparent 30%),linear-gradient(145deg,#020711 0%,#061524 48%,#020711 100%);pointer-events:none}
.app{width:100%;max-width:440px;min-height:100vh;background:linear-gradient(180deg,rgba(3,9,19,0.96),rgba(7,16,30,0.98));display:flex;flex-direction:column;position:relative;overflow:hidden;box-shadow:0 0 90px rgba(17,128,255,0.2)}
.app::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(100,210,255,0.32) 0 1px,transparent 1.4px),radial-gradient(circle,rgba(255,255,255,0.16) 0 1px,transparent 1.3px);background-size:72px 72px,118px 118px;background-position:0 0,28px 36px;opacity:.34;animation:particleDrift 18s linear infinite;pointer-events:none}
.app::after{content:'';position:absolute;inset:-20%;background:conic-gradient(from 200deg at 50% 30%,transparent,rgba(46,166,255,0.16),transparent 28%,rgba(58,232,180,0.08),transparent 54%);filter:blur(28px);animation:aurora 12s ease-in-out infinite alternate;pointer-events:none}
.nav{background:rgba(3,12,24,0.72);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border-bottom:1px solid rgba(127,201,255,0.16);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;flex-shrink:0}
.nav-logo{display:flex;align-items:center;gap:10px}
.nav-logo-icon,.home-logo-big{position:relative;background:linear-gradient(145deg,rgba(70,201,255,0.95),rgba(13,67,152,0.9));border:1px solid rgba(213,245,255,0.5);box-shadow:0 0 28px rgba(66,200,255,0.46),inset 0 1px 12px rgba(255,255,255,0.25);display:flex;align-items:center;justify-content:center;color:#fff;overflow:hidden}
.nav-logo-icon{width:34px;height:34px;border-radius:10px;font-size:0}
.nav-logo-icon::before,.home-logo-big::before{content:'+';font-size:22px;font-weight:800;line-height:1;text-shadow:0 0 16px rgba(255,255,255,0.9)}
.nav-logo-icon::after,.home-logo-big::after{content:'';position:absolute;width:55%;height:55%;border:1px solid rgba(255,255,255,0.38);border-radius:50%;animation:logoRing 2.8s ease-in-out infinite}
.nav-title{color:#fff;font-size:15px;font-weight:800;letter-spacing:0}
.nav-title span{color:var(--blue);text-shadow:0 0 18px rgba(66,200,255,0.7)}
.nav-sub{color:#8CB9D8;font-size:10px;font-weight:600;margin-top:1px}
.nav-btn{background:rgba(255,255,255,0.08);color:#EAF8FF;font-size:12px;font-weight:700;padding:7px 12px;border-radius:999px;border:1px solid rgba(148,213,255,0.2);cursor:pointer;font-family:inherit;backdrop-filter:blur(12px);transition:all .24s ease}
.nav-btn:hover{border-color:rgba(66,200,255,0.55);box-shadow:0 0 18px rgba(66,200,255,0.18);transform:translateY(-1px)}
.screen{flex:1;overflow-y:auto;padding-bottom:32px;position:relative;z-index:2}
.home-hero{position:relative;z-index:2;padding:68px 24px 26px;text-align:center;color:#fff;min-height:325px;display:flex;flex-direction:column;justify-content:center}
.home-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,30,52,0),rgba(2,7,17,0.62)),radial-gradient(circle at 50% 40%,rgba(66,200,255,0.26),transparent 34%);z-index:-1}
.home-logo-big{width:92px;height:92px;border-radius:26px;margin:0 auto 22px;font-size:0;animation:logoIntro .95s cubic-bezier(.18,.89,.32,1.28) both}
.home-logo-big::before{font-size:52px}
.home-logo-big::after{animation:logoRing 2.8s ease-in-out infinite .6s}
.home-title{font-size:34px;font-weight:800;margin-bottom:8px;line-height:1.02;letter-spacing:0;animation:riseIn .72s ease both .12s}
.home-title span{color:var(--blue);text-shadow:0 0 24px rgba(66,200,255,0.78)}
.home-sub{font-size:13px;color:#A8D9FF;line-height:1.7;animation:riseIn .72s ease both .24s}
.home-cards{position:relative;z-index:2;padding:8px 18px 0;animation:riseIn .78s ease both .32s}
.home-section-label{font-size:10px;font-weight:800;color:#82A4C2;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:12px}
.role-card{position:relative;background:linear-gradient(145deg,rgba(15,32,54,0.82),rgba(7,18,34,0.74));border:1px solid rgba(136,204,255,0.2);border-radius:18px;padding:17px;cursor:pointer;display:flex;align-items:center;gap:14px;margin-bottom:12px;transition:transform .26s ease,border-color .26s ease,box-shadow .26s ease,background .26s ease;box-shadow:0 16px 44px rgba(0,0,0,0.18);backdrop-filter:blur(20px);overflow:hidden}
.role-card::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent,rgba(255,255,255,0.1),transparent);transform:translateX(-130%);transition:transform .75s ease}
.role-card:hover{transform:translateY(-4px) scale(1.01);border-color:rgba(66,200,255,0.68);box-shadow:0 22px 58px rgba(0,0,0,0.34),0 0 34px rgba(66,200,255,0.18)}
.role-card:hover::before{transform:translateX(130%)}
.role-card:active{transform:scale(0.98)}
.role-icon{width:52px;height:52px;border-radius:15px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;border:1px solid rgba(255,255,255,0.18);box-shadow:inset 0 1px 10px rgba(255,255,255,0.12)}
.role-icon.doc{background:linear-gradient(145deg,rgba(59,147,255,0.35),rgba(35,67,128,0.25))}
.role-icon.interp{background:linear-gradient(145deg,rgba(66,232,180,0.28),rgba(17,93,96,0.2))}
.role-icon.admin{background:linear-gradient(145deg,rgba(196,221,255,0.28),rgba(71,92,133,0.2))}
.role-info h3{font-size:15px;font-weight:800;color:#F9FCFF;margin-bottom:4px}
.role-info p{font-size:12px;color:#9FB1C8;line-height:1.45}
.field-group{margin-bottom:14px}
.field-label{font-size:12px;font-weight:800;color:#B9CDE0;display:block;margin-bottom:7px;letter-spacing:0.02em}
.field-input{width:100%;padding:14px 15px;border:1px solid rgba(132,200,255,0.2);border-radius:14px;font-size:15px;font-family:inherit;outline:none;color:#F8FBFF;transition:all 0.2s;background:rgba(5,14,26,0.72);box-shadow:inset 0 1px 0 rgba(255,255,255,0.04)}
.field-input::placeholder{color:#5F7891}
.field-input:focus{border-color:rgba(66,200,255,0.72);box-shadow:0 0 0 4px rgba(66,200,255,0.1),0 0 26px rgba(66,200,255,0.13)}
.dept-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.dept-btn{padding:12px 8px;border:1px solid rgba(132,200,255,0.17);border-radius:12px;background:rgba(8,20,36,0.72);font-family:inherit;font-size:12px;font-weight:700;color:#ADC3D8;cursor:pointer;text-align:center;line-height:1.3;transition:all 0.18s}
.dept-btn:hover{border-color:rgba(66,200,255,0.42);color:#fff}
.dept-btn:active{transform:scale(0.97)}
.dept-btn.sel{border-color:rgba(66,200,255,0.9);background:linear-gradient(135deg,rgba(32,122,255,0.88),rgba(66,200,255,0.52));color:#fff;box-shadow:0 0 24px rgba(66,200,255,0.2)}
.floor-label{font-size:10px;font-weight:800;color:#7190AD;letter-spacing:0.08em;text-transform:uppercase;margin:14px 0 8px;padding-left:2px}
.btn-primary{width:100%;background:linear-gradient(135deg,#117BFF,#42C8FF);color:#fff;border:none;padding:15px;border-radius:14px;font-size:15px;font-weight:800;font-family:inherit;cursor:pointer;transition:all 0.2s;letter-spacing:0;box-shadow:0 18px 38px rgba(22,119,255,0.28),0 0 30px rgba(66,200,255,0.18)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 48px rgba(22,119,255,0.34),0 0 38px rgba(66,200,255,0.24)}
.btn-primary:active{transform:scale(0.98)}
.btn-primary:disabled{background:#334155;cursor:not-allowed;transform:none}
.btn-secondary{width:100%;background:rgba(255,255,255,0.07);color:#BDD2E6;border:1px solid rgba(148,213,255,0.14);padding:13px;border-radius:13px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:8px}
.card-section{padding:18px 18px 0;position:relative;z-index:2;animation:screenIn .34s ease both}
.doc-hero,.interp-hero{position:relative;z-index:2;background:linear-gradient(145deg,rgba(18,73,130,0.92),rgba(5,17,31,0.9));border-bottom:1px solid rgba(125,205,255,0.16);padding:24px 20px 28px;color:#fff;overflow:hidden}
.doc-hero::before,.interp-hero::before{content:'';position:absolute;inset:-40% -20%;background:radial-gradient(circle at 30% 35%,rgba(66,200,255,0.26),transparent 30%),radial-gradient(circle at 78% 22%,rgba(65,232,180,0.16),transparent 26%);animation:slowFloat 8s ease-in-out infinite alternate;z-index:-1}
.interp-hero{background:linear-gradient(145deg,rgba(7,95,82,0.92),rgba(5,17,31,0.94))}
.hero-greeting{font-size:11px;font-weight:700;opacity:0.65;margin-bottom:3px;letter-spacing:0.06em;text-transform:uppercase}
.hero-name{font-size:20px;font-weight:800;margin-bottom:2px}
.hero-dept{font-size:13px;opacity:0.75;margin-bottom:16px}
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.stat-card{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.14);border-radius:14px;padding:12px 14px;backdrop-filter:blur(16px)}
.stat-num{font-size:26px;font-weight:800;line-height:1}
.stat-label{font-size:10px;opacity:0.7;margin-top:4px;font-weight:700;letter-spacing:0.05em;text-transform:uppercase}
.req-card{background:rgba(12,24,41,0.76);border-radius:16px;margin-bottom:12px;overflow:hidden;box-shadow:0 16px 44px rgba(0,0,0,0.22);border:1px solid rgba(132,200,255,0.14);backdrop-filter:blur(18px)}
.req-card-inner{padding:14px 16px}
.req-stripe{height:4px}
.req-stripe.pending{background:#F59E0B}
.req-stripe.assigned{background:#3B82F6}
.req-stripe.onway{background:#8B5CF6}
.req-stripe.arrived{background:#10B981}
.req-stripe.cancelled{background:#E2E8F0}
.req-stripe.completed{background:#42E8B4}
.req-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.req-id{font-size:11px;color:#84A1BC;font-weight:700;letter-spacing:0.03em}
.badge{font-size:10px;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:0.03em}
.badge.pending{background:#FEF3C7;color:#92400E}
.badge.assigned{background:#DBEAFE;color:#1E40AF}
.badge.onway{background:#EDE9FE;color:#5B21B6}
.badge.arrived{background:#D1FAE5;color:#065F46}
.badge.cancelled{background:#263241;color:#94A3B8}
.badge.completed{background:#D1FAE5;color:#065F46}
.req-dept{font-size:16px;font-weight:800;color:#F8FBFF;margin-bottom:4px}
.req-room{font-size:13px;color:#A9B9CA;margin-bottom:8px}
.req-note{font-size:12px;color:#C4D4E4;background:rgba(255,255,255,0.06);border-radius:10px;padding:9px 11px;margin-bottom:10px;line-height:1.5;border-left:3px solid rgba(66,200,255,0.48)}
.req-meta-row{display:flex;align-items:center;justify-content:space-between}
.btn-cancel-req{font-size:11px;color:#EF4444;background:none;border:none;cursor:pointer;font-family:inherit;font-weight:700;padding:0}
.tracker{display:flex;align-items:center;margin:12px 0 6px}
.track-step{flex:1;text-align:center}
.track-dot{width:22px;height:22px;border-radius:50%;margin:0 auto 5px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;border:2px solid rgba(132,200,255,0.18);background:rgba(255,255,255,0.08);color:#5F7891}
.track-dot.done{background:#117BFF;border-color:#42C8FF;color:#fff}
.track-dot.active{background:#4FC3F7;border-color:#4FC3F7;color:#fff}
.track-lbl{font-size:9px;color:#94A3B8;font-weight:600;letter-spacing:0.02em}
.track-line{flex:none;width:20px;height:2px;background:rgba(132,200,255,0.18);margin-bottom:22px}
.track-line.done{background:#42C8FF}
.track-ts{font-size:8px;color:#4FC3F7;font-weight:600;margin-top:3px;min-height:11px;letter-spacing:0.01em}
.btn-accept{width:100%;background:#065F46;color:#fff;border:none;padding:13px;border-radius:11px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:10px}
.btn-complete{width:100%;background:linear-gradient(135deg,#042f2e,#065F46);color:#42E8B4;border:1px solid rgba(66,232,180,0.4);padding:13px;border-radius:11px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:10px;letter-spacing:0.02em}
.btn-onway{width:100%;background:#5B21B6;color:#fff;border:none;padding:13px;border-radius:11px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:10px}
.btn-arrived{width:100%;background:#117BFF;color:#fff;border:none;padding:13px;border-radius:11px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;margin-top:10px}
.avail-bar{display:flex;flex-direction:column;background:rgba(255,255,255,0.1);border-radius:12px;padding:12px 16px;margin-top:14px;gap:10px}
.avail-text{font-size:13px;font-weight:700;color:#fff}
.avail-sub{font-size:11px;color:rgba(255,255,255,0.6);margin-top:2px}
.status-btns{display:flex;gap:7px}
.status-btn{flex:1;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);border-radius:9px;color:rgba(255,255,255,0.4);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;padding:8px 2px;transition:all 0.18s}
.status-btn.s-available{background:rgba(52,211,153,0.15);border-color:rgba(52,211,153,0.5);color:#34D399}
.status-btn.s-break{background:rgba(245,158,11,0.15);border-color:rgba(245,158,11,0.5);color:#F59E0B}
.status-btn.s-offline{background:rgba(100,116,139,0.15);border-color:rgba(100,116,139,0.4);color:#94A3B8}
.admin-interp-card.break{border-color:rgba(245,158,11,0.3)}
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.68);z-index:200;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(10px)}
.modal-sheet{background:linear-gradient(180deg,rgba(13,27,47,0.96),rgba(5,13,25,0.98));border:1px solid rgba(132,200,255,0.22);border-radius:22px 22px 0 0;padding:8px 20px 36px;width:100%;max-width:440px;max-height:85vh;overflow-y:auto;box-shadow:0 -24px 70px rgba(0,0,0,0.44);animation:sheetUp .32s ease both}
.modal-handle{width:40px;height:4px;background:rgba(132,200,255,0.26);border-radius:2px;margin:12px auto 20px}
.modal-title{font-size:19px;font-weight:800;color:#F8FBFF;margin-bottom:6px}
.modal-dept-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(66,200,255,0.12);color:#A8D9FF;border:1px solid rgba(66,200,255,0.24);font-size:12px;font-weight:700;padding:5px 12px;border-radius:20px;margin-bottom:18px}
/* ================= ORBITAL LOGIN HUB ================= */
.hub-screen{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 20px 40px;min-height:100vh;overflow:hidden}
.hub-screen::before{content:'';position:absolute;inset:-30%;background:
  radial-gradient(circle at 50% 50%,rgba(66,200,255,0.18),transparent 36%),
  radial-gradient(circle at 18% 22%,rgba(0,116,255,0.18),transparent 30%),
  radial-gradient(circle at 82% 78%,rgba(66,232,180,0.12),transparent 32%);
  filter:blur(2px);pointer-events:none;animation:hubAura 14s ease-in-out infinite alternate;z-index:0}
.hub-screen::after{content:'';position:absolute;inset:0;background-image:
  radial-gradient(circle,rgba(110,210,255,0.5) 0 1px,transparent 1.4px),
  radial-gradient(circle,rgba(255,255,255,0.18) 0 1px,transparent 1.3px);
  background-size:46px 46px,90px 90px;background-position:0 0,18px 24px;opacity:.32;animation:particleDrift 20s linear infinite;pointer-events:none;z-index:0}
.hub-brand{position:relative;z-index:3;text-align:center;margin-top:18px;animation:riseIn .8s ease both}
.hub-brand-title{font-size:24px;font-weight:800;color:#fff;letter-spacing:.02em}
.hub-brand-title span{color:var(--blue);text-shadow:0 0 22px rgba(66,200,255,.7)}
.hub-brand-sub{font-size:11px;color:#8FB6D6;font-weight:700;letter-spacing:.18em;text-transform:uppercase;margin-top:6px;opacity:.85}
.hub-stage{position:relative;width:min(360px,86vw);aspect-ratio:1/1;margin:32px auto 0;display:flex;align-items:center;justify-content:center;z-index:2}
.hub-ring{position:absolute;inset:0;border-radius:50%;border:1px dashed rgba(132,200,255,.22);box-shadow:inset 0 0 60px rgba(66,200,255,.05);animation:ringSpin 38s linear infinite}
.hub-ring.r2{inset:14%;border-color:rgba(66,232,180,.16);animation-direction:reverse;animation-duration:48s}
.hub-ring.r3{inset:26%;border-color:rgba(132,200,255,.12);animation-duration:60s}
.hub-ring.glow{inset:-6%;border:1px solid rgba(66,200,255,.18);box-shadow:0 0 80px rgba(66,200,255,.18) inset,0 0 60px rgba(66,200,255,.12);animation:ringPulse 4.6s ease-in-out infinite}
.hub-core{position:relative;width:42%;aspect-ratio:1/1;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 25%,rgba(180,235,255,.95),rgba(46,150,255,.85) 36%,rgba(13,55,128,.95) 80%);
  border:1px solid rgba(220,245,255,.6);
  box-shadow:0 0 0 6px rgba(8,18,34,.7),0 0 36px rgba(66,200,255,.6),0 0 72px rgba(46,150,255,.45),inset 0 1px 18px rgba(255,255,255,0.35);
  cursor:pointer;color:#fff;text-align:center;padding:10px;
  transition:transform .35s cubic-bezier(.22,.9,.32,1.4),box-shadow .35s ease,filter .35s ease;
  z-index:5;animation:coreFloat 5s ease-in-out infinite,logoIntro 1s cubic-bezier(.18,.89,.32,1.28) both}
.hub-core::before{content:'+';position:absolute;top:18%;font-size:34px;font-weight:800;text-shadow:0 0 18px rgba(255,255,255,.95);line-height:1}
.hub-core::after{content:'';position:absolute;inset:-14%;border:1.5px solid rgba(255,255,255,.35);border-radius:50%;animation:coreRing 3s ease-in-out infinite}
.hub-core .core-label{font-size:13px;font-weight:800;letter-spacing:.06em;margin-top:18px;line-height:1.15}
.hub-core .core-label small{display:block;font-size:9.5px;font-weight:700;color:#CDEBFF;letter-spacing:.18em;margin-top:4px;opacity:.85}
.hub-core:hover{transform:scale(1.06);box-shadow:0 0 0 6px rgba(8,18,34,.7),0 0 50px rgba(66,200,255,.85),0 0 100px rgba(46,150,255,.6),inset 0 1px 22px rgba(255,255,255,.45)}
.hub-core:active{transform:scale(.96)}
.hub-core.expanded{transform:scale(.78);filter:saturate(1.1) brightness(1.05)}
.hub-tap-hint{position:absolute;bottom:-28px;left:0;right:0;text-align:center;font-size:10px;font-weight:700;color:#9FC4E2;letter-spacing:.18em;text-transform:uppercase;animation:hintPulse 2.6s ease-in-out infinite}
.hub-tap-hint.hidden{opacity:0;pointer-events:none;transition:opacity .3s ease}
.hub-node{position:absolute;width:88px;height:88px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(150deg,rgba(20,42,72,.95),rgba(7,18,36,.95));
  border:1px solid rgba(132,200,255,.3);
  box-shadow:0 14px 40px rgba(0,0,0,.45),0 0 30px rgba(66,200,255,.18),inset 0 1px 12px rgba(255,255,255,.08);
  color:#EAF8FF;text-align:center;cursor:pointer;backdrop-filter:blur(20px);
  transform:translate(-50%,-50%) scale(0);opacity:0;pointer-events:none;
  transition:transform .55s cubic-bezier(.22,.9,.32,1.45),opacity .35s ease,box-shadow .3s ease,border-color .3s ease;
  z-index:4}
.hub-node .node-icon{font-size:26px;line-height:1;margin-bottom:4px;filter:drop-shadow(0 0 12px rgba(66,200,255,.5))}
.hub-node .node-label{font-size:10.5px;font-weight:800;letter-spacing:.04em;line-height:1.1}
.hub-node .node-sub{font-size:8.5px;font-weight:700;color:#9FC4E2;letter-spacing:.06em;margin-top:2px;opacity:.85}
.hub-node:hover{border-color:rgba(66,200,255,.85);box-shadow:0 18px 48px rgba(0,0,0,.5),0 0 44px rgba(66,200,255,.35),inset 0 1px 16px rgba(255,255,255,0.14);transform:translate(-50%,-50%) scale(1.08) !important}
.hub-node:active{transform:translate(-50%,-50%) scale(0.96) !important}
.hub-stage.expanded .hub-node.doc{left:18%;top:25%;transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto;transition-delay:.05s}
.hub-stage.expanded .hub-node.interp{left:82%;top:25%;transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto;transition-delay:.13s}
.hub-stage.expanded .hub-node.admin{left:50%;top:90%;transform:translate(-50%,-50%) scale(1);opacity:1;pointer-events:auto;transition-delay:.21s}
.hub-node{left:50%;top:50%}
.hub-node.doc .node-icon{filter:drop-shadow(0 0 12px rgba(66,200,255,.7))}
.hub-node.doc{border-color:rgba(66,200,255,.35)}
.hub-node.interp{border-color:rgba(66,232,180,.4)}
.hub-node.interp .node-icon{filter:drop-shadow(0 0 12px rgba(66,232,180,.7))}
.hub-node.admin{border-color:rgba(196,221,255,.35)}
.hub-node.admin .node-icon{filter:drop-shadow(0 0 12px rgba(196,221,255,.55))}
.hub-line{position:absolute;height:1px;background:linear-gradient(90deg,transparent,rgba(66,200,255,.4),transparent);transform-origin:left center;opacity:0;transition:opacity .5s ease;pointer-events:none;z-index:1}
.hub-stage.expanded .hub-line{opacity:.8}
.hub-foot{position:relative;z-index:3;margin-top:auto;padding-top:18px;display:flex;align-items:center;justify-content:center;gap:18px;color:#7E9DBC;font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;animation:riseIn .9s ease both .35s}
.hub-foot .dot{width:5px;height:5px;border-radius:50%;background:#42E8B4;box-shadow:0 0 10px #42E8B4;animation:pulse 1.8s infinite}
.hub-foot span{opacity:.85}
@keyframes hubAura{0%{transform:rotate(0deg) scale(1)}100%{transform:rotate(12deg) scale(1.1)}}
@keyframes ringSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes ringPulse{0%,100%{box-shadow:0 0 80px rgba(66,200,255,.18) inset,0 0 60px rgba(66,200,255,.12);transform:scale(1)}50%{box-shadow:0 0 100px rgba(66,200,255,.35) inset,0 0 90px rgba(66,200,255,.22);transform:scale(1.02)}}
@keyframes coreFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes coreRing{0%,100%{transform:scale(.9);opacity:.5}50%{transform:scale(1.18);opacity:.05}}
@keyframes hintPulse{0%,100%{opacity:.55}50%{opacity:1}}
.empty{text-align:center;padding:40px 20px;color:#94A3B8}
.empty-icon{font-size:44px;margin-bottom:14px}
.empty-title{font-size:15px;font-weight:800;color:#C8D8E8;margin-bottom:6px}
.empty-sub{font-size:12px;line-height:1.5}
.pulse{animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}
.new-dot{width:8px;height:8px;background:#EF4444;border-radius:50%;display:inline-block;margin-left:6px;animation:pulse 1.2s infinite;vertical-align:middle}
.sec-header{display:flex;align-items:center;margin-bottom:12px}
.sec-title{font-size:11px;font-weight:800;color:#8BA7C1;letter-spacing:0.08em;text-transform:uppercase}
.tab-row{display:flex;background:rgba(255,255,255,0.06);border:1px solid rgba(132,200,255,0.13);border-radius:14px;padding:3px;margin-bottom:16px}
.tab-item{flex:1;padding:9px;border-radius:11px;border:none;font-family:inherit;font-size:12px;font-weight:800;cursor:pointer;transition:all 0.18s;background:transparent;color:#8BA7C1}
.tab-item.active{background:rgba(66,200,255,0.16);color:#EAF8FF;box-shadow:0 0 22px rgba(66,200,255,0.13)}
.assigned-interp{font-size:12px;color:#1D4ED8;font-weight:600;background:#EFF6FF;padding:6px 10px;border-radius:8px;margin-bottom:8px}
.onway-status{font-size:12px;color:#5B21B6;font-weight:700;margin-bottom:8px}
.arrived-status{font-size:12px;color:#065F46;font-weight:700;margin-bottom:8px}
.job-card{border:2px solid #3B82F6}
.job-card.onway{border-color:#8B5CF6}
@keyframes particleDrift{from{background-position:0 0,28px 36px}to{background-position:72px 144px,146px 272px}}
@keyframes aurora{from{transform:rotate(-8deg) scale(1);opacity:.65}to{transform:rotate(9deg) scale(1.08);opacity:.9}}
@keyframes logoIntro{0%{opacity:0;transform:scale(.68) translateY(18px);filter:blur(10px)}100%{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}}
@keyframes logoRing{0%,100%{transform:scale(.82);opacity:.55}50%{transform:scale(1.28);opacity:.08}}
@keyframes riseIn{from{opacity:0;transform:translateY(18px);filter:blur(8px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}
@keyframes screenIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes slowFloat{from{transform:translate3d(-8px,-6px,0) scale(1)}to{transform:translate3d(8px,10px,0) scale(1.06)}}
@keyframes sheetUp{from{transform:translateY(30px);opacity:.4}to{transform:translateY(0);opacity:1}}
@media (min-width:640px){.app{max-width:680px}.dept-grid{grid-template-columns:repeat(3,1fr)}.stats-row{grid-template-columns:repeat(4,1fr)}.card-section{padding:22px 28px 0}.hub-stage{width:min(420px,80vw)}.modal-overlay{align-items:center}.modal-sheet{border-radius:22px;max-width:500px;max-height:80vh}.install-bar{max-width:680px}}
@media (min-width:1024px){body{align-items:flex-start}.app{max-width:1180px;width:100%}.app:has(.doc-hero),.app:has(.interp-hero){display:grid;grid-template-columns:300px 1fr;grid-template-rows:auto 1fr;grid-template-areas:'nav nav''side main';min-height:100vh}.app:has(.doc-hero) .nav,.app:has(.interp-hero) .nav{grid-area:nav;padding:16px 36px}.doc-hero,.interp-hero{grid-area:side;border-right:1px solid rgba(125,205,255,0.12);border-bottom:none;position:sticky;top:0;min-height:calc(100vh - 65px);align-self:start}.app:has(.doc-hero) .screen,.app:has(.interp-hero) .screen{grid-area:main;overflow-y:auto}.app:has(.doc-hero) .card-section,.app:has(.interp-hero) .card-section{padding:28px 36px 0;max-width:760px}.app:has(.doc-hero) .card-section>div[class='req-card'],.app:has(.doc-hero) .card-section>.req-card,.app:has(.interp-hero) .card-section>.req-card{display:inline-block;width:calc(50% - 8px)}.req-cards-wrap{display:grid;grid-template-columns:1fr 1fr;gap:14px}.nav{padding:16px 36px}.nav-title{font-size:17px}.nav-logo-icon{width:38px;height:38px}.hub-stage{width:min(540px,56vw)}.hub-brand-title{font-size:30px}.hub-core .core-label{font-size:15px}.dept-grid{grid-template-columns:repeat(4,1fr)}.stats-row{grid-template-columns:repeat(4,1fr)}.card-section{padding:28px 36px 0}.modal-overlay{align-items:center}.modal-sheet{border-radius:22px;max-width:520px;max-height:78vh}.install-bar{max-width:1180px}.tab-row{max-width:400px}.btn-primary{font-size:16px}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important}}
.install-bar{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:440px;background:linear-gradient(135deg,rgba(13,27,47,0.97),rgba(5,13,25,0.99));border-top:1px solid rgba(66,200,255,0.28);padding:14px 18px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;z-index:999;backdrop-filter:blur(20px);animation:sheetUp .35s ease both;box-shadow:0 -16px 48px rgba(0,0,0,0.4)}
.install-bar-left{display:flex;align-items:center;gap:12px}
.install-bar-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(145deg,rgba(70,201,255,0.95),rgba(13,67,152,0.9));border:1px solid rgba(213,245,255,0.4);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 0 20px rgba(66,200,255,0.35)}
.install-bar-text{font-size:13px;font-weight:700;color:#F8FBFF;line-height:1.3}
.install-bar-text small{display:block;font-size:11px;color:#84A1BC;font-weight:500;margin-top:2px}
.install-bar-btn{background:linear-gradient(135deg,#117BFF,#42C8FF);color:#fff;border:none;padding:10px 18px;border-radius:12px;font-size:13px;font-weight:800;font-family:inherit;cursor:pointer;white-space:nowrap;box-shadow:0 8px 24px rgba(22,119,255,0.35)}
.install-bar-dismiss{background:none;border:none;color:#5F7891;font-size:20px;cursor:pointer;padding:4px;line-height:1;flex-shrink:0}/* Custom styles for the Search Bar */
.search-box {
    background: rgba(66, 200, 255, 0.08) !important;
    border: 1px solid rgba(66, 200, 255, 0.3) !important;
    margin-bottom: 20px;
    font-weight: 600;
}

.search-box:focus {
    background: rgba(66, 200, 255, 0.15) !important;
    border-color: var(--blue) !important;
    box-shadow: 0 0 20px rgba(66, 200, 255, 0.2);
}

.empty-search {
    text-align: center;
    padding: 30px;
    color: var(--muted);
    font-size: 14px;
    font-style: italic;
    background: rgba(255, 255, 255, 0.03);
    border-radius: 14px;
    border: 1px dashed var(--line);
}

.dept-list-container {
    max-height: 400px;
    overflow-y: auto;
    padding-right: 5px;
}

/* Custom Scrollbar for the list */
.dept-list-container::-webkit-scrollbar {
    width: 4px;
}
.dept-list-container::-webkit-scrollbar-thumb {
    background: var(--line);
    border-radius: 10px;
}

/* ── Notification status bar (interpreter screen) ─────────── */
.notif-status-bar{display:block;width:100%;margin-top:10px;padding:11px 14px;border-radius:11px;font-size:12px;font-weight:700;font-family:inherit;text-align:center;cursor:pointer;border:none;transition:all .2s}
.notif-status-bar.good{background:rgba(66,232,180,0.14);color:#42E8B4;border:1px solid rgba(66,232,180,0.28);cursor:default}
.notif-status-bar.bad{background:rgba(239,68,68,0.12);color:#FCA5A5;border:1px solid rgba(239,68,68,0.28);cursor:default}
.notif-status-bar.btn-enable{background:rgba(245,158,11,0.18);color:#FCD34D;border:1px solid rgba(245,158,11,0.38);animation:hintPulse 2s ease-in-out infinite}
.notif-status-bar.btn-enable:hover{background:rgba(245,158,11,0.28)}

/* ── Admin PIN pad ─────────────────────────────────────────── */
.pin-dots-row{display:flex;justify-content:center;gap:14px;margin-bottom:6px}
.pin-dot{width:18px;height:18px;border-radius:50%;border:2px solid rgba(132,200,255,0.35);background:transparent;transition:all .15s}
.pin-dot.filled{background:var(--blue);border-color:var(--blue);box-shadow:0 0 16px rgba(66,200,255,0.55)}
.pin-dots-row.pin-wrong .pin-dot.filled{background:#EF4444;border-color:#EF4444;box-shadow:0 0 14px rgba(239,68,68,0.5);animation:shake .35s ease}
.pin-error{font-size:12px;color:#EF4444;margin-bottom:6px;font-weight:700}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:240px;margin:18px auto 0}
.pin-row{display:contents}
.pin-key{background:rgba(255,255,255,0.07);border:1px solid rgba(132,200,255,0.2);border-radius:14px;font-size:22px;font-weight:700;color:#F8FBFF;font-family:inherit;cursor:pointer;padding:16px 8px;transition:all .14s;aspect-ratio:1;display:flex;align-items:center;justify-content:center}
.pin-key:hover{background:rgba(66,200,255,0.15);border-color:rgba(66,200,255,0.5)}
.pin-key:active{transform:scale(0.91);background:rgba(66,200,255,0.28)}
.pin-key.ghost{pointer-events:none;background:transparent;border-color:transparent}
.pin-key.back{font-size:18px}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}

/* ── Admin interpreter grid ────────────────────────────────── */
.admin-interp-grid{display:flex;flex-direction:column;gap:7px;margin-bottom:4px}
.admin-interp-card{display:flex;align-items:center;gap:12px;background:rgba(12,24,41,0.76);border:1px solid rgba(132,200,255,0.14);border-radius:13px;padding:11px 14px;backdrop-filter:blur(18px)}
.admin-interp-card.available{border-color:rgba(66,232,180,0.32)}
.admin-interp-card.busy{border-color:rgba(245,158,11,0.3)}
.admin-interp-card.offline{opacity:0.45}
.admin-interp-dot{font-size:16px;flex-shrink:0}
.admin-interp-info{flex:1;min-width:0}
.admin-interp-name{font-size:14px;font-weight:700;color:#F8FBFF}
.admin-interp-id{font-size:11px;color:#84A1BC;margin-top:2px}

/* ── Admin action button ───────────────────────────────────── */
.btn-small-action{margin-left:auto;background:rgba(66,200,255,0.14);color:#42C8FF;border:1px solid rgba(66,200,255,0.32);border-radius:9px;padding:6px 12px;font-size:11px;font-weight:800;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all .18s}
.btn-small-action:hover{background:rgba(66,200,255,0.25);border-color:rgba(66,200,255,0.6)}

/* ── Admin bottom tab bar ──────────────────────────────────── */
.admin-screen{padding-bottom:0}
.admin-bottom-tabs{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:440px;background:rgba(4,11,22,0.97);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top:1px solid rgba(66,200,255,0.14);display:flex;z-index:200;padding-bottom:env(safe-area-inset-bottom,0)}
.admin-btab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:10px 4px 10px;font-family:inherit;font-size:10px;font-weight:700;color:#5A7A99;border:none;background:transparent;cursor:pointer;position:relative;transition:color .18s;letter-spacing:0.01em}
.admin-btab span{font-size:18px;line-height:1}
.admin-btab.active{color:#42C8FF}
.admin-btab.active span{filter:drop-shadow(0 0 6px rgba(66,200,255,0.7))}
.btab-badge{position:absolute;top:6px;right:calc(50% - 18px);background:#EF4444;color:#fff;font-size:9px;font-weight:800;border-radius:999px;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 4px}

/* ── Admin overview stats grid ─────────────────────────────── */
.admin-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:4px}
.admin-stat-box{background:rgba(12,24,41,0.82);border:1px solid rgba(132,200,255,0.14);border-radius:14px;padding:14px 10px;text-align:center;backdrop-filter:blur(18px)}
.admin-stat-box.urgent{border-color:rgba(239,68,68,0.35);background:rgba(60,10,10,0.62)}
.asb-num{font-size:26px;font-weight:800;color:#F8FBFF;line-height:1}
.asb-lbl{font-size:10px;color:#84A1BC;font-weight:700;margin-top:4px;text-transform:uppercase;letter-spacing:0.06em}

/* ── Account list rows ─────────────────────────────────────── */
.acc-list{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.acc-row{display:flex;align-items:center;gap:12px;background:rgba(12,24,41,0.76);border:1px solid rgba(132,200,255,0.14);border-radius:13px;padding:12px 14px;backdrop-filter:blur(18px)}
.acc-info{flex:1;min-width:0}
.acc-name{font-size:14px;font-weight:700;color:#F8FBFF}
.acc-empid{font-size:11px;color:#84A1BC;margin-top:2px;font-family:monospace;letter-spacing:0.04em}
.acc-del-btn{background:rgba(239,68,68,0.12);color:#FCA5A5;border:1px solid rgba(239,68,68,0.28);border-radius:9px;padding:6px 11px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .18s;flex-shrink:0}
.acc-del-btn:hover{background:rgba(239,68,68,0.28);border-color:rgba(239,68,68,0.6)}

/* ── Request age urgency ───────────────────────────────────── */
.req-card.age-warn{border-color:rgba(245,158,11,0.45);box-shadow:0 0 0 1px rgba(245,158,11,0.18)}
.req-card.age-warn .req-stripe.pending{background:linear-gradient(180deg,#F59E0B,#D97706)}
.req-card.age-urgent{border-color:rgba(239,68,68,0.55);box-shadow:0 0 0 1px rgba(239,68,68,0.22)}
.req-card.age-urgent .req-stripe.pending{background:linear-gradient(180deg,#EF4444,#DC2626)}
.req-card.age-urgent .req-id{color:#FCA5A5}

/* ── Reports page ──────────────────────────────────────────── */
.report-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:14px 0}
.report-kpi{background:rgba(12,24,41,0.82);border:1px solid rgba(132,200,255,0.14);border-radius:13px;padding:13px 8px;text-align:center}
.report-kpi-num{font-size:22px;font-weight:800;color:#42C8FF}
.report-kpi-lbl{font-size:10px;color:#84A1BC;font-weight:700;margin-top:3px;text-transform:uppercase;letter-spacing:0.05em}
.fairness-list{margin-bottom:4px}
.fairness-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid rgba(132,200,255,0.07)}
.fairness-name{font-size:12px;color:#ADC3D8;width:130px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fairness-bar-wrap{flex:1;height:8px;background:rgba(255,255,255,0.07);border-radius:4px;overflow:hidden}
.fairness-bar-fill{height:100%;background:linear-gradient(90deg,#117BFF,#42C8FF);border-radius:4px;transition:width 0.4s ease}
.fairness-count{font-size:13px;font-weight:700;color:#F8FBFF;width:22px;text-align:right;flex-shrink:0}
.fairness-warning{background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.3);border-radius:10px;padding:8px 12px;font-size:12px;color:#F59E0B;margin-bottom:10px}
.report-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.report-bar-label{font-size:11px;color:#ADC3D8;font-weight:600;width:110px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.report-bar-track{flex:1;height:8px;background:rgba(132,200,255,0.1);border-radius:99px;overflow:hidden}
.report-bar-fill{height:100%;background:linear-gradient(90deg,#1E6FFF,#42C8FF);border-radius:99px;transition:width .4s ease}
.report-bar-fill.green{background:linear-gradient(90deg,#059669,#42E8B4)}
.report-bar-val{font-size:12px;font-weight:700;color:#F8FBFF;width:24px;text-align:right;flex-shrink:0}
.report-day-chart{display:flex;align-items:flex-end;gap:6px;height:100px;margin:10px 0 4px;padding:0 2px}
.report-day-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px}
.report-day-bar-wrap{flex:1;display:flex;align-items:flex-end;width:100%}
.report-day-bar{width:100%;background:linear-gradient(180deg,#42C8FF,#1E6FFF);border-radius:5px 5px 2px 2px;min-height:8px;transition:height .4s ease}
.report-day-val{font-size:11px;font-weight:700;color:#F8FBFF}
.report-day-lbl{font-size:10px;color:#84A1BC;font-weight:600}

/* ── Shift page ────────────────────────────────────────────── */
.shift-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.shift-row{display:flex;align-items:center;gap:12px;background:rgba(12,24,41,0.76);border:1px solid rgba(132,200,255,0.14);border-radius:13px;padding:12px 14px}
.shift-info{flex:1}
.shift-name{font-size:14px;font-weight:700;color:#F8FBFF}
.shift-id{font-size:11px;color:#84A1BC;margin-top:2px;font-family:monospace}
.shift-on-duty{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.duty-chip{background:rgba(66,232,180,0.14);border:1px solid rgba(66,232,180,0.32);color:#42E8B4;border-radius:99px;padding:4px 12px;font-size:12px;font-weight:700}

/* ── Toast notification ────────────────────────────────────── */
.app-toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%);background:rgba(18,38,62,0.96);color:#42E8B4;border:1px solid rgba(66,232,180,0.38);border-radius:14px;padding:13px 22px;font-size:14px;font-weight:700;font-family:'Plus Jakarta Sans',sans-serif;box-shadow:0 8px 36px rgba(0,0,0,0.44);z-index:9999;white-space:nowrap;animation:toastIn .28s cubic-bezier(.18,.89,.32,1.28) both}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(18px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
/* ── Broadcast form ────────────────────────────────────────── */
.broadcast-form{background:rgba(30,111,255,0.07);border:1px solid rgba(66,200,255,0.18);border-radius:16px;padding:16px;margin-top:6px}

/* ── Broadcast banner (interpreter screen) ─────────────────── */
.broadcast-banner{background:linear-gradient(135deg,rgba(30,111,255,0.92),rgba(14,60,160,0.95));border-bottom:1px solid rgba(66,200,255,0.4);padding:12px 16px;cursor:pointer;animation:bcSlideIn .3s ease both}
@keyframes bcSlideIn{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.broadcast-banner-inner{display:flex;align-items:center;gap:12px}
.broadcast-banner-icon{font-size:22px;flex-shrink:0}
.broadcast-banner-body{flex:1;min-width:0}
.broadcast-banner-title{font-size:14px;font-weight:800;color:#fff;margin-bottom:2px}
.broadcast-banner-msg{font-size:13px;color:rgba(255,255,255,0.85);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.broadcast-banner-close{color:rgba(255,255,255,0.6);font-size:16px;flex-shrink:0;padding:4px}

/* ── Broadcast history rows ─────────────────────────────────── */
.bc-hist-row{background:rgba(12,24,41,0.6);border:1px solid rgba(132,200,255,0.12);border-radius:10px;padding:10px 12px;margin-top:8px}
.bc-hist-title{font-size:13px;font-weight:700;color:#F8FBFF}
.bc-hist-time{font-size:11px;color:#84A1BC;float:right}
.bc-hist-msg{font-size:12px;color:#94A3B8;margin-top:4px}

/* ── Report date row ──────────────────────────────────────────── */
.rpt-date-row{display:flex;gap:10px}
.rpt-date-field{flex:1}

/* ── Report table ─────────────────────────────────────────────── */
.rpt-table{width:100%;border-collapse:collapse;margin-top:14px;font-size:13px;border-radius:12px;overflow:hidden}
.rpt-table th{background:rgba(11,37,69,0.9);color:#A8D9FF;padding:10px 12px;text-align:left;font-size:11px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase}
.rpt-table td{padding:10px 12px;border-bottom:1px solid rgba(132,200,255,0.1);color:#F8FBFF}
.rpt-table tfoot td{border-top:1px solid rgba(132,200,255,0.28);border-bottom:none;font-weight:700;color:#42C8FF;background:rgba(66,200,255,0.06)}
.rpt-table tbody tr:hover td{background:rgba(66,200,255,0.05)}

/* ── Push notification log ────────────────────────────────────── */
.notif-log-list{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.notif-log-row{background:rgba(12,24,41,0.76);border:1px solid rgba(132,200,255,0.14);border-radius:11px;padding:10px 13px}

/* ── Break on break status bar ────────────────────────────────── */
.avail-bar.break-active{background:rgba(245,158,11,0.12);border:1px solid rgba(245,158,11,0.35);flex-direction:row;align-items:center;justify-content:space-between}
.break-countdown{font-size:28px;font-weight:800;color:#FCD34D;letter-spacing:0.04em;line-height:1.1;font-variant-numeric:tabular-nums;text-shadow:0 0 16px rgba(245,158,11,0.5)}
.btn-return-early{background:rgba(66,200,255,0.14);color:#42C8FF;border:1px solid rgba(66,200,255,0.35);border-radius:10px;padding:9px 14px;font-size:12px;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .18s}
.btn-return-early:hover{background:rgba(66,200,255,0.26);border-color:rgba(66,200,255,0.6)}

/* ── Break picker modal ───────────────────────────────────────── */
.break-picker-sheet{padding-bottom:28px}
.break-picker-icon{font-size:40px;text-align:center;margin-bottom:10px;filter:drop-shadow(0 0 16px rgba(245,158,11,0.6))}
.break-dur-row{display:flex;gap:14px;margin-top:8px}
.break-dur-btn{flex:1;background:rgba(245,158,11,0.12);border:1px solid rgba(245,158,11,0.38);border-radius:16px;padding:20px 10px;cursor:pointer;font-family:inherit;text-align:center;transition:all .2s;color:#fff}
.break-dur-btn:hover{background:rgba(245,158,11,0.24);border-color:rgba(245,158,11,0.7);transform:translateY(-2px);box-shadow:0 8px 28px rgba(245,158,11,0.2)}
.break-dur-btn:active{transform:scale(0.97)}
.break-dur-mins{font-size:38px;font-weight:800;color:#FCD34D;line-height:1}
.break-dur-label{font-size:12px;color:rgba(255,255,255,0.55);font-weight:700;margin-top:4px;text-transform:uppercase;letter-spacing:0.06em}

/* ── Doctor card break notice ─────────────────────────────────── */
.interp-on-break{font-size:12px;color:#F59E0B;font-weight:700;background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.28);border-radius:9px;padding:7px 11px;margin-bottom:8px}

/* ── 3-column stats row ───────────────────────────────────────── */
.stats-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}

/* ── Interpreter welcome screen ───────────────────────────────── */
.interp-welcome{position:relative;z-index:2;background:linear-gradient(145deg,rgba(7,95,82,0.92),rgba(5,17,31,0.94));border-bottom:1px solid rgba(66,232,180,0.2);padding:32px 20px 32px;color:#fff;text-align:center;overflow:hidden}
.interp-welcome::before{content:'';position:absolute;inset:-40% -20%;background:radial-gradient(circle at 30% 35%,rgba(66,200,255,0.22),transparent 30%),radial-gradient(circle at 78% 22%,rgba(66,232,180,0.16),transparent 26%);animation:slowFloat 8s ease-in-out infinite alternate;z-index:-1}
.welcome-avatar{font-size:58px;margin-bottom:10px;filter:drop-shadow(0 0 22px rgba(66,232,180,0.55));animation:logoIntro .8s cubic-bezier(.18,.89,.32,1.28) both}
.welcome-greeting{font-size:11px;font-weight:700;opacity:0.6;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:4px}
.welcome-name{font-size:26px;font-weight:800;margin-bottom:4px;letter-spacing:-.01em}
.welcome-empid{display:inline-block;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:99px;padding:3px 13px;font-size:12px;font-weight:700;letter-spacing:0.04em;opacity:0.75;margin-bottom:18px}
.welcome-recent-list{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.welcome-recent-row{display:flex;align-items:center;background:rgba(12,24,41,0.72);border:1px solid rgba(132,200,255,0.14);border-radius:13px;padding:12px 14px;gap:10px;backdrop-filter:blur(18px)}
