*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#eef0f8;--surface:#fff;--surface-2:#f5f6fa;--border:#e4e7f0;--accent:#2563eb;--accent-dim:#eff6ff;--text-1:#0f1117;--text-2:#5b6170;--text-3:#9ea5b3;--red:#ef4444;--green:#22c55e;--radius-sm:12px;--radius-md:16px;--radius-lg:24px;--shadow-sm:0 1px 2px #0f11230a, 0 4px 14px #0f11230d;--shadow-md:0 8px 28px #0f112317, 0 2px 8px #0f11230a}html,body{overscroll-behavior:none;height:100%;overflow:hidden}body{background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5}.gate{z-index:999;background:linear-gradient(145deg,#eef4ff 0%,#e8f0fe 50%,#eff6ff 100%);justify-content:center;align-items:center;padding:32px 24px;display:flex;position:fixed;inset:0}.gate-card{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:340px;box-shadow:var(--shadow-md), 0 0 0 1px #2563eb0f;flex-direction:column;align-items:center;gap:10px;padding:36px 28px 28px;animation:.45s cubic-bezier(.16,1,.3,1) gateIn;display:flex}@keyframes gateIn{0%{opacity:0;transform:translateY(28px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.gate-icon-wrap{background:var(--accent);color:#fff;border-radius:22px;justify-content:center;align-items:center;width:72px;height:72px;margin-bottom:4px;display:flex;box-shadow:0 8px 24px #2563eb66}.gate-title{letter-spacing:-.04em;text-align:center;background:linear-gradient(135deg,#2563eb 0%,#0ea5e9 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.6rem;font-weight:700}.gate-subtitle{color:var(--text-2);text-align:center;margin-bottom:6px;font-size:.875rem;line-height:1.5}.gate-input-wrap{width:100%;margin-top:4px;position:relative}.gate-input{border:1.5px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-1);background:var(--surface-2);text-align:center;letter-spacing:.14em;outline:none;padding:15px 16px;font-family:inherit;font-size:1rem;font-weight:500;transition:border-color .2s,box-shadow .2s,background .2s}.gate-input::placeholder{letter-spacing:0;color:var(--text-3);font-weight:400}.gate-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px #2563eb1f}.gate-input--error{border-color:var(--red);animation:.35s shake;box-shadow:0 0 0 3px #ef44441f}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-7px)}60%{transform:translate(7px)}}.gate-error{color:var(--red);text-align:center;height:18px;font-size:.82rem;font-weight:500}.gate-btn{border-radius:var(--radius-md);cursor:pointer;letter-spacing:-.01em;border:none;width:100%;margin-top:4px;padding:15px;font-family:inherit;font-size:.95rem;font-weight:600;transition:opacity .15s,transform .1s,box-shadow .15s}.gate-btn:active{opacity:.85;transform:scale(.98)}.gate-btn--primary{background:var(--accent);color:#fff;box-shadow:0 4px 14px #2563eb66}.app-header{background:var(--surface);box-shadow:0 1px 0 var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.app-header-user{align-items:center;gap:10px;display:flex}.app-header-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.app-header-label{color:var(--text-1);letter-spacing:-.01em;font-size:.9rem;font-weight:600}.app-header-actions{gap:4px;display:flex}.header-btn{border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-3);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.header-btn:hover{background:var(--surface-2);color:var(--text-1)}.header-btn--spinning svg{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.tab-bar{background:var(--surface);-webkit-backdrop-filter:blur(20px);box-shadow:0 -1px 0 var(--border);padding-bottom:env(safe-area-inset-bottom);flex-shrink:0;display:flex}.tab-btn{cursor:pointer;color:var(--text-3);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px 0 10px;transition:color .2s;display:flex}.tab-btn--active{color:var(--accent)}.tab-icon-wrap{border-radius:99px;justify-content:center;align-items:center;width:40px;height:26px;transition:background .2s;display:flex;position:relative}.tab-badge{color:#fff;border:2px solid var(--surface);background:#ef4444;border-radius:99px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:.58rem;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.tab-btn--active .tab-icon-wrap{background:var(--accent-dim)}.tab-label{letter-spacing:.01em;font-size:.62rem;font-weight:500}.tab-btn--active .tab-label{font-weight:700}.filter-bar{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:0;gap:8px;padding:12px 16px;display:flex;overflow-x:auto}.filter-bar::-webkit-scrollbar{display:none}.filter-pill{border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;white-space:nowrap;box-shadow:var(--shadow-sm);letter-spacing:-.01em;border-radius:999px;flex-shrink:0;padding:6px 16px;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .15s}.filter-pill--active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px #2563eb4d}.filter-pill:not(.filter-pill--active):active{background:var(--surface-2)}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(6px);background:#0f112373;align-items:flex-end;display:flex;position:fixed;inset:0}.modal{background:var(--surface);width:100%;max-height:92vh;padding-bottom:env(safe-area-inset-bottom);border-radius:26px 26px 0 0;animation:.32s cubic-bezier(.16,1,.3,1) slideUp;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal:before{content:"";background:var(--border);border-radius:99px;width:36px;height:4px;margin:12px auto 0;display:block}.modal-header{background:var(--surface);justify-content:space-between;align-items:center;padding:16px 20px 14px;display:flex;position:sticky;top:0}.modal-title{color:var(--text-1);letter-spacing:-.02em;font-size:1.05rem;font-weight:700}.modal-close{background:var(--surface-2);color:var(--text-2);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex}.modal-close:hover{background:var(--border);color:var(--text-1)}.modal-body{flex-direction:column;gap:16px;padding:4px 20px 28px;display:flex}.form-field{flex-direction:column;gap:7px;display:flex}.form-label{color:var(--text-2);letter-spacing:.02em;text-transform:uppercase;font-size:.78rem;font-weight:600}.required{color:var(--red)}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);background:var(--surface-2);outline:none;width:100%;padding:12px 14px;font-family:inherit;font-size:.93rem;font-weight:400;transition:border-color .2s,box-shadow .2s,background .2s}.form-input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}select.form-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239EA5B3' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.assignee-chips{flex-wrap:wrap;gap:6px;display:flex}.assignee-chip{border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;border-radius:999px;padding:5px 13px;font-family:inherit;font-size:.78rem;font-weight:500;transition:all .15s}.assignee-chip--active{background:var(--accent);border-color:var(--accent);color:#fff}.tab-content{max-width:620px;margin:0 auto;padding:0 16px 32px}.tab-header{z-index:10;-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-md);background:#ffffffe0;border:1px solid #2563eb1a;justify-content:space-between;align-items:center;margin:10px -16px 16px;padding:16px 20px;display:flex;position:sticky;top:0;box-shadow:0 2px 16px #2563eb1a,0 1px 4px #0000000a}.tab-title{letter-spacing:-.04em;background:linear-gradient(135deg,#2563eb 0%,#0ea5e9 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.8rem;font-weight:700;line-height:1.1}.tab-subtitle{color:var(--text-3);letter-spacing:0;margin-top:3px;font-size:.8rem;font-weight:400}.fab{background:var(--accent);color:#fff;cursor:pointer;letter-spacing:-.01em;border:none;border-radius:99px;align-items:center;gap:5px;padding:9px 18px;font-family:inherit;font-size:.85rem;font-weight:600;transition:opacity .15s,transform .1s,box-shadow .15s;display:flex;box-shadow:0 4px 12px #2563eb59}.fab:active{opacity:.85;box-shadow:none;transform:scale(.95)}.empty-state{color:var(--text-3);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:80px 20px;display:flex}.empty-icon-svg{opacity:.3;margin-bottom:14px}.empty-state p{color:var(--text-2);letter-spacing:-.01em;font-size:.95rem;font-weight:600}.empty-hint{color:var(--text-3)!important;font-size:.82rem!important;font-weight:400!important}.card-list{flex-direction:column;gap:10px;list-style:none;display:flex}.card{background:var(--surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);align-items:flex-start;gap:12px;padding:16px;transition:box-shadow .2s,transform .15s;display:flex}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card--video{flex-direction:column;gap:10px}.card-main{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.card-row{align-items:center;gap:8px;display:flex}.card-row-space{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.badge{background:var(--accent-dim);color:var(--accent);letter-spacing:.04em;text-transform:uppercase;border-radius:99px;align-items:center;width:fit-content;padding:2px 8px;font-size:.67rem;font-weight:700;display:inline-flex}.file-icon-wrap{flex-shrink:0;align-items:center;display:flex}.card-title{color:var(--text-1);word-break:break-word;letter-spacing:-.01em;font-size:.93rem;font-weight:600;line-height:1.35}.card-desc{color:var(--text-2);font-size:.82rem;line-height:1.5}.card-link{color:var(--accent);word-break:break-all;letter-spacing:-.01em;align-items:center;gap:4px;font-size:.8rem;font-weight:600;text-decoration:none;display:inline-flex}.card-link:hover{text-decoration:underline}.card-date{color:var(--text-3);margin-top:2px;font-size:.71rem;font-weight:500}.card-actions{flex-direction:column;flex-shrink:0;gap:4px;display:flex}.edit-btn,.delete-btn{cursor:pointer;width:30px;height:30px;color:var(--text-3);background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.edit-btn:hover{color:var(--accent);background:var(--accent-dim)}.delete-btn:hover{color:var(--red);background:#fef2f2}.video-thumb{border-radius:var(--radius-sm);cursor:pointer;aspect-ratio:16/9;background:var(--text-1);margin-top:2px;position:relative;overflow:hidden}.video-thumb img{object-fit:cover;width:100%;height:100%;display:block}.video-thumb-placeholder{width:100%;height:100%;color:var(--text-3);justify-content:center;align-items:center;display:flex}.play-overlay{color:#fff;background:#00000047;justify-content:center;align-items:center;transition:background .2s;display:flex;position:absolute;inset:0}.video-thumb:hover .play-overlay{background:#00000073}.video-embed{aspect-ratio:16/9;border-radius:var(--radius-sm);margin-top:2px;position:relative;overflow:hidden}.video-embed iframe{border:none;width:100%;height:100%;position:absolute;inset:0}.unread-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:8px;height:8px}.search-bar{margin-bottom:14px;position:relative}.search-bar svg{color:var(--text-3);pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.search-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text-1);box-sizing:border-box;outline:none;padding:9px 12px 9px 34px;font-family:inherit;font-size:.87rem;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.search-input::placeholder{color:var(--text-3)}.edit-btn:disabled{opacity:.2;cursor:default;pointer-events:none}.submit-btn{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;letter-spacing:-.01em;border:none;width:100%;margin-top:4px;padding:14px;font-family:inherit;font-size:.95rem;font-weight:600;transition:opacity .15s,transform .1s}.submit-btn:disabled{background:var(--border);color:var(--text-3);cursor:not-allowed}.submit-btn:not(:disabled):active{opacity:.8;transform:scale(.99)}.ann-card{align-items:flex-start}.ann-card--pinned{border-left:3px solid var(--accent);background:var(--accent-dim);box-shadow:0 2px 8px #2563eb1a}.ann-top{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.ann-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:99px;padding:2px 9px;font-size:.67rem;font-weight:700}.ann-pin-indicator{color:var(--accent);letter-spacing:.03em;text-transform:uppercase;align-items:center;gap:3px;font-size:.67rem;font-weight:700;display:inline-flex}.ann-message{color:var(--text-1);white-space:pre-wrap;margin-top:2px;font-size:.875rem;line-height:1.6}.ann-actions{flex-direction:column;flex-shrink:0;gap:6px;display:flex}.pin-btn{color:var(--text-3);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;transition:color .15s,background .15s;display:flex}.pin-btn:hover,.pin-btn--active{color:var(--accent);background:var(--accent-dim)}.pin-toggle{color:var(--text-2);cursor:pointer;align-items:center;gap:10px;padding:4px 0;font-size:.88rem;display:flex}.pin-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.sa-input{display:none}.sa-label{background:var(--accent);color:#fff;border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:6px;margin-top:4px;padding:8px 14px;font-family:inherit;font-size:.82rem;font-weight:600;transition:opacity .15s,transform .1s;display:inline-flex}.sa-label:active{opacity:.85;transform:scale(.97)}.sa-label--busy{opacity:.7;cursor:not-allowed}@keyframes sa-spin{to{transform:rotate(360deg)}}.sa-spin{animation:.8s linear infinite sa-spin}.sa-result{border-radius:var(--radius-sm);flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px;padding:8px 12px;font-size:.82rem;font-weight:500;display:flex}.sa-result--success{color:#16a34a;background:#e8f8f0}.sa-result--error{color:var(--red);background:#fff0f0}.sa-filelist{flex-direction:column;gap:2px;display:flex}.sa-retry{cursor:pointer;color:inherit;background:0 0;border:none;margin-left:2px;padding:0;font-family:inherit;font-size:.78rem;font-weight:600;text-decoration:underline}.test-filter-bar{gap:8px;margin-bottom:14px;display:flex}.test-filter-pill{border:1.5px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:999px;padding:6px 16px;font-family:inherit;font-size:.8rem;font-weight:500;transition:all .15s}.test-filter-pill--active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px #2563eb4d}.submit-closed-note{color:var(--text-3);margin-top:4px;font-size:.75rem}.status-badge{letter-spacing:.04em;text-transform:uppercase;cursor:default;border:none;border-radius:99px;padding:3px 10px;font-family:inherit;font-size:.67rem;font-weight:700}button.status-badge{cursor:pointer;transition:opacity .15s}button.status-badge:hover{opacity:.75}.due-date{color:var(--text-2);font-size:.74rem;font-weight:500}.submit-indicator{letter-spacing:.04em;text-transform:uppercase;background:var(--accent-dim);color:var(--accent);border-radius:99px;padding:3px 10px;font-size:.67rem;font-weight:700}.app{background:var(--bg);flex-direction:column;height:100dvh;display:flex;overflow:hidden}.app-main{overscroll-behavior:none;flex:1;overflow-y:auto}
