@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Syncopate:wght@400;700&display=swap";:root{--bg: radial-gradient(circle at 18% 18%, rgba(59, 130, 246, .16) 0%, transparent 26%), radial-gradient(circle at 82% 22%, rgba(34, 211, 238, .12) 0%, transparent 24%), radial-gradient(circle at 58% 72%, rgba(37, 99, 235, .14) 0%, transparent 30%), linear-gradient(140deg, #0a0f16 0%, #090d14 45%, #06090f 100%);--bg-2: #141821;--panel: #1a1f26;--panel-2: #151a20;--card: #1f252d;--border: #2b323c;--border-soft: rgba(148, 163, 184, .18);--text: #e5e7eb;--muted: #94a3b8;--accent: #3b82f6;--accent-strong: #2563eb;--accent-soft: rgba(59, 130, 246, .2);--success: #22c55e;--danger: #ef4444;--badge-bg: rgba(234, 179, 8, .22);--badge-text: #fbbf24}body.theme-light{--bg: radial-gradient(circle at 14% 16%, rgba(96, 165, 250, .18) 0%, transparent 24%), radial-gradient(circle at 84% 18%, rgba(34, 211, 238, .14) 0%, transparent 22%), radial-gradient(circle at 52% 82%, rgba(147, 197, 253, .22) 0%, transparent 28%), linear-gradient(145deg, #f8fbff 0%, #eef4fb 48%, #e8eff8 100%);--bg-2: #eef2f7;--panel: #ffffff;--panel-2: #f8fafc;--card: #ffffff;--border: #e2e8f0;--border-soft: rgba(148, 163, 184, .35);--text: #0f172a;--muted: #64748b;--accent: #2563eb;--accent-strong: #1d4ed8;--accent-soft: rgba(37, 99, 235, .15);--success: #16a34a;--danger: #dc2626;--badge-bg: rgba(234, 179, 8, .25);--badge-text: #a16207}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:Manrope,SF Pro Text,system-ui,sans-serif;color:var(--text);background:var(--bg);background-size:160% 160%,145% 145%,180% 180%,100% 100%;background-position:0% 0%,100% 0%,50% 100%,0% 0%;animation:body-gradient-flow 22s ease-in-out infinite alternate;color-scheme:dark}body.theme-light{color-scheme:light}@keyframes body-gradient-flow{0%{background-position:0% 0%,100% 0%,50% 100%,0% 0%}50%{background-position:22% 16%,78% 12%,44% 86%,0% 0%}to{background-position:14% 28%,92% 26%,58% 72%,0% 0%}}button{font:inherit}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--panel-2);border-right:1px solid var(--border);padding:20px 16px;display:flex;flex-direction:column;gap:18px;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:hidden}.brand{display:flex;align-items:center;gap:12px;background:transparent;border:none;padding:0;text-align:left;cursor:pointer}.brand-badge{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg,#1d4ed8,#22d3ee);display:grid;place-items:center;font-weight:700;color:#0f172a}.brand-title{font-weight:700;font-size:1.05rem;color:var(--text)}.search .input{background:var(--bg-2)}.side-nav{display:flex;flex-direction:column;gap:8px}.side-nav button{display:flex;justify-content:flex-start;align-items:center;width:100%;background:transparent;border:1px solid transparent;color:var(--text);padding:10px 44px 10px 12px;border-radius:12px;cursor:pointer;text-align:left;position:relative;gap:10px}.side-nav button.active{background:#3b82f626;border-color:#3b82f666}.badge{background:var(--badge-bg);color:var(--badge-text);padding:2px 8px;border-radius:999px;font-size:.75rem}.side-nav button .badge{position:absolute;right:10px;top:50%;transform:translateY(-50%)}.side-section{display:flex;flex-direction:column;gap:8px}.side-title{display:flex;align-items:center;gap:8px;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.side-item{padding:8px 10px;border-radius:10px;background:#94a3b80f}.sidebar-footer{margin-top:auto;display:flex;flex-direction:column;gap:12px;position:sticky;bottom:0;padding-top:10px;background:linear-gradient(180deg,rgba(15,17,21,0) 0%,var(--panel-2) 32%);z-index:2}.user-chip{display:flex;align-items:center;gap:10px}.user-avatar{width:36px;height:36px;border-radius:12px;background:#3b82f633;display:grid;place-items:center;font-weight:600}.user-name{font-weight:600}.main{display:flex;flex-direction:column;gap:16px;padding:20px 28px 32px}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:16px 18px;border-radius:16px;background:var(--panel);border:1px solid var(--border)}.topbar h1{margin:6px 0 0;font-size:1.4rem}.breadcrumbs{color:var(--muted);font-size:.85rem}.topbar-actions{display:flex;align-items:center;gap:10px}.status-pill{background:#22c55e26;color:#86efac;padding:6px 10px;border-radius:999px;font-size:.8rem}.notice{background:#eab30826;border:1px solid rgba(234,179,8,.4);padding:10px 14px;border-radius:12px;color:#fbbf24}.workspace{display:grid;grid-template-columns:360px 1fr;gap:20px}.workspace.workspace-requests{grid-template-columns:1fr}.workspace.workspace-requests .task-panel{max-height:none}.task-panel{background:var(--panel);border-radius:16px;border:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 180px)}.detail-panel{display:flex;flex-direction:column;gap:16px}.panel-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.panel-title-text{font-weight:700}.task-list{display:flex;flex-direction:column;gap:8px;overflow:auto}.task-list.task-list-horizontal{flex-direction:column;gap:12px;overflow:auto;padding-bottom:0}.inbox-card{flex:1 1 auto;width:100%;max-width:100%;background:var(--panel-2);border:1px solid transparent;border-radius:18px;padding:14px 14px 12px;cursor:pointer;color:inherit;text-align:left;display:flex;flex-direction:column;gap:10px;transition:border-color .16s ease,transform .16s ease}.inbox-card:hover{border-color:#3b82f666;transform:translateY(-1px)}.inbox-row{display:grid;grid-template-columns:84px minmax(0,1fr) minmax(200px,280px);gap:12px;align-items:start}.inbox-row-id{font-weight:700;letter-spacing:.02em;color:var(--muted);display:inline-flex;align-items:center;gap:10px}.inbox-row-title{font-weight:800;font-size:1.1rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inbox-row-owner{text-align:right;color:var(--text);font-weight:600;white-space:normal;word-break:break-word}.inbox-row-meta{display:flex;align-items:center;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:.9rem}@media(max-width:520px){.inbox-row{grid-template-columns:70px minmax(0,1fr);grid-template-rows:auto auto;align-items:start}.inbox-row-owner{grid-column:1 / -1;text-align:left;opacity:.85}.inbox-row-title{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}.task-row{position:relative;display:grid;grid-template-columns:72px 1fr 190px;gap:12px;text-align:left;background:var(--panel-2);border:1px solid transparent;padding:10px 12px;border-radius:12px;cursor:pointer;color:inherit}.task-row>*{min-width:0}.task-row.active{border-color:#3b82f680;background:#3b82f61f}.task-row-left{display:flex;flex-direction:column;gap:6px}.task-id{font-size:.85rem;color:var(--muted)}.task-badge{background:#22c55e26;color:#86efac;padding:2px 8px;border-radius:999px;font-size:.75rem;display:inline-flex;width:fit-content}.task-row-main{display:flex;flex-direction:column;gap:4px;min-width:0}.task-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-row-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px;color:var(--muted);font-size:.8rem;min-width:0}.task-owner{color:var(--text);font-weight:500;text-align:right;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.card{background:var(--panel);border-radius:16px;border:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:12px}.card h2{margin:0;font-size:1.1rem}.card p{margin:0;color:var(--muted)}.card-dark{background:var(--card)}.task-card{position:relative;padding-top:58px}.task-top-right{position:absolute;top:10px;right:10px;display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end;max-width:calc(100% - 20px)}.detail-header{display:flex;flex-direction:column;gap:12px}.detail-title{color:var(--muted);font-size:.85rem}.detail-actions{display:flex;gap:8px;flex-wrap:wrap}.task-top-btn{border:1px solid rgba(148,163,184,.2);background:#0f1319b3;color:var(--text);border-radius:8px;padding:6px 10px;cursor:pointer}.task-top-btn.danger{border-color:#f8717173;color:#f87171}.form-grid{display:grid;gap:10px}.input,.select,.textarea{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border-soft);background:var(--bg-2);color:var(--text);font:inherit}.input-dark{background:var(--panel-2)}.textarea{resize:vertical}.actions{display:flex;gap:8px;flex-wrap:wrap}.primary{background:var(--accent);color:#fff;border:none;padding:10px 14px;border-radius:10px;cursor:pointer}.primary:hover{background:var(--accent-strong)}.ghost{background:transparent;border:1px solid var(--border-soft);padding:8px 12px;border-radius:10px;cursor:pointer;color:inherit}.full{width:100%}.upload{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:10px;border:1px dashed var(--border-soft);cursor:pointer}.upload.upload-icon{padding:8px;gap:0}.upload.upload-icon svg{display:block}.upload input{display:none}.attachment-list{display:flex;flex-direction:column;gap:10px}.attachment-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;background:#94a3b814;padding:10px 12px;border-radius:12px}.attachment-info{min-width:0}.attachment-info.attachment-info-with-thumb{display:flex;align-items:center;gap:10px}.attachment-text{min-width:0;overflow:hidden}.attachment-thumb{width:78px;height:54px;border-radius:12px;border:1px solid rgba(148,163,184,.22);background:#94a3b814;padding:0;overflow:hidden;cursor:pointer;flex:0 0 auto}.attachment-thumb img{width:100%;height:100%;object-fit:cover;display:block}.attachment-actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-end;align-items:flex-end}.hidden-file-input{display:none}@media(max-width:520px){.attachment-row{grid-template-columns:1fr}.attachment-actions{align-items:flex-start;flex-direction:row;flex-wrap:wrap}}.announcement-attachments .attachment-row{grid-template-columns:1fr}.announcement-attachments .attachment-info-with-thumb{flex-direction:column;align-items:stretch}.announcement-attachments .attachment-thumb{width:100%;height:auto;aspect-ratio:16 / 9}.announcement-attachments .attachment-thumb img{height:100%}.announcement-attachments .attachment-actions{flex-direction:row;flex-wrap:wrap;justify-content:flex-end;align-items:center}.ai-approval{margin:12px 0 16px;padding:12px;border-radius:16px;border:1px solid rgba(148,163,184,.18);background:#3b82f614;display:grid;gap:10px}.ai-approval-header{font-weight:600}.ai-approval-list{margin:0;padding-left:18px;display:grid;gap:4px}.ai-approval-actions{display:flex;gap:10px;flex-wrap:wrap}.ai-compare-list{display:grid;gap:8px}.ai-compare-row{display:grid;grid-template-columns:auto minmax(0,1fr) 110px 90px auto auto;gap:8px;align-items:center;padding:8px;border-radius:12px;background:#0f172a59;border:1px solid transparent}.ai-compare-row.match{border-color:#22c55e59}.ai-compare-row.partial{border-color:#f59e0b66}.ai-compare-row.missing{border-color:#ef444459}.ai-compare-check input{width:16px;height:16px}.ai-compare-meta{display:flex;flex-direction:column;gap:4px;font-size:.75rem}.ai-compare-badge{font-size:.72rem;padding:3px 8px;border-radius:999px;font-weight:600;text-align:center;width:fit-content}.ai-compare-badge.match{color:#22c55e;background:#22c55e29}.ai-compare-badge.partial{color:#f59e0b;background:#f59e0b2e}.ai-compare-badge.missing{color:#ef4444;background:#ef444429}.ai-compare-required{color:var(--muted)}.ai-compare-missing{padding:8px;border-radius:12px;border:1px solid rgba(239,68,68,.3);background:#ef444414}.ai-compare-missing-title{font-weight:600;margin-bottom:6px}.ai-compare-missing ul{margin:0;padding-left:18px;display:grid;gap:4px}.user-chip{background:transparent;border:none;padding:0;text-align:left;cursor:pointer}.user-avatar img{width:100%;height:100%;border-radius:inherit;object-fit:cover;display:block}.meta-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));font-size:.9rem}.step-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.step{border:1px solid var(--border-soft);border-radius:12px;padding:10px;background:#94a3b814}.step-title{font-weight:600}.step.APPROVED{border-color:#22c55e66;background:#22c55e26}.step.REJECTED{border-color:#ef444466;background:#ef444426}.step-row{display:grid;gap:8px;grid-template-columns:2fr 1fr 1fr}.comment-list{display:flex;flex-direction:column;gap:8px}.comment{padding:10px 12px;border-radius:12px;background:#94a3b814}.comment-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}.comment-author{font-weight:600}.comment-time{font-size:.75rem;color:var(--muted)}.comment-date{align-self:center;padding:4px 12px;border-radius:999px;background:#94a3b81f;font-size:.75rem;color:var(--muted)}.comment-text{white-space:pre-wrap;line-height:1.45}.chat{display:flex;flex-direction:column;gap:12px}.chat-messages{display:flex;flex-direction:column;gap:10px;max-height:240px;overflow:auto}.chat-bubble{border-radius:12px;padding:10px 12px;background:#94a3b81a}.chat-bubble.user{background:#3b82f626}.chat-bubble.assistant{background:#22c55e26}.chat-role{font-size:.7rem;text-transform:uppercase;color:var(--muted);margin-bottom:6px}.ai-fab{position:fixed;right:20px;bottom:20px;width:44px;height:44px;border-radius:999px;border:1px solid rgba(59,130,246,.5);background:#1e40afe6;color:#fff;display:grid;place-items:center;cursor:pointer;z-index:80;box-shadow:0 10px 28px #02061780}.ai-dialog{position:fixed;right:20px;bottom:72px;width:min(430px,calc(100vw - 24px));height:min(620px,calc(100vh - 110px));z-index:85;border-radius:14px;box-shadow:0 18px 48px #0206178c}.ai-dialog-header{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:grab;-webkit-user-select:none;user-select:none}.ai-dialog-header:active{cursor:grabbing}.ai-dialog-controls{display:flex;align-items:center;gap:8px;cursor:auto}.ai-dialog-controls *{cursor:auto}.ai-model-picker{display:flex;align-items:center;gap:6px}.ai-model-picker .muted{font-size:.78rem}.ai-dialog-body{min-height:0;height:100%}.ai-dialog .chat-messages{max-height:none;flex:1 1 auto;min-height:0}.procurement-list-view{display:flex;flex-direction:column;gap:8px;width:100%}.procurement-list-table{display:flex;flex-direction:column;gap:6px}.procurement-list-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:10px;align-items:center;padding:6px 8px;border-radius:10px;background:#94a3b814}.procurement-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-end}.procurement-name{min-width:0;font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.procurement-qty{font-size:.85rem;color:var(--muted);white-space:nowrap}.procurement-status{font-size:.75rem;border-radius:999px;padding:4px 8px;font-weight:600;white-space:nowrap}.procurement-status.ok{color:#22c55e;background:#22c55e2e}.procurement-status.partial{color:#f59e0b;background:#f59e0b33}.procurement-status.pending{color:#f97316;background:#f9731633}.procurement-list-item{display:flex;flex-direction:column;gap:6px}.procurement-remove{font-size:.75rem}.procurement-action{padding:6px 10px;border-radius:8px;font-size:.78rem}.procurement-edit{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr) minmax(0,1fr) auto auto;gap:8px;align-items:center}.procurement-ai{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.procurement-approve{margin-top:8px;display:flex;gap:8px;flex-wrap:wrap}.procurement-add{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr) minmax(0,1fr) auto;gap:8px;align-items:center}.procurement-add-btn{white-space:nowrap}@media(max-width:900px){.procurement-list-row{grid-template-columns:minmax(0,1fr);gap:6px}.procurement-edit{grid-template-columns:minmax(0,1fr)}.procurement-ai{flex-direction:column;align-items:flex-start}.procurement-add,.ai-compare-row{grid-template-columns:minmax(0,1fr)}}body.theme-light .ai-fab{background:#2563eb;border-color:#1d4ed8}.muted{color:var(--muted);font-size:.9rem}.pill{background:#94a3b833;padding:4px 8px;border-radius:999px;font-size:.75rem}.user-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;background:#94a3b814}.user-row-main{min-width:0}.user-row-actions{flex:0 0 auto}.placeholder{min-height:220px}.auth{min-height:100vh;display:grid;place-items:center;padding:32px}.auth-card{width:min(520px,100%)}.auth-title h1{margin:0 0 6px}.auth-portal{position:relative;overflow:hidden;padding:40px 24px;background:radial-gradient(circle at 50% 30%,rgba(34,211,238,.12),transparent 18%),radial-gradient(circle at 50% 52%,rgba(59,130,246,.12),transparent 32%),linear-gradient(180deg,#05070b,#04070c 48%,#070b12)}.auth-portal:before,.auth-portal:after{content:"";position:absolute;inset:0;pointer-events:none}.auth-portal:before{background:radial-gradient(circle at 18% 24%,rgba(59,130,246,.08),transparent 24%),radial-gradient(circle at 82% 72%,rgba(34,211,238,.06),transparent 22%);mix-blend-mode:screen}.auth-portal:after{background:linear-gradient(90deg,transparent 0%,rgba(37,99,235,.06) 48%,transparent 100%),linear-gradient(180deg,rgba(255,255,255,.02),transparent 22%,transparent 78%,rgba(255,255,255,.02));opacity:.65}.auth-watermark{position:absolute;left:0;right:0;overflow:hidden;font-family:Syncopate,Manrope,sans-serif;font-size:clamp(4.6rem,11vw,11rem);line-height:.9;letter-spacing:.16em;text-transform:uppercase;color:#3d78ff14;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none}.auth-watermark-track{display:inline-flex;width:max-content;min-width:200%;gap:3.5rem;animation:auth-marquee 42s linear infinite}.auth-watermark-track span{display:inline-block;flex:0 0 auto}.auth-watermark-track-reverse{animation-direction:reverse;animation-duration:48s}.auth-watermark-top{top:13vh}.auth-watermark-bottom{bottom:5vh}.auth-orbit{position:absolute;width:520px;height:520px;border-radius:50%;border:1px solid rgba(34,211,238,.08);box-shadow:inset 0 0 120px #2563eb14,0 0 160px #08183729;filter:blur(.2px);pointer-events:none}.auth-orbit:before{content:"";position:absolute;inset:52px;border-radius:50%;border:1px solid rgba(125,211,252,.08)}.auth-orbit-left{top:12%;left:-190px}.auth-orbit-right{right:-220px;bottom:-120px}.auth-core{position:relative;z-index:1;width:min(460px,100%);display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px}.auth-emblem{display:grid;place-items:center;margin-bottom:6px}.auth-emblem-badge{width:108px;height:108px;border-radius:28px;display:grid;place-items:center;font-family:Syncopate,Manrope,sans-serif;font-size:2rem;font-weight:700;letter-spacing:.08em;color:#031423;background:linear-gradient(135deg,#93c5fdfa,#3b82f6fa 52%,#22d3eef0);box-shadow:inset 0 1px #ffffff73,0 0 32px #3b82f652,0 24px 44px #03122773;position:relative}.auth-emblem-badge:before{content:"";position:absolute;inset:-14px;border-radius:38px;border:1px solid rgba(96,165,250,.18);box-shadow:0 0 70px #3b82f61f}.auth-title{display:flex;flex-direction:column;align-items:center;gap:6px}.auth-kicker,.auth-title-sub,.auth-footer-note,.auth-caption,.auth-field-label{text-transform:uppercase;letter-spacing:.32em}.auth-kicker{font-size:.7rem;color:#93c5fd8f}.auth-title h1{margin:0;font-family:Syncopate,Manrope,sans-serif;font-size:clamp(2.5rem,6vw,4rem);letter-spacing:.24em;font-weight:400;color:#7dd3fc;text-shadow:0 0 24px rgba(34,211,238,.14)}.auth-title-sub{font-size:.9rem;color:#60a5fae0}.auth-title p{margin:8px 0 0;max-width:390px;color:#dee0f2b8;font-size:.95rem;line-height:1.65}.auth-mode-switch{display:inline-flex;gap:8px;padding:6px;border-radius:999px;background:#09101cdb;border:1px solid rgba(59,130,246,.24);box-shadow:inset 0 0 0 1px #bae6fd08}.auth-mode-btn{min-width:132px;padding:10px 18px;border-radius:999px;border:1px solid transparent;background:transparent;color:#e0e1f0bd;cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.auth-mode-btn:hover{color:#f4f3ff}.auth-mode-btn.active{background:linear-gradient(135deg,#0b1c3afa,#081222fa);color:#f8f7ff;border-color:#38bdf86b;box-shadow:inset 0 0 0 1px #bae6fd0f,0 8px 18px #0000003d}.auth-panel{width:100%;padding:26px 24px 22px;border-radius:28px;background:linear-gradient(180deg,#0a101cf0,#080c14f0);border:1px solid rgba(59,130,246,.24);box-shadow:0 20px 70px #00000061,inset 0 1px #ffffff05;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.auth-stack,.auth-form-grid{display:grid;gap:14px}.auth-field{display:grid;gap:8px;text-align:left}.auth-field-label{font-size:.66rem;color:#93c5fd94}.auth-input{height:58px;border-radius:18px;border:1px solid rgba(59,130,246,.4);background:#080e1aeb;color:#faf8ff;text-align:center;font-size:1rem;letter-spacing:.14em;box-shadow:inset 0 0 0 1px #bae6fd05,0 0 0 1px #3b82f614}.auth-input::placeholder{color:#60a5fa7a;text-transform:uppercase}.auth-input:focus{outline:none;border-color:#38bdf8d1;box-shadow:0 0 0 4px #3b82f61f,inset 0 0 0 1px #bae6fd0a}.auth-submit,.auth-secondary{min-height:56px;border-radius:18px;text-transform:uppercase;letter-spacing:.28em}.auth-submit{background:linear-gradient(135deg,#0c203e,#08101e);border:1px solid rgba(59,130,246,.42);color:#bfdbfef5;box-shadow:inset 0 1px #ffffff05,0 16px 30px #05040a57}.auth-submit:hover{background:linear-gradient(135deg,#0e274c,#091528);border-color:#38bdf885}.auth-secondary{background:transparent;border:1px solid rgba(59,130,246,.24);color:#dfdcf7c7}.auth-inline-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.auth-caption{font-size:.64rem;color:#93c5fd75;text-align:center}.auth-status{border-radius:18px;padding:12px 14px;border:1px solid rgba(59,130,246,.26);background:#0e182bc7;color:#efebffdb;font-size:.92rem}.auth-status-warning{border-color:#cea24952;background:#412f138c;color:#f0cd83}.auth-divider{width:min(230px,100%);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px}.auth-divider span{height:1px;background:linear-gradient(90deg,transparent,rgba(56,189,248,.5),transparent)}.auth-divider-dot{width:8px;height:8px!important;border-radius:50%;background:radial-gradient(circle,#7dd3fc,#2563eb 80%);box-shadow:0 0 16px #22d3ee52}.auth-footer-note{font-size:.62rem;color:#60a5fa8a}@keyframes auth-marquee{0%{transform:translate(0)}to{transform:translate(-50%)}}.icon-button{border:1px solid var(--border-soft);background:#94a3b814;color:var(--text);width:26px;height:26px;border-radius:8px;display:grid;place-items:center;cursor:pointer;margin-left:auto}.favorite-item{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:10px;background:#94a3b814}.favorite-link{background:none;border:none;color:var(--text);font:inherit;text-align:left;cursor:pointer}.favorite-form{display:grid;gap:8px;margin-top:8px}.summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.summary-card{background:#94a3b814;border:1px solid var(--border-soft);border-radius:12px;padding:10px}.summary-label{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.06em}.summary-value{font-size:1.1rem;font-weight:600;margin-top:4px}.detail-split{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:16px}.detail-main{display:flex;flex-direction:column;gap:16px}.detail-side{display:flex;flex-direction:column;gap:12px}.detail-tabs{display:flex;gap:6px}.detail-tabs button{border:1px solid var(--border-soft);background:transparent;color:var(--muted);border-radius:10px;padding:6px 10px;font-size:.8rem}.detail-tabs button.active{color:var(--text);border-color:#3b82f680;background:#3b82f626}.detail-tabs button:disabled{opacity:.5;cursor:not-allowed}.info-grid{display:grid;gap:8px}.info-row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px solid rgba(148,163,184,.12)}.info-row:last-child{border-bottom:none}.info-label{color:var(--muted);font-size:.85rem}.info-value{text-align:right}.info-row-stack{display:grid;grid-template-columns:1fr;gap:8px;align-items:start}.info-value-stack{display:block;width:100%;text-align:left}.info-files{display:inline-flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.file-pill{border:1px solid var(--border-soft);background:#94a3b814;border-radius:999px;padding:6px 10px;font-size:.85rem;color:inherit;cursor:pointer;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-pill:hover{border-color:#3b82f680}.profile-avatar-editor{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.profile-avatar{width:52px;height:52px;border-radius:16px}.profile-password-grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}@media(max-width:520px){.profile-avatar-editor{justify-content:flex-start}.profile-password-grid{grid-template-columns:1fr}}.breadcrumbs{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.crumb{background:none;border:none;color:var(--muted);font:inherit;cursor:pointer;padding:0}.crumb-sep{color:var(--muted);margin:0 6px}.inbox-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.inbox-actions{display:flex;justify-content:flex-end;align-items:center}.inbox-select{min-width:160px}.task-row{grid-template-columns:72px 1fr 190px}.task-row-left{flex-direction:row;align-items:center;gap:8px}.task-check{width:12px;height:12px;border-radius:4px;border:1px solid rgba(148,163,184,.4)}.task-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.85rem}.task-tag{padding:2px 8px;border-radius:999px;background:#3b82f626;color:#93c5fd;font-size:.75rem}.task-content p{margin:0;line-height:1.5}.create-card{border:1px dashed rgba(148,163,184,.4)}@media(max-width:1100px){.workspace{grid-template-columns:1fr}.task-panel{max-height:none}.detail-split{grid-template-columns:1fr}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.sidebar{position:sticky;top:0;z-index:10;height:auto;overflow:visible}.task-row{grid-template-columns:1fr}.task-row-right{align-items:flex-start}.step-row{grid-template-columns:1fr}}.task-group{display:flex;flex-direction:column;gap:6px}.task-group-row{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.85rem;padding:4px 6px}.task-group-dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}.task-group-title{font-weight:600;color:var(--text)}.task-group-count{margin-left:auto;background:#94a3b829;padding:2px 8px;border-radius:999px;font-size:.75rem}.task-dot{width:8px;height:8px;border-radius:999px;background:#fbbf24}.attachment-actions{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.danger{color:#f87171}.ghost.danger{border-color:#f8717166;color:#f87171}.upload.disabled{opacity:.5;cursor:not-allowed}.field-grid{display:grid;gap:10px}.field-row{display:grid;gap:6px}.field-label{font-size:.8rem;color:var(--muted)}.required{color:#f97316;margin-left:4px}.field-preview{display:grid;gap:6px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(148,163,184,.12)}.field-builder{display:grid;gap:10px}.field-builder-row{display:grid;gap:8px;background:#0f131999;border:1px solid rgba(148,163,184,.2);padding:10px;border-radius:12px}.field-actions{display:flex;gap:6px}.divider{height:1px;background:#94a3b833;margin:8px 0}.star-button{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:1rem}.star-button.active{color:#facc15}.audit-list{display:grid;gap:10px}.audit-row{display:flex;justify-content:space-between;gap:12px;padding:10px;border-radius:12px;background:#94a3b814;border:1px solid rgba(148,163,184,.12)}.audit-title{font-weight:600}.audit-meta{color:var(--muted);font-size:.75rem;max-width:160px;word-break:break-word}.board-view{display:flex;flex-direction:column;gap:16px}.board-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.board-actions{display:flex;align-items:center;gap:10px}.board-status-add{display:flex;align-items:center;gap:8px}.board-status-add .input-compact{width:190px}.board-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.board-column{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:12px;display:flex;flex-direction:column;gap:10px;min-height:240px}.board-column-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;gap:8px}.board-column-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:grab}.board-column-title:active{cursor:grabbing}.board-cards{display:flex;flex-direction:column;gap:10px}.board-card{background:var(--panel-2);border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:10px 34px 10px 10px;text-align:left;cursor:pointer;color:inherit;position:relative}.board-star{position:absolute;top:8px;right:10px;font-size:.95rem;color:var(--muted);cursor:pointer}.board-star.active{color:var(--primary)}.calendar-view{display:flex;flex-direction:column;gap:16px}.calendar-header{display:flex;justify-content:space-between;align-items:center}.calendar-actions{display:flex;gap:8px}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}.calendar-day{background:var(--panel);border:1px solid var(--border);border-radius:10px;min-height:120px;padding:8px;display:flex;flex-direction:column;gap:6px}.calendar-day.header{min-height:auto;background:transparent;border:none;color:var(--muted);font-size:.8rem;text-transform:uppercase}.calendar-day.dim{opacity:.4}.calendar-date{font-weight:600;font-size:.85rem}.calendar-events{display:flex;flex-direction:column;gap:6px}.calendar-event{border:none;background:#3b82f633;color:var(--text);border-radius:8px;padding:4px 6px;text-align:left;font-size:.75rem;cursor:pointer}.calendar-event.success{background:#22c55e33;color:#bbf7d0}.calendar-event.danger{background:#ef444433;color:#fecaca}.announcements-view{display:flex;flex-direction:column;gap:16px}.announcements-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:16px}.announcements-list{display:flex;flex-direction:column;gap:12px}.announcement-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:8px}.announcement-title{font-weight:700;font-size:1rem}.announcement-form{position:sticky;top:20px}@media(max-width:1100px){.announcements-grid{grid-template-columns:1fr}}@media(max-width:900px){.board-grid{grid-template-columns:1fr}.calendar-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.task-star{position:static;width:28px;height:28px;border-radius:8px;border:1px solid rgba(148,163,184,.2);background:#0f1319b3;color:var(--muted);display:grid;place-items:center;cursor:pointer}.task-star.active{color:#facc15;border-color:#facc1580}.input-compact{background:var(--bg-2);border:1px solid rgba(148,163,184,.2);color:var(--text);border-radius:8px;padding:4px 8px;font-size:.85rem}.comment-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.comment-draft-files{display:grid;gap:8px;margin:8px 0}.comment-draft-file{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center;padding:6px 8px;border-radius:10px;border:1px solid var(--border-soft);background:#94a3b814}.comment-draft-name{min-width:0;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.comment-draft-size{font-size:.75rem;color:var(--muted);white-space:nowrap}.comment-draft-remove{white-space:nowrap}.comment-files{display:flex;flex-wrap:wrap;gap:6px}.comment-image{padding:0;border:1px solid rgba(148,163,184,.2);border-radius:12px;background:#0f172a40;cursor:pointer;overflow:hidden;width:124px;height:86px}.comment-image img{width:100%;height:100%;object-fit:cover;display:block}.attachment-row .task-title{word-break:break-word;overflow-wrap:anywhere;white-space:normal;line-height:1.3}.attachment-row .muted,.attachment-text .muted{white-space:normal;overflow-wrap:anywhere;word-break:break-word}.status-editor{display:grid;gap:10px}.status-input{display:flex;gap:8px;flex-wrap:wrap}.status-list{display:flex;flex-wrap:wrap;gap:6px}.status-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#3b82f626;border:1px solid rgba(59,130,246,.4)}.settings-view{max-width:720px}.settings-grid{display:grid;gap:12px}.settings-row{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.theme-toggle{display:flex;gap:8px;flex-wrap:wrap}body.theme-light .calendar-event.success{color:#166534;background:#16a34a2e}body.theme-light .calendar-event.danger{color:#b91c1c;background:#dc26262e}@media(max-width:720px){.auth-portal{padding:24px 16px}.auth-watermark{font-size:clamp(2.8rem,16vw,5.4rem);letter-spacing:.12em}.auth-watermark-top{top:10vh}.auth-watermark-bottom{bottom:7vh}.auth-orbit{width:280px;height:280px}.auth-orbit-left{left:-120px;top:8%}.auth-orbit-right{right:-120px;bottom:3%}.auth-panel{padding:22px 18px 18px;border-radius:22px}.auth-mode-switch{width:100%}.auth-mode-btn{flex:1 1 0;min-width:0}.auth-inline-actions{grid-template-columns:1fr}.auth-input{font-size:.92rem;letter-spacing:.08em}.topbar{flex-direction:column;align-items:flex-start}.topbar-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}.inbox-header{flex-direction:column;align-items:flex-start}.inbox-actions{width:100%}.task-card{padding-top:96px}.task-top-right{max-width:calc(100% - 16px);right:8px;top:8px}.ai-fab{right:14px;bottom:14px}.ai-dialog{right:12px;left:12px;width:auto;bottom:66px;height:calc(100vh - 100px)}.ai-dialog-header{flex-wrap:wrap;align-items:flex-start}.ai-dialog-controls{width:100%;justify-content:space-between}}.modal-backdrop{position:fixed;inset:0;background:#020617b8;display:flex;align-items:center;justify-content:center;padding:24px;z-index:9999}body.theme-light .modal-backdrop{background:#0f172a73}.modal{width:min(920px,96vw);max-height:90vh;background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 20px 80px #00000080;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}.modal-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-body{padding:12px 14px;overflow:auto}.preview-img{max-width:100%;height:auto;display:block;margin:0 auto;border-radius:12px;border:1px solid rgba(148,163,184,.18)}.preview-frame{width:100%;height:70vh;border:0;border-radius:12px;background:#fff}.preview-doc-html{background:#fff;color:#0f172a;border:1px solid rgba(148,163,184,.24);border-radius:12px;padding:12px;max-height:70vh;overflow:auto}.preview-doc-html table{width:100%;border-collapse:collapse;margin-top:8px}.preview-doc-html th,.preview-doc-html td{border:1px solid rgba(15,23,42,.15);padding:6px 8px;text-align:left;vertical-align:top}.preview-doc-html .preview-sheet+.preview-sheet{margin-top:14px}.preview-fallback{display:flex;flex-direction:column;gap:12px}
