@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap");*{box-sizing:border-box;margin:0;padding:0}:root{--teal:#1d9e75;--teal-light:#e1f5ee;--teal-dark:#085041;--teal-glow:rgba(29,158,117,.35);--bg:#f4faf8;--bg-grad-1:#eaf6f1;--bg-grad-2:#f7faf9;--card:#fff;--card-glass:hsla(0,0%,100%,.7);--text:#1a2e28;--muted:#5a7a72;--border:#d0e8e0;--done-bg:#e1f5ee;--done-border:#1d9e75;--shadow-sm:0 1px 2px rgba(8,80,65,.06);--shadow-md:0 8px 24px rgba(8,80,65,.08);--shadow-lg:0 24px 48px rgba(8,80,65,.12);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px}[data-theme=dark]{--bg:#0a1614;--bg-grad-1:#0d1f1b;--bg-grad-2:#0a1614;--card:#112320;--card-glass:rgba(17,35,32,.7);--text:#e6f5ef;--muted:#7fa89d;--border:#1e3833;--done-bg:#173e32;--done-border:#1d9e75;--teal-light:#173e32;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 8px 24px rgba(0,0,0,.4);--shadow-lg:0 24px 48px rgba(0,0,0,.5)}body,html{font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;background:radial-gradient(1200px 600px at 10% -10%,var(--bg-grad-1),transparent 60%),radial-gradient(1000px 500px at 110% 110%,var(--bg-grad-1),transparent 60%),var(--bg);background-attachment:fixed;color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit}input,select,textarea{font-family:inherit;color:inherit}a{color:inherit}::selection{background:var(--teal);color:#fff}.app-shell{max-width:1100px;margin:0 auto;padding:20px 16px 60px}.header{display:flex;align-items:center;gap:14px;padding:18px 22px;background:linear-gradient(135deg,var(--teal-dark) 0,#0a4537 100%);border-radius:var(--radius-lg);margin-bottom:22px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.header:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(159,225,203,.18),transparent 50%);pointer-events:none}.logo-mark{width:48px;height:48px;flex-shrink:0}.header-text,.logo-mark{position:relative;z-index:1}.header-text h1{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.3px}.header-text p{font-size:13px;color:#9fe1cb;margin-top:2px}.header-right{margin-left:auto;display:flex;align-items:center;gap:10px;position:relative;z-index:1}.orbit-badge{background:rgba(15,110,86,.65);border:1px solid var(--teal);border-radius:var(--radius-sm);padding:6px 14px;font-size:12px;color:#9fe1cb;font-family:DM Mono,monospace;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.icon-btn{background:hsla(0,0%,100%,.08);border:1px solid hsla(0,0%,100%,.18);color:#9fe1cb;width:36px;height:36px;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .18s ease}.icon-btn:hover{background:hsla(0,0%,100%,.14);transform:translateY(-1px)}.btn{background:var(--teal);color:#fff;border:none;padding:12px 22px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .18s ease;display:inline-flex;align-items:center;gap:8px;box-shadow:0 4px 14px var(--teal-glow)}.btn:hover{background:#0f6e56;transform:translateY(-1px);box-shadow:0 8px 22px var(--teal-glow)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border);box-shadow:none}.btn-ghost:hover{background:var(--teal-light);border-color:var(--teal);transform:none;box-shadow:none}.btn-danger{background:#c8364c;box-shadow:0 4px 14px rgba(200,54,76,.3)}.btn-danger:hover{background:#a02a3d;box-shadow:0 8px 22px rgba(200,54,76,.35)}.btn-lg{padding:14px 32px;font-size:15px}.input,.select,.textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:var(--radius-md);font-size:14px;outline:none;background:var(--card);color:var(--text);transition:all .18s ease}.input:focus,.select:focus,.textarea:focus{border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-glow)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:20px}.glass{background:var(--card-glass);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.login-wrap{min-height:calc(100vh - 40px);display:flex;align-items:center;justify-content:center;padding:16px}.login-card{width:100%;max-width:460px;padding:36px 32px;text-align:center}.login-card h2{font-size:26px;font-weight:700;color:var(--teal-dark);margin-top:14px}[data-theme=dark] .login-card h2{color:#9fe1cb}.login-card p.lead{color:var(--muted);font-size:14px;line-height:1.6;margin:8px 0 22px}.role-pills{display:flex;gap:8px;justify-content:center;margin-bottom:18px;flex-wrap:wrap}.role-pill{padding:8px 16px;border-radius:99px;border:1.5px solid var(--border);background:transparent;color:var(--muted);font-weight:500;font-size:13px;cursor:pointer;transition:all .18s ease}.role-pill.active{background:var(--teal);border-color:var(--teal);color:#fff;box-shadow:0 4px 14px var(--teal-glow)}.hint{font-family:DM Mono,monospace;font-size:11px;color:var(--muted);margin-top:14px}.progress-bar-wrap{background:var(--border);border-radius:99px;height:10px;margin:12px 0 4px;overflow:hidden;position:relative}.progress-bar{height:10px;background:linear-gradient(90deg,var(--teal) 0,#5dcaa8 100%);border-radius:99px;transition:width .6s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 12px var(--teal-glow)}.progress-label{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);font-family:DM Mono,monospace}.legend{display:flex;gap:12px;flex-wrap:wrap;margin:12px 0 16px}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}.legend-dot{width:10px;height:10px;border-radius:3px}.bingo-banner{position:relative;color:#fff;padding:18px 20px;border-radius:var(--radius-md);text-align:center;font-weight:600;font-size:15px;margin-bottom:14px;overflow:hidden;isolation:isolate}.banner-bingo{background:linear-gradient(135deg,#1d9e75,#5dcaa8 35%,#f5c84c 70%,#ff8a3d);background-size:220% 220%;animation:bannerGradient 3s ease infinite;box-shadow:0 12px 32px rgba(245,200,76,.45),0 4px 12px var(--teal-glow),inset 0 0 0 1px hsla(0,0%,100%,.25);display:flex;flex-direction:column;align-items:center;gap:4px}@keyframes bannerGradient{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.banner-completed{background:linear-gradient(135deg,#ff8a3d,#ffd86b 35%,#5dcaa8 75%,#1d9e75);background-size:220% 220%;animation:bannerGradient 4.5s ease infinite;box-shadow:0 16px 40px rgba(255,138,61,.4),0 4px 14px var(--teal-glow),inset 0 0 0 1px hsla(0,0%,100%,.25)}.banner-letters{display:inline-flex;gap:2px;font-size:28px;font-weight:800;letter-spacing:.04em;text-shadow:0 2px 8px rgba(0,0,0,.18)}.banner-letters>span{display:inline-block}.banner-sub{font-size:13px;font-weight:500;opacity:.94;letter-spacing:.02em}.banner-shine{position:absolute;inset:0;background:linear-gradient(100deg,transparent 30%,hsla(0,0%,100%,.55) 50%,transparent 70%);transform:translateX(-100%);animation:bannerShine 2.4s ease-in-out infinite;pointer-events:none;z-index:0}.bingo-banner>*{position:relative;z-index:1}@keyframes bannerShine{0%{transform:translateX(-100%)}60%{transform:translateX(100%)}to{transform:translateX(100%)}}.nudge{background:var(--teal-light);color:var(--teal-dark);padding:10px 16px;border-radius:var(--radius-md);text-align:center;font-size:13px;margin-bottom:14px;border:1px dashed var(--teal)}[data-theme=dark] .nudge{color:#9fe1cb}.bingo-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:10px;gap:10px;margin-bottom:18px}.tile{background:var(--card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:12px 8px;cursor:pointer;text-align:center;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;position:relative;overflow:hidden}.tile:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 0,var(--teal-glow),transparent 60%);opacity:0;transition:opacity .2s ease;pointer-events:none}.tile:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-md)}.tile:hover:before{opacity:.4}.tile.done{background:var(--done-bg);border-color:var(--done-border);box-shadow:0 4px 16px var(--teal-glow)}.tile.bingo-line{background:linear-gradient(135deg,#fff8d8 0,#d4f5e7 60%,var(--done-bg) 100%);border-color:#f5c84c;animation:pulseGlow 1.8s ease-in-out infinite alternate}.tile.bingo-line .tile-text{color:#5b3a00;font-weight:600}[data-theme=dark] .tile.bingo-line{background:linear-gradient(135deg,#3a2c10,#1f5040 60%,#173e32);border-color:#f5c84c}[data-theme=dark] .tile.bingo-line .tile-text{color:#ffe6a8}@keyframes pulseGlow{0%{box-shadow:0 0 0 rgba(245,200,76,0),0 0 0 var(--teal-glow)}to{box-shadow:0 0 22px rgba(245,200,76,.55),0 0 32px var(--teal-glow)}}.tile.bingo-flash{animation:bingoFlash 1.2s ease-out}@keyframes bingoFlash{0%{box-shadow:0 0 0 0 rgba(245,200,76,.9);transform:scale(1)}35%{box-shadow:0 0 32px 12px rgba(245,200,76,.85),0 0 48px 4px var(--teal-glow);transform:scale(1.06)}70%{box-shadow:0 0 24px 4px rgba(245,200,76,.4);transform:scale(1.02)}to{box-shadow:0 0 0 0 rgba(245,200,76,0);transform:scale(1)}}.tile.locked{opacity:.6;cursor:not-allowed}.tile-editable{cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.tile-editable:active{cursor:-webkit-grabbing;cursor:grabbing}.tile-editable:hover{border-color:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-md)}.drag-handle{position:absolute;bottom:6px;left:7px;font-size:12px;color:var(--muted);opacity:.45;letter-spacing:-2px;font-family:DM Mono,monospace;pointer-events:none}.tile-editable:hover .drag-handle{opacity:.85;color:var(--teal)}.tile-edit-btn{position:absolute;bottom:5px;right:6px;width:22px;height:22px;border-radius:6px;border:1px solid var(--border);background:var(--card);color:var(--muted);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;opacity:0}.tile-editable:hover .tile-edit-btn{opacity:1}.tile-edit-btn:hover{background:var(--teal);color:#fff;border-color:var(--teal);transform:scale(1.08)}.dragging-overlay{cursor:-webkit-grabbing!important;cursor:grabbing!important;transform:rotate(3deg) scale(1.06);box-shadow:0 24px 60px rgba(8,80,65,.35),0 0 0 2px var(--teal);background:var(--card);z-index:999}.tile-icon{font-size:22px;line-height:1}.tile-text{font-size:11px;font-weight:500;color:var(--text);line-height:1.4}.tile.done .tile-text{color:var(--teal-dark)}[data-theme=dark] .tile.done .tile-text{color:#9fe1cb}.tile-check{position:absolute;top:6px;right:7px;width:18px;height:18px;background:var(--teal);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px var(--teal-glow)}.tile-check svg{width:10px;height:10px;stroke:#fff;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.tile-tag{position:absolute;top:6px;left:6px;font-size:8.5px;padding:2px 6px;border-radius:5px;font-family:DM Mono,monospace;font-weight:500;letter-spacing:.3px}.tag-30{background:#e1f5ee;color:#085041}.tag-60{background:#dbeeff;color:#0c447c}.tag-90{background:#faeeda;color:#633806}.tag-culture{background:#fbeaf0;color:#72243e}[data-theme=dark] .tag-30{background:#173e32;color:#9fe1cb}[data-theme=dark] .tag-60{background:#163348;color:#a8d3ff}[data-theme=dark] .tag-90{background:#3a2c10;color:#f0c891}[data-theme=dark] .tag-culture{background:#3a1f29;color:#f5b6cb}.toast{position:fixed;top:22px;right:22px;background:var(--teal-dark);color:#fff;padding:10px 18px;border-radius:10px;font-size:13px;font-weight:500;pointer-events:none;z-index:100;box-shadow:var(--shadow-lg)}.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:16px;gap:16px}.emp-card{padding:18px;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;position:relative;overflow:hidden}.emp-card:hover{transform:translateY(-3px);border-color:var(--teal);box-shadow:var(--shadow-lg)}.emp-row{gap:12px;margin-bottom:12px}.avatar,.emp-row{display:flex;align-items:center}.avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--teal) 0,var(--teal-dark) 100%);color:#fff;font-weight:700;font-size:15px;justify-content:center;box-shadow:0 4px 12px var(--teal-glow)}.emp-name{font-weight:600;font-size:15px}.emp-id{font-family:DM Mono,monospace}.emp-id,.emp-stats{font-size:11px;color:var(--muted)}.emp-stats{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}.stat-chip{background:var(--teal-light);color:var(--teal-dark);padding:3px 8px;border-radius:99px;font-family:DM Mono,monospace;font-weight:500}[data-theme=dark] .stat-chip{color:#9fe1cb}.stat-chip.warn{background:#faeeda;color:#633806}.stat-chip.fire{background:linear-gradient(135deg,#ffd86b,#ff8a3d);color:#4a1f00}.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:18px 0 10px}.tabs{display:flex;gap:4px;padding:4px;background:var(--border);border-radius:12px;margin-bottom:18px;width:-moz-fit-content;width:fit-content}.tab{padding:8px 16px;border:none;background:transparent;border-radius:8px;font-weight:500;font-size:13px;color:var(--muted);cursor:pointer;transition:all .18s ease}.tab.active{background:var(--card);color:var(--text);box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;inset:0;background:rgba(8,30,25,.55);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;padding:16px}.modal{background:var(--card);border-radius:var(--radius-lg);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;padding:24px;box-shadow:var(--shadow-lg)}.modal h3{margin-bottom:14px;font-size:18px;font-weight:700}.field{margin-bottom:12px}.field label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.06em}.row{display:flex;gap:8px;flex-wrap:wrap}.minigrid{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:4px;gap:4px;margin-top:10px}.minicell{aspect-ratio:1;border-radius:4px;background:var(--border)}.minicell.done{background:var(--teal);box-shadow:0 0 6px var(--teal-glow)}.minicell.bingo{background:linear-gradient(135deg,#ffd86b,#ff8a3d)}.customizer-subnav{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.customizer-subbtn{padding:7px 16px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--card);color:var(--muted);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.customizer-subbtn:hover{border-color:var(--teal);color:var(--teal)}.customizer-subbtn.active{background:var(--teal);border-color:var(--teal);color:#fff;font-weight:600}.customizer-hint{color:var(--muted);font-size:13px;margin-bottom:18px}.customizer-fields{display:flex;flex-direction:column;gap:14px}.customizer-field{display:flex;flex-direction:column;gap:6px}.customizer-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.customizer-textarea{resize:vertical;min-height:60px}.customizer-color-row{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;padding:12px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md)}.customizer-color-desc{font-size:12px;color:var(--muted);margin-top:2px}.customizer-color-inputs{display:flex;gap:10px;align-items:center}.customizer-colorpicker{width:44px;height:38px;border:2px solid var(--border);border-radius:var(--radius-sm);padding:2px;cursor:pointer;background:none}.customizer-hex{width:100px;font-family:DM Mono,monospace;font-size:13px}.customizer-preview-palette{display:flex;gap:16px;margin-top:20px;padding:14px 18px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;flex-wrap:wrap}.customizer-swatch-wrap{display:flex;flex-direction:column;align-items:center;gap:6px}.customizer-swatch{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);box-shadow:var(--shadow-sm)}.customizer-swatch-label{font-size:11px;color:var(--muted)}.customizer-add-tile{margin-bottom:18px;padding:16px 18px}.customizer-add-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.customizer-icon-input{width:60px;text-align:center;font-size:18px}.customizer-tag-select{width:90px}.customizer-tile-list{display:flex;flex-direction:column;gap:6px}.customizer-tile-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-md);transition:background .15s}.customizer-tile-row:hover{background:var(--teal-light)}.customizer-tile-icon{font-size:20px;flex-shrink:0}.customizer-tile-text{flex:1 1;font-size:13px;color:var(--text)}.customizer-delete-btn{background:none;border:none;cursor:pointer;font-size:16px;opacity:.45;padding:4px 6px;border-radius:6px;transition:opacity .15s,background .15s}.customizer-delete-btn:hover{opacity:1;background:rgba(220,60,60,.1)}.customizer-publish-bar{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--teal-dark),#0a4537);border:1px solid var(--teal);border-radius:var(--radius-lg);padding:12px 20px;box-shadow:0 8px 32px rgba(8,80,65,.35);z-index:200;white-space:nowrap}.customizer-publish-hint{color:hsla(0,0%,100%,.75);font-size:13px}@media (max-width:600px){.bingo-grid{gap:6px}.tile{min-height:78px;padding:8px 4px}.tile-text{font-size:9.5px}.tile-icon{font-size:16px}.header{padding:14px 16px}.header-text h1{font-size:18px}.header-text p{font-size:12px}}