*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Segoe UI,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.static{position:static}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.table{display:table}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg: #f4f6fb;--surface: #ffffff;--surface2: #f0f2f8;--border: #dde1ef;--accent: #5b6af5;--accent2: #7c3aed;--success: #16a34a;--warn: #d97706;--danger: #dc2626;--text: #1e2235;--muted: #6b7280}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Segoe UI,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}input[type=text],input[type=number],input[type=date],select,textarea{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;padding:8px 10px;outline:none;transition:border-color .2s;font-family:inherit;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--accent)}.field-error{border-color:var(--danger)!important}.error-text{color:var(--danger);font-size:11px;margin-top:4px}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:linear-gradient(135deg,#134e4a,#0f766e);flex-shrink:0;gap:10px;flex-wrap:nowrap;min-height:48px}.hdr-left{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:0}.logo{font-size:16px;font-weight:800;letter-spacing:-.5px;color:#fff;flex-shrink:0;white-space:nowrap}.logo span{color:#5eead4}.date-badge{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fffc;border-radius:7px;padding:3px 9px;font-size:11px;white-space:nowrap;flex-shrink:0}.hdr-left .progress-wrap{display:flex;align-items:center;gap:8px;width:180px;flex-shrink:0}.progress-bar{flex:1;height:5px;background:#fff3;border-radius:99px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#5eead4,#a7f3d0);transition:width .3s}.progress-text{color:#ffffffbf;font-size:11px;white-space:nowrap}.header-right{display:flex;gap:5px;flex-wrap:nowrap;align-items:center;min-width:0;flex-shrink:1;overflow:visible;position:relative}.hdr-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:7px;padding:5px 10px;font-size:11.5px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.hdr-btn.logout-btn{font-size:11px;padding:5px 9px}.app-header .hdr-btn:hover{background:#ffffff38;border-color:#fff;color:#fff}.app-header .hdr-btn.red{background:#ef44442e;border-color:#fca5a58c;color:#fecaca}.app-header .hdr-btn.red:hover{background:#ef444452;border-color:#fca5a5;color:#fff}.app-header .hdr-btn.master-btn{background:#f59e0b38;border-color:#f59e0b8c;color:#fde68a}.app-header .hdr-btn.master-btn:hover{background:#f59e0b59;border-color:#f59e0b;color:#fff}.user-chip{display:flex;align-items:center;gap:6px;background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:20px;padding:3px 10px 3px 3px;color:#fff;font-size:11.5px;flex-shrink:0}.user-chip .user-name{font-size:11.5px;max-width:70px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip .user-team{font-size:10px;opacity:.7}.more-wrap{position:relative;flex-shrink:0;z-index:1200}.more-btn{font-size:15px;font-weight:700;padding:4px 10px;position:relative}.more-btn.active{background:#ffffff38;border-color:#fff}.more-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;box-shadow:0 10px 28px #0000002e;z-index:1250;min-width:200px;padding:6px;display:flex;flex-direction:column;gap:2px;color:var(--text)}.more-item{background:transparent;border:0;padding:9px 12px;font-size:12.5px;font-weight:600;color:var(--text);text-align:left;border-radius:6px;cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:space-between}.more-item:hover{background:#5b6af514}.more-item.master{color:#b45309}.more-item.master:hover{background:#f59e0b1a}.more-item.danger{color:var(--danger)}.more-item.danger:hover{background:#ef444414}.more-sep{height:1px;background:var(--line);margin:4px 2px}.more-badge{background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:9px;min-width:18px;text-align:center}.user-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#5b6af5,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff;font-weight:700}.sync-dot{width:8px;height:8px;border-radius:50%;background:#5eead4;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.mob-hamburger{display:none;align-items:center;justify-content:center;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:8px;color:#fff;font-size:18px;padding:5px 10px;cursor:pointer;flex-shrink:0}.summary-wrap{background:var(--bg);border-bottom:1px solid var(--border);padding:6px 12px}.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:6px 10px;text-align:left;cursor:pointer;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;flex-direction:row;align-items:center;gap:8px;font-family:inherit;min-height:34px}.summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 10px #0000000f}.summary-card.active{box-shadow:0 4px 12px #00000014}.summary-card.tone-blue{border-left:3px solid #0ea5e9}.summary-card.tone-red{border-left:3px solid #ef4444}.summary-card.tone-green{border-left:3px solid #22c55e}.summary-card.tone-indigo{border-left:3px solid #5b6af5}.summary-card.tone-blue.active{border-color:#0ea5e9;background:#0ea5e90f}.summary-card.tone-red.active{border-color:#ef4444;background:#ef44440f}.summary-card.tone-green.active{border-color:#22c55e;background:#22c55e0f}.summary-card.tone-indigo.active{border-color:#5b6af5;background:#5b6af50f}.summary-icon{font-size:15px;flex-shrink:0}.summary-label{font-size:10.5px;font-weight:600;color:var(--muted);flex:1;min-width:0}.summary-value{font-size:16px;font-weight:800;color:var(--text);flex-shrink:0}.summary-wrap{position:relative}.summary-detail-toggle{position:absolute;right:10px;top:8px;background:#5b6af514;border:1px solid rgba(91,106,245,.2);color:var(--accent);font-size:10px;font-weight:700;cursor:pointer;padding:3px 8px;border-radius:4px;font-family:inherit;z-index:2}.summary-detail-toggle:hover{background:#5b6af524}.summary-detail{margin-top:8px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.summary-detail .summary-section{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.summary-section-title{font-size:11px;font-weight:700;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.summary-bars{display:flex;flex-direction:column;gap:6px}.summary-bar-row{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:8px;font-size:11px}.summary-bar-label{color:var(--text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-bar-track{height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}.summary-bar-fill{height:100%;background:linear-gradient(90deg,#5b6af5,#7c3aed);transition:width .3s}.summary-bar-value{font-size:10px;color:var(--muted);font-weight:700}@media (max-width: 768px){.summary-cards{grid-template-columns:repeat(2,1fr)}.summary-detail{grid-template-columns:1fr}}.app-body{display:flex;gap:0;padding:0;flex:1;overflow:hidden}.panel-personal,.panel-team-timeline{background:var(--surface);border-right:1px solid var(--border);padding:14px 16px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.panel-personal{flex:1}.panel-team-timeline{flex:1.2}.panel-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid var(--border)}.personal-input{flex-shrink:0}.pi-row{display:flex;gap:6px;margin-bottom:7px;flex-wrap:wrap;align-items:center}.pi-row input,.pi-row select{flex:1;min-width:0}.pi-name{flex:1 1 100%}.pi-date{flex:1 1 140px;max-width:100%}.pi-priority{flex:1;min-width:90px}.btn-importance{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:13px;cursor:pointer;color:var(--text);transition:all .15s}.btn-importance:hover{border-color:#eab308}.btn-importance.active{background:#eab30826;border-color:#eab308;color:#eab308}.btn-outing{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:13px;font-weight:600;cursor:pointer;color:var(--text);transition:all .15s}.btn-outing:hover{border-color:var(--accent);color:var(--accent)}.btn-outing.active{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-outing.absence{color:#a855f7;border-color:#a855f7}.btn-outing.absence:hover{background:#a855f71a}.btn-pi-add{background:var(--accent);border:none;color:#fff;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;width:100%;transition:opacity .2s;margin-top:2px}.btn-pi-add:hover{opacity:.85}.team-input-bar{background:var(--surface2);border:1px solid var(--border);border-radius:11px;padding:11px 12px;margin-bottom:12px}.tib-row1{display:grid;grid-template-columns:1fr auto;gap:7px;margin-bottom:7px;align-items:center}.tib-row2{display:grid;grid-template-columns:85px 1fr 38px;gap:7px;margin-bottom:7px;align-items:center}.tib-time-wrap{display:flex;align-items:center;gap:3px}.tib-time-wrap select{padding:7px 4px;text-align:center;font-size:12px}.tib-time-sep{color:var(--muted);font-weight:700;font-size:14px}.tib-name,.tib-att,.tib-dur,.tib-date{font-size:12px}.btn-tib-alarm{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:7px 0;font-size:13px;cursor:pointer;transition:all .15s}.btn-tib-alarm:hover{border-color:var(--accent)}.btn-tib-alarm.active{background:#f59e0b26;border-color:#f59e0b}.btn-tib-add{background:var(--success);border:none;color:#fff;border-radius:8px;padding:9px;font-size:12px;font-weight:700;cursor:pointer;width:100%;transition:opacity .2s}.btn-tib-add:hover{opacity:.88}.team-tl-header{padding:9px 0 8px;border-bottom:1px solid var(--border);margin-bottom:9px;display:flex;align-items:center;justify-content:space-between;gap:8px}.team-tl-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.t-slot{display:grid;grid-template-columns:44px 1fr;gap:8px;padding:4px 0;border-top:1px dashed var(--border);min-height:26px;align-items:flex-start}.t-slot:first-child{border-top:none}.t-label{font-size:10px;color:var(--muted);font-family:monospace;padding-top:3px}.t-col{display:flex;flex-wrap:wrap;gap:4px;align-items:center;min-height:22px}.pill-btn{border:1px solid var(--border);background:var(--surface2);color:var(--text);border-radius:8px;padding:7px 10px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.pill-btn:hover{border-color:var(--accent);color:var(--accent)}.pill-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.pill-btn.active:hover{opacity:.9;color:#fff}.pill-btn.danger{color:var(--danger)}.pill-btn.danger:hover{border-color:var(--danger);color:var(--danger)}.pill-btn.warn{color:var(--warn)}.pill-btn.success{color:var(--success)}.personal-list{flex:1;overflow-y:auto;margin-top:8px}.pl-empty{color:var(--muted);font-size:12px;text-align:center;padding:24px 8px}.pl-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;margin-bottom:6px;background:var(--surface);font-size:13px;transition:border-color .15s}.pl-item:hover{border-color:var(--accent)}.pl-item:hover .pl-drag-handle{opacity:.7}.pl-drag-handle{opacity:0;color:var(--muted);cursor:grab;transition:opacity .15s}.pl-item.done{opacity:.55}.pl-item.done .pl-title{text-decoration:line-through}.pl-item .prio-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pl-item .pl-title{flex:1}.pl-item .star{color:#eab308}.btn-pl{background:none;border:none;color:var(--muted);cursor:pointer;padding:2px 4px;font-size:14px;transition:color .15s}.btn-pl:hover{color:var(--accent)}.btn-pl.del:hover{color:var(--danger)}.team-tl-body{flex:1;overflow-y:auto;position:relative}.tl-hour{display:flex;align-items:flex-start;gap:10px;padding:6px 4px;border-top:1px dashed var(--border);font-size:11px;color:var(--muted);min-height:34px}.tl-hour .h-label{width:48px;flex-shrink:0;font-weight:600;font-family:monospace;padding-top:2px}.tl-hour .h-body{flex:1;display:flex;gap:6px;flex-wrap:wrap;align-items:center}.tl-now{background:var(--accent);color:#fff;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700}.tt-card{display:inline-flex;align-items:center;gap:6px;background:#5b6af514;border:1px solid rgba(91,106,245,.35);color:var(--text);padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600;transition:all .15s;cursor:pointer}.tt-card:hover{border-color:var(--success);background:#22c55e1c}.tt-card .ttc-meta{color:var(--muted);font-weight:500;font-size:11px}.panel-right{width:280px;flex-shrink:0;background:var(--surface);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.pr-header{padding:12px 16px 9px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.pr-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}.btn-refresh{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:12px;color:var(--muted);transition:all .15s}.btn-refresh:hover{color:var(--accent);border-color:var(--accent)}.sm-card{background:var(--surface2);border:1px solid var(--border);border-radius:11px;padding:11px 13px;margin:0 12px 8px}.sm-card:first-child{margin-top:12px}.sm-top{display:flex;align-items:center;gap:9px;margin-bottom:8px}.sm-av{width:32px;height:32px;border-radius:50%;-o-object-fit:cover;object-fit:cover;flex-shrink:0}.sm-av-fallback{background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px}.sm-name{font-size:12px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:2px}.sm-email{font-size:10px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.sm-pb{width:100%;height:5px;background:var(--border);border-radius:99px;overflow:hidden;margin-bottom:6px}.sm-pf{height:100%;background:var(--accent);transition:width .3s}.sm-stats{display:flex;justify-content:space-between;font-size:10px;color:var(--muted)}.sm-stats .sv{color:var(--text);font-weight:700}.pr-note{padding:8px 16px;font-size:10px;color:var(--muted);text-align:right;border-top:1px solid var(--border)}.status-list{flex:1;overflow-y:auto}.status-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:var(--surface2);margin-bottom:6px;font-size:12px}.status-row .sr-name{flex:1;font-weight:600}.status-row .sr-tag{padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700}.tag-work{background:#16a34a26;color:#16a34a}.tag-외근{background:#3b82f626;color:#3b82f6}.tag-출장{background:#16a34a26;color:#16a34a}.tag-연차{background:#d9770626;color:#d97706}.tag-휴가{background:#a855f726;color:#a855f7}.tag-반차{background:#eab30826;color:#eab308}.pr-note{font-size:10px;color:var(--muted);margin-top:8px;text-align:right}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg);padding:20px}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 40px;text-align:center;max-width:400px;width:100%}.login-logo{font-size:28px;font-weight:800;margin-bottom:8px;color:#1e2235}.login-logo span{color:var(--accent)}.login-sub{color:var(--muted);font-size:14px;margin-bottom:40px}.btn-google{display:flex;align-items:center;justify-content:center;gap:12px;background:#fff;color:#1f2937;border:none;border-radius:12px;padding:14px 24px;font-size:15px;font-weight:600;cursor:pointer;width:100%;transition:all .2s;box-shadow:0 2px 12px #0000004d}.btn-google:hover{box-shadow:0 4px 20px #0006;transform:translateY(-1px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-card.wide{max-width:860px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.modal-title{font-size:16px;font-weight:700}.btn-close{background:var(--surface2);border:1px solid var(--border);border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:13px;color:var(--muted);transition:all .15s}.btn-close:hover{color:var(--danger);border-color:var(--danger)}.btn-save{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:13px;font-weight:700;cursor:pointer;transition:opacity .15s}.btn-save:hover{opacity:.85}.btn-cancel{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:10px 20px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;transition:all .15s}.btn-cancel:hover{border-color:var(--danger);color:var(--danger)}.report-table{width:100%;border-collapse:collapse;font-size:12px}.report-table th,.report-table td{padding:10px 8px;border-bottom:1px solid var(--border);text-align:left}.report-table th{background:var(--surface2);color:var(--muted);font-weight:700;font-size:11px}.report-table tr:hover td{background:#5b6af50a}.report-date-nav{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:12px;cursor:pointer;transition:all .15s}.report-date-nav:hover{border-color:var(--accent);color:var(--accent)}.remc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:12px}.remc-card{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:18px 12px;text-align:center;cursor:pointer;font-size:13px;color:var(--muted);transition:all .15s;text-decoration:none}.remc-card:hover{border-color:var(--accent);color:var(--accent)}.remc-card .icon{font-size:26px;display:block;margin-bottom:6px}.remc-card.active{color:var(--text)}button.remc-card{font-family:inherit;font-weight:600;color:var(--text)}.remc-card .remc-meta{display:block;font-size:10px;color:var(--muted);font-weight:500;margin-top:4px}.remc-card .sr-tag{margin-top:6px;display:inline-block}.cal-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}.cal-nav{display:flex;align-items:center;gap:10px}.cal-nav-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:14px;transition:all .15s}.cal-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-month-label{font-size:15px;font-weight:700;min-width:130px;text-align:center}.cal-view-toggle{display:flex;gap:6px;margin-left:auto}.cal-view-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 14px;font-size:12px;cursor:pointer;transition:all .15s}.cal-view-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-view-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.cal-members{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.cal-member-btn{background:var(--surface2);border:1px solid var(--border);border-radius:99px;padding:4px 12px;font-size:12px;cursor:pointer;transition:all .15s}.cal-member-btn:hover{border-color:var(--accent);color:var(--accent)}.cal-member-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}.cal-wd{text-align:center;font-size:11px;color:var(--muted);padding:4px 0;font-weight:600}.cal-wd.sun{color:#ef4444}.cal-wd.sat{color:#3b82f6}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-day{background:var(--surface2);border:1px solid var(--border);border-radius:8px;min-height:72px;padding:6px 8px;font-size:11px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column}.cal-day:hover{border-color:var(--accent)}.cal-day.other{opacity:.4}.cal-day.today{border-color:var(--accent);border-width:2px}.cal-day-num{font-weight:700;margin-bottom:2px}.cal-day-tasks{display:flex;flex-direction:column;gap:2px}.cal-dot{background:var(--accent);color:#fff;font-size:9px;padding:1px 4px;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-dot.draggable{cursor:grab}.cal-dot.draggable:active{cursor:grabbing}.cal-dot.dragging{opacity:.4}.cal-day.drop-target{transition:all .15s}.cal-day.drop-over{border:2px dashed var(--accent);background:#5b6af514;transform:scale(1.02)}.toast-wrap{position:fixed;bottom:22px;right:22px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 15px;font-size:13px;box-shadow:0 4px 16px #0000001f;animation:slideIn .3s ease;min-width:200px}.toast.success{border-color:#22c55e66}.toast.error{border-color:#ef444466;color:var(--danger)}.toast.info{border-color:#5b6af566}.toast.warn{border-color:#f59e0b8c;color:#b45309;background:#fef3c7f2}@keyframes slideIn{0%{transform:translate(40px);opacity:0}to{transform:translate(0);opacity:1}}.notif-wrap{position:relative;display:inline-block}.notif-btn{position:relative}.notif-badge{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;border:2px solid #134e4a}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:340px;max-height:440px;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;box-shadow:0 10px 32px #0000002e;z-index:900;overflow:hidden;display:flex;flex-direction:column;color:var(--ink)}.notif-header{padding:12px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;background:#f8fafc}.notif-count{color:var(--muted);font-size:11px;font-weight:600}.notif-list{overflow-y:auto;flex:1}.notif-empty{padding:24px 16px;text-align:center;color:var(--muted);font-size:12px}.notif-item{padding:10px 14px;border-bottom:1px solid var(--line);display:flex;gap:10px;align-items:flex-start}.notif-item:last-child{border-bottom:0}.notif-tag{display:inline-flex;align-items:center;font-size:10px;font-weight:700;padding:3px 7px;border-radius:4px;border:1px solid;white-space:nowrap;flex-shrink:0}.notif-body{flex:1;min-width:0}.notif-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:3px}.notif-meta{font-size:11px;color:var(--muted)}.deadline-tag{font-weight:700}.recurring-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:16px}.recurring-form,.recurring-list{display:flex;flex-direction:column;gap:8px}.rform-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}.rf-label{font-size:11px;font-weight:600;color:var(--muted);margin-top:6px}.rf-input{padding:8px 10px;border:1px solid var(--border);border-radius:6px;font-size:12px;background:var(--surface);font-family:inherit}.rf-input:focus{outline:none;border-color:var(--accent)}.rf-row{display:flex;gap:6px}.rf-weekdays{display:flex;gap:4px}.rf-wd{flex:1;padding:7px 0;font-size:11px;font-weight:700;border:1px solid var(--border);border-radius:6px;background:var(--surface);cursor:pointer;font-family:inherit;color:var(--text)}.rf-wd.active{background:var(--accent);color:#fff;border-color:var(--accent)}.rf-actions{display:flex;gap:6px;margin-top:10px}.rec-row{display:flex;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);align-items:center}.rec-info{flex:1;min-width:0}.rec-name{font-size:13px;font-weight:700;color:var(--text)}.rec-meta{font-size:11px;color:var(--muted);margin-top:2px}.rec-actions{display:flex;gap:4px;flex-shrink:0}.rec-actions button{padding:4px 8px;font-size:11px}.rec-actions button.del{color:var(--danger)}@media (max-width: 768px){.recurring-layout{grid-template-columns:1fr}}.perf-shell{padding:14px;max-height:78vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.perf-toolbar{background:var(--surface2);padding:10px 12px;border-radius:8px}.perf-toolbar-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.perf-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.perf-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px;border-left-width:3px}.perf-card.tone-blue{border-left-color:#0ea5e9}.perf-card.tone-green{border-left-color:#22c55e}.perf-card.tone-indigo{border-left-color:#5b6af5}.perf-card.tone-red{border-left-color:#ef4444}.perf-card.warn{background:#ef44440a;border-color:#fecaca}.perf-card.gold{background:#facc150f;border-color:#fcd34d}.perf-card-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase}.perf-card-value{font-size:24px;font-weight:800;color:var(--text);margin-top:4px}.perf-card-sub{font-size:13px;color:var(--muted);font-weight:600}.perf-charts{display:grid;grid-template-columns:1fr 1fr;gap:10px}.perf-chart-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.perf-chart-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:8px}.perf-chart{width:100%;height:auto}.perf-legend{display:flex;gap:12px;margin-top:4px;font-size:10px;color:var(--muted)}.perf-legend i{display:inline-block;width:10px;height:10px;border-radius:2px;margin-right:4px;vertical-align:middle}.perf-analysis{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.perf-analysis-row{display:flex;gap:6px;flex-wrap:wrap}.perf-pill{padding:5px 10px;border-radius:99px;font-size:11px;font-weight:700;border:1px solid}.perf-pill.green{background:#22c55e1a;color:#15803d;border-color:#22c55e4d}.perf-pill.yellow{background:#eab3081f;color:#a16207;border-color:#eab30859}.perf-pill.red{background:#ef44441a;color:#b91c1c;border-color:#ef44444d}.perf-pill.gray{background:#94a3b81f;color:#475569;border-color:#94a3b859}.perf-table{width:100%;border-collapse:collapse;font-size:11px}.perf-table th{text-align:left;padding:6px 8px;background:var(--surface2);color:var(--muted);font-weight:600;font-size:10px;text-transform:uppercase;border-bottom:1px solid var(--border)}.perf-table td{padding:6px 8px;border-bottom:1px solid var(--line)}.perf-table tr.low{background:#ef44440a}.perf-table tr.high{background:#facc150d}.perf-table tr:hover{background:#5b6af50a}.perf-ai-body{font-size:12px;color:var(--text);line-height:1.7;padding:10px 12px;background:#5b6af50a;border-radius:6px;margin-top:8px;white-space:pre-wrap}@media (max-width: 900px){.perf-cards,.perf-charts{grid-template-columns:1fr 1fr}}.inactivity-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1400;display:flex;align-items:center;justify-content:center;padding:20px}.inactivity-card{background:#fff;border-radius:14px;padding:28px 32px;max-width:420px;text-align:center;box-shadow:0 20px 60px #0000004d}.inactivity-title{font-size:20px;font-weight:800;color:var(--text);margin-bottom:12px}.inactivity-body{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:20px}.inactivity-card .btn-save{width:100%;padding:12px;font-size:14px}.attach-tag{background:#0ea5e91a;color:#0369a1;border:1px solid rgba(14,165,233,.3);font-weight:600;font-size:10px;padding:2px 6px;border-radius:4px;text-decoration:none}.attach-tag:hover{background:#0ea5e933}.meet-link{display:inline-flex;align-items:center;justify-content:center;background:#1a73e8;color:#fff;border-radius:99px;width:18px;height:18px;font-size:10px;text-decoration:none;margin-left:4px;cursor:pointer}.meet-link:hover{background:#1557b0}.tt-card.gcal-card{background:#0000000a;color:#475569;border:1px dashed rgba(148,163,184,.6);text-decoration:none}.tt-card.gcal-card:hover{background:#00000012;border-color:#64748b}.gcal-dot{margin-right:3px}.mt-shell{padding:16px;max-height:75vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.mt-toolbar{display:flex;gap:8px;align-items:center}.mt-list-items{display:flex;flex-direction:column;gap:8px}.mt-list-item{display:flex;gap:10px;padding:12px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:pointer;align-items:center;transition:border-color .15s,box-shadow .15s}.mt-list-item:hover{border-color:var(--accent);box-shadow:0 4px 12px #5b6af51a}.mt-list-title{font-size:14px;font-weight:700;color:var(--text)}.mt-list-summary{font-size:11px;color:var(--muted);margin-top:4px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.mt-editor{display:flex;flex-direction:column;gap:8px}.mt-mode-row{display:flex;gap:6px}.mt-voice{display:flex;flex-direction:column;gap:8px}.mt-voice-bar{display:flex;align-items:center;gap:10px}.mt-rec-dot{width:10px;height:10px;border-radius:99px;background:#ef4444;animation:mt-pulse 1s infinite}@keyframes mt-pulse{0%,to{opacity:.4}50%{opacity:1}}.mt-interim{padding:8px 10px;background:#5b6af50f;border-left:2px solid var(--accent);font-size:12px;color:var(--muted);font-style:italic;border-radius:4px}.mt-transcript{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:12px;line-height:1.6;resize:vertical;min-height:180px}.mt-transcript-view{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:11px;line-height:1.6;white-space:pre-wrap;background:var(--surface2);padding:10px 12px;border-radius:6px;max-height:260px;overflow-y:auto;color:var(--text)}.mt-file{display:flex;flex-direction:column;gap:8px}.mt-actions{display:flex;gap:8px;margin-top:10px}.mt-result{display:flex;flex-direction:column;gap:10px;margin-top:12px}.mt-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px 14px}.mt-card-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:6px}.mt-card-body{font-size:12.5px;color:var(--text);line-height:1.6}.mt-list{margin:4px 0 4px 18px;font-size:12px;color:var(--text);line-height:1.7}.mt-action-table{width:100%;border-collapse:collapse;font-size:12px}.mt-action-table th{text-align:left;padding:6px 8px;background:var(--surface2);color:var(--muted);font-weight:600;border-bottom:1px solid var(--border);font-size:11px}.mt-action-table td{padding:7px 8px;border-bottom:1px solid var(--line);vertical-align:middle}.mt-action-table tr:last-child td{border-bottom:0}.mt-detail{display:flex;flex-direction:column;gap:10px}.up-wrap{position:relative;width:100%}.up-field{display:flex;flex-wrap:wrap;align-items:center;gap:6px;min-height:40px;padding:6px 8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;cursor:text;transition:border-color .15s,box-shadow .15s}.up-field.focused{border-color:var(--accent);box-shadow:0 0 0 3px #5b6af524}.up-field.disabled{background:var(--surface2);cursor:not-allowed;opacity:.6}.up-wrap.has-error .up-field{border-color:var(--danger)}.up-input{flex:1;min-width:120px;border:0;outline:0;background:transparent;font-size:12.5px;font-family:inherit;color:var(--text);padding:4px 2px}.up-input::-moz-placeholder{color:#9ca3af}.up-input::placeholder{color:#9ca3af}.up-chip{display:inline-flex;align-items:center;gap:6px;padding:3px 4px 3px 3px;background:#5b6af51a;border:1px solid rgba(91,106,245,.3);border-radius:99px;font-size:12px;color:#3730a3;max-width:200px}.up-chip-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.up-chip-remove{width:16px;height:16px;border:0;border-radius:99px;background:#5b6af533;color:#3730a3;font-size:13px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0}.up-chip-remove:hover{background:#5b6af559;color:#fff}.up-avatar{border-radius:99px;background:linear-gradient(135deg,#5b6af5,#7c3aed);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;-o-object-fit:cover;object-fit:cover}.up-avatar.fallback{background:linear-gradient(135deg,#5b6af5,#7c3aed)}.up-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 10px 28px #00000026;z-index:1100;max-height:260px;overflow-y:auto;padding:4px}.up-empty{padding:12px 14px;text-align:center;color:var(--muted);font-size:12px}.up-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:0;border-radius:6px;cursor:pointer;text-align:left;font-family:inherit}.up-item.highlight,.up-item:hover{background:#5b6af514}.up-item-text{flex:1;min-width:0}.up-item-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-item-email{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.up-hint{margin-top:4px;font-size:11px;color:var(--muted)}.approval-btn{position:relative}.approval-shell{padding:16px;max-height:70vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.approval-tabs{display:flex;gap:6px}.approval-tabs .btn-outing.active{background:var(--accent);color:#fff;border-color:var(--accent)}.approval-list{display:flex;flex-direction:column;gap:8px}.approval-row{display:flex;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center}.approval-body{flex:1;min-width:0}.approval-title{font-size:13px;font-weight:700;color:var(--text)}.approval-reason{margin-top:4px;padding:6px 8px;background:#ef44440f;border-left:2px solid var(--danger);font-size:11px;color:#991b1b}.approval-actions{display:flex;gap:6px;flex-shrink:0}.approval-actions .btn-pi-add,.approval-actions .btn-outing{padding:6px 12px;font-size:11px}.design-kanban{padding:16px;max-height:75vh;overflow-y:auto}.dk-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.dk-col{background:var(--surface2);border:1px solid var(--border);border-radius:8px;min-height:320px;transition:border-color .15s,background .15s}.dk-col.over{border-color:var(--accent);background:#5b6af50d}.dk-col-head{padding:10px 12px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;font-size:12px;border-top-left-radius:8px;border-top-right-radius:8px}.dk-col-count{background:#5b6af51f;color:var(--accent);padding:1px 7px;border-radius:99px;font-size:10px;font-weight:700}.dk-col-body{padding:8px;display:flex;flex-direction:column;gap:6px}.dk-empty{text-align:center;color:var(--muted);font-size:11px;padding:10px 0}.dk-card{background:var(--surface);border:1px solid var(--border);border-left:3px solid #db2777;border-radius:6px;padding:8px 10px;cursor:grab;transition:box-shadow .15s,transform .15s}.dk-card:hover{box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.dk-card:active{cursor:grabbing}.dk-card-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:3px}.dk-card-meta{font-size:10px;color:var(--muted)}.dk-card-date{font-size:10px;color:#9ca3af;margin-top:2px}@media (max-width: 1100px){.dk-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.dk-grid{grid-template-columns:repeat(2,1fr)}}.prj-shell{padding:16px;display:flex;flex-direction:column;gap:14px;max-height:70vh;overflow-y:auto}.prj-toolbar{display:flex;justify-content:space-between;align-items:center}.prj-new{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--surface2);border-radius:8px}.prj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.prj-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:8px}.prj-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 6px 18px #5b6af51f}.prj-card-head{display:flex;justify-content:space-between;align-items:center;font-size:13px}.prj-card-desc{font-size:11px;color:var(--muted);min-height:16px}.prj-card-meta{display:flex;flex-wrap:wrap;gap:4px}.prj-team-chip{font-size:10px;font-weight:600;padding:2px 6px;background:#5b6af51a;color:#4338ca;border-radius:4px}.prj-card-pct{font-size:10px;color:var(--muted);text-align:right;font-weight:700}.prj-dday{font-size:10px;font-weight:700;padding:2px 7px;background:#e0e7ff;color:#4338ca;border-radius:99px}.prj-dday.warn{background:#f59e0b33;color:#b45309}.prj-dday.late{background:#ef44442e;color:#b91c1c}.prj-detail-head{display:flex;align-items:center;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}.prj-detail-head>div{flex:1}.prj-kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;padding-top:8px}.prj-col{background:var(--surface2);border:1px solid var(--border);border-radius:8px;overflow:hidden;min-height:240px}.prj-col-head{padding:8px 10px;background:var(--surface);border-top:3px solid var(--border);font-size:12px;display:flex;justify-content:space-between;align-items:center}.prj-col-status{font-size:9px;font-weight:700;padding:2px 6px;color:#fff;border-radius:99px;text-transform:uppercase}.prj-col-body{padding:10px;display:flex;flex-direction:column;gap:4px}.prj-status-row{display:flex;gap:4px}@media (max-width: 900px){.prj-kanban{grid-template-columns:1fr}}.wr-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:16px;padding:16px}.wr-form,.wr-history{display:flex;flex-direction:column;gap:8px}.wr-toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600}.wr-toggle input{width:18px;height:18px}.wr-note{margin-top:14px;padding:10px 12px;background:var(--surface2);border-radius:6px;font-size:11px;color:var(--muted);line-height:1.6}.wr-mono{font-family:ui-monospace,monospace;font-size:11px;color:var(--text)}.wr-row{padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:4px}.wr-row-head{display:flex;justify-content:space-between;font-size:13px}.wr-summary{margin-top:4px;padding:6px 8px;background:var(--surface2);border-radius:4px;font-size:11px;color:var(--text);line-height:1.5}@media (max-width: 768px){.wr-layout{grid-template-columns:1fr}}.ai-panel{position:fixed;top:0;right:0;bottom:0;width:460px;max-width:100vw;background:#fff;box-shadow:-8px 0 40px #0003;z-index:1200;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;color:var(--text)}.ai-panel.open{transform:translate(0)}.ai-head{padding:14px 18px;background:linear-gradient(135deg,#134e4a,#0f766e);color:#fff;display:flex;justify-content:space-between;align-items:center}.ai-title{font-size:15px;font-weight:700}.ai-warn{font-size:11px;color:#fde68a;font-weight:600;margin-left:6px}.ai-head .btn-close{background:transparent;border:0;color:#fff;font-size:18px;cursor:pointer}.ai-quick{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:14px;border-bottom:1px solid var(--border);background:#f8fafc}.ai-quick-btn{display:flex;flex-direction:column;align-items:center;gap:4px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 10px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text);transition:all .15s;font-family:inherit}.ai-quick-btn:hover:not(:disabled){border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px #5b6af526}.ai-quick-btn:disabled{opacity:.5;cursor:not-allowed}.ai-quick-icon{font-size:20px}.ai-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.ai-empty{text-align:center;color:var(--muted);padding:32px 16px;font-size:13px}.ai-empty-hint{margin-top:6px;font-size:11px;color:#9ca3af}.ai-msg{padding:12px 14px;border-radius:10px;font-size:13px;line-height:1.6}.ai-msg.user{background:#5b6af514;border:1px solid rgba(91,106,245,.2);align-self:flex-end;max-width:90%}.ai-msg.assistant{background:#fff;border:1px solid var(--border);align-self:flex-start;max-width:100%}.ai-msg.assistant.error{border-color:var(--danger);background:#ef44440a}.ai-msg.assistant.skipped{border-color:#f59e0b;background:#f59e0b0f}.ai-skeleton{display:flex;flex-direction:column;gap:6px}.ai-skel-line{height:10px;border-radius:4px;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:aiskel 1.5s infinite}.ai-skel-line.short{width:60%}@keyframes aiskel{0%{background-position:200% 0}to{background-position:-200% 0}}.ai-md-h{font-size:14px;font-weight:700;margin:10px 0 6px;color:#134e4a}.ai-md-p{margin:4px 0}.ai-md-list{margin:4px 0 8px 18px}.ai-md-list li{margin-bottom:3px}.ai-md-space{height:4px}.ai-input{display:flex;gap:6px;padding:12px 14px;border-top:1px solid var(--border);background:#f8fafc}.ai-input input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:13px;font-family:inherit}.ai-input input:focus{outline:none;border-color:var(--accent)}.ai-input .btn-pi-add{padding:0 18px}@media (max-width: 768px){.ai-panel{width:100vw}.ai-quick{grid-template-columns:1fr 1fr}}.role-badge{display:inline-flex;align-items:center;justify-content:center;font-weight:800;border-radius:99px;letter-spacing:.2px;white-space:nowrap;flex-shrink:0}.role-badge.role-size-sm{font-size:10px;padding:2px 8px}.role-badge.role-size-md{font-size:12px;padding:4px 12px}.role-master{background:#ef444426;color:#dc2626;border:1px solid rgba(239,68,68,.3)}.role-leader{background:#3b82f626;color:#2563eb;border:1px solid rgba(59,130,246,.3)}.role-member{background:#6b728026;color:#6b7280;border:1px solid rgba(107,114,128,.3)}.app-header .role-badge.role-master{background:#ef444440;color:#fecaca;border-color:#fca5a580}.app-header .role-badge.role-leader{background:#3b82f640;color:#bfdbfe;border-color:#93c5fd80}.app-header .role-badge.role-member{background:#ffffff26;color:#ffffffd9;border-color:#ffffff40}.users-table{width:100%;border-collapse:collapse;font-size:12px}.users-table th,.users-table td{padding:10px 8px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.users-table th{background:var(--surface2);color:var(--muted);font-weight:700;font-size:11px}.users-table tr:hover td{background:#5b6af50a}.users-table select{padding:6px 8px;font-size:12px;min-width:90px}.install-banner{position:fixed;left:50%;transform:translate(-50%);bottom:20px;z-index:80;background:linear-gradient(135deg,#134e4a,#0f766e);color:#fff;border-radius:14px;padding:12px 14px;box-shadow:0 12px 40px #00000040;display:flex;align-items:center;gap:12px;max-width:min(560px,calc(100% - 24px));animation:slideUp .25s ease}.install-banner-icon{font-size:22px;flex-shrink:0}.install-banner-text{flex:1;font-size:12.5px;line-height:1.5;color:#fffffff2}.install-banner-text b{color:#5eead4;font-weight:700}.install-banner-btn{background:#fff;color:#0f766e;border:none;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:700;cursor:pointer;flex-shrink:0;transition:all .15s}.install-banner-btn:hover{background:#ecfeff;transform:translateY(-1px)}.install-banner-btn.secondary{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.25)}.install-banner-btn.secondary:hover{background:#fff3}@media (max-width: 640px){.install-banner{bottom:76px;left:12px;right:12px;max-width:none;transform:none;flex-wrap:wrap}.install-banner-text{flex:1 1 100%;order:-1}}.mobile-tabbar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:8px 6px;z-index:40;justify-content:space-around;box-shadow:0 -2px 10px #0000000f}.mobile-tabbar button{background:none;border:none;font-size:10px;color:var(--muted);cursor:pointer;padding:4px 8px;line-height:1.4;text-align:center;flex:1}.mobile-tabbar button.active{color:var(--accent);font-weight:700}.mob-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:60;display:flex;justify-content:flex-end;animation:fadeIn .15s ease}.mob-menu-panel{background:var(--surface);width:280px;max-width:80%;height:100%;padding:20px;display:flex;flex-direction:column;gap:4px;overflow-y:auto;animation:slideLeft .25s ease}@keyframes slideLeft{0%{transform:translate(40px)}to{transform:translate(0)}}.mob-menu-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:12px;font-size:14px;font-weight:700}.mob-menu-user{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:10px 14px;margin-bottom:12px}.mob-menu-panel button{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;text-align:left;font-size:13px;color:var(--text);cursor:pointer;transition:all .15s}.mob-menu-panel button:hover{border-color:var(--accent);color:var(--accent)}.mob-menu-panel button.red:hover{border-color:var(--danger);color:var(--danger)}.mob-menu-divider{height:1px;background:var(--border);margin:4px 0}@media (max-width: 768px){.app-header{padding:8px 14px;flex-wrap:nowrap}.progress-wrap{display:none}.header-right{display:none!important}.mob-hamburger{display:flex}.date-badge,.user-chip span{display:none}.app-body{flex-direction:column;padding:0 0 56px;overflow:auto}.panel-personal,.panel-team-timeline{border-right:none;border-bottom:1px solid var(--border);display:none}.panel-personal.mob-active,.panel-team-timeline.mob-active{display:flex}.panel-right{position:fixed;bottom:56px;left:0;right:0;top:auto;width:100%;max-height:60vh;z-index:150;overflow-y:auto;box-shadow:0 -4px 20px #00000026;border-left:none;border-top:1px solid var(--border)}.mobile-tabbar{display:flex}.modal-backdrop{padding:0}.modal-card{max-height:100%;height:100%;border-radius:0;max-width:100%}.modal-card.wide{max-width:100%}.toast-wrap{bottom:76px;left:12px;right:12px}.toast{min-width:0;text-align:center}}.guide-page{--bg: #0f1117;--surface: #1a1d27;--surface2: #222536;--border: #2e3248;--text: #e8eaf0;--muted: #7b82a0;--accent: #5b6af5;--accent2: #7c3aed;--success: #22c55e;--warn: #f59e0b;--danger: #ef4444;--new: #a855f7;background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,Apple SD Gothic Neo,sans-serif;font-size:14px;line-height:1.7}.guide-page .hero{background:linear-gradient(135deg,#1a1d27,#16192a,#1a1d27);border-bottom:1px solid var(--border);padding:56px 24px 48px;text-align:center}.guide-page .hero-badge{display:inline-block;background:#5b6af526;color:var(--accent);border:1px solid rgba(91,106,245,.3);border-radius:20px;padding:4px 14px;font-size:12px;font-weight:700;letter-spacing:.5px;margin-bottom:16px}.guide-page .hero h1{font-size:32px;font-weight:800;margin-bottom:10px;color:var(--text)}.guide-page .hero h1 span{color:var(--accent)}.guide-page .hero p{color:var(--muted);font-size:15px}.guide-page .hero-updated{margin-top:14px;font-size:11px;color:var(--muted)}.guide-page .new-tag{display:inline-block;background:var(--new);color:#fff;border-radius:4px;padding:1px 7px;font-size:10px;font-weight:800;vertical-align:middle;margin-left:6px;letter-spacing:.3px}.guide-page .guide-nav{position:sticky;top:0;z-index:100;background:#0f1117f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:0 24px;display:flex;gap:0;overflow-x:auto}.guide-page .guide-nav a{color:var(--muted);text-decoration:none;padding:14px 16px;font-size:13px;font-weight:600;white-space:nowrap;border-bottom:2px solid transparent;transition:all .2s}.guide-page .guide-nav a:hover{color:var(--text);border-bottom-color:var(--accent)}.guide-page .guide-container{max-width:860px;margin:0 auto;padding:40px 24px 80px}.guide-page .section{margin-bottom:56px}.guide-page .section-title{font-size:20px;font-weight:800;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:10px;color:var(--text)}.guide-page .section-title .icon{font-size:22px}.guide-page .cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.guide-page .card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px}.guide-page .card-title{font-size:13px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:6px;color:var(--text)}.guide-page .card p{font-size:13px;color:var(--muted);line-height:1.65}.guide-page .card.highlight{border-color:#a855f766;background:#a855f70d}.guide-page .card.highlight .card-title{color:#c084fc}.guide-page .steps{display:flex;flex-direction:column;gap:12px}.guide-page .step{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px}.guide-page .step-num{background:var(--accent);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;margin-top:1px}.guide-page .step-body{flex:1}.guide-page .step-title{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--text)}.guide-page .step-desc{font-size:12px;color:var(--muted)}.guide-page .table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}.guide-page table{width:100%;border-collapse:collapse}.guide-page th{background:var(--surface2);padding:11px 16px;font-size:12px;font-weight:700;color:var(--muted);text-align:left}.guide-page td{padding:11px 16px;font-size:13px;border-top:1px solid var(--border);color:var(--text)}.guide-page tr:hover td{background:var(--surface2)}.guide-page .badge{display:inline-block;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:700}.guide-page .badge-blue{background:#3b82f626;color:#60a5fa}.guide-page .badge-purple{background:#a855f726;color:#c084fc}.guide-page .badge-green{background:#22c55e26;color:#4ade80}.guide-page .badge-yellow{background:#eab30826;color:#fbbf24}.guide-page .badge-orange{background:#f9731626;color:#fb923c}.guide-page .badge-red{background:#ef444426;color:#f87171}.guide-page .tip{background:#5b6af514;border:1px solid rgba(91,106,245,.2);border-radius:10px;padding:14px 16px;font-size:13px;color:var(--muted);margin-top:14px}.guide-page .tip strong{color:var(--accent)}.guide-page .master-box{background:linear-gradient(135deg,#5b6af514,#7c3aed14);border:1px solid rgba(91,106,245,.3);border-radius:14px;padding:20px 22px}.guide-page .master-title{font-size:14px;font-weight:800;color:#a5b4fc;margin-bottom:14px}.guide-page code{background:var(--surface2);padding:1px 6px;border-radius:4px;font-size:12px;color:var(--accent)}.guide-page .guide-footer{text-align:center;padding:32px;color:var(--muted);font-size:12px;border-top:1px solid var(--border)}@media (max-width: 600px){.guide-page .hero h1{font-size:24px}.guide-page .cards{grid-template-columns:1fr}.guide-page .guide-nav a{padding:12px 10px;font-size:12px}}
