.gantt-container{--blue: #1a7dc4;--blue-dark: #155f96;--blue-light: #e8f3fb;--blue-mid: #b8d9f0;--red: #d9232d;--red-light: #fdecea;--orange: #ea6c00;--orange-lt: #fff4e6;--green: #16a34a;--green-lt: #dcfce7;--yellow: #d97706;--bg: #ffffff;--surface: #f4f8fc;--border: #dce8f3;--text: #1a2233;--text-muted: #7a90a8;--text-dim: #4a6070;--row-h: 48px;--header-h: 84px;--sidebar-w: 680px;--day-w: 24px;--shadow: 0 2px 12px rgba(26,125,196,.1);--shadow-lg: 0 8px 32px rgba(26,125,196,.15);font-size:14px;color:var(--text);background:var(--bg);min-height:600px;display:flex;flex-direction:column;position:relative;border-radius:12px;overflow:hidden;box-shadow:0 4px 15px #0000000d;border:1px solid var(--border)}.gantt-container *{box-sizing:border-box}.g-topbar{position:sticky;top:0;z-index:100;background:#fff;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 20px;height:64px;box-shadow:var(--shadow)}.g-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}.g-proj-info-wrap{display:flex;flex-direction:column;gap:2px;cursor:pointer;padding:4px 8px;border-radius:8px;border:1.5px solid transparent;transition:all .15s}.g-proj-info-wrap:hover{border-color:var(--blue-mid);background:var(--blue-light)}.g-proj-info-wrap:hover .g-edit-hint{opacity:1}.g-proj-name-display{font-weight:700;font-size:15px;color:var(--text)}.g-proj-meta-display{font-size:11px;color:var(--text-muted)}.g-edit-hint{font-size:10px;color:var(--blue);opacity:0;transition:opacity .15s;font-weight:700}.g-spacer{flex:1}.g-stat-pill{display:flex;align-items:center;gap:7px;padding:6px 13px;background:var(--surface);border:1.5px solid var(--border);border-radius:20px;font-size:12px;font-weight:700;color:var(--text-dim);white-space:nowrap}.g-stat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.g-btn{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:13px;font-weight:700;transition:all .18s;display:flex;align-items:center;gap:6px;white-space:nowrap}.g-btn-primary{background:var(--blue);color:#fff;box-shadow:0 2px 8px #1a7dc440}.g-btn-primary:hover{background:var(--blue-dark);transform:translateY(-1px)}.g-btn-secondary{background:var(--surface);color:var(--blue);border:1.5px solid var(--blue-mid)}.g-btn-secondary:hover{background:var(--blue-light)}.g-btn-save{background:#7c3aed;color:#fff;border:none;box-shadow:0 2px 8px #7c3aed40}.g-btn-save:hover{background:#6d28d9;transform:translateY(-1px)}.g-btn-excel{background:#1d6f42;color:#fff;border:none;box-shadow:0 2px 8px #1d6f4240}.g-btn-excel:hover{background:#155233;transform:translateY(-1px);box-shadow:0 4px 14px #1d6f4259}.g-btn-ghost{background:transparent;color:var(--text-dim);border:1.5px solid var(--border)}.g-btn-ghost:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.g-btn-danger{background:var(--red);color:#fff}.g-btn-danger:hover{background:#b91c1c}.g-btn-sm{padding:5px 12px;font-size:12px}.g-toolbar{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--surface);border-bottom:1.5px solid var(--border);flex-wrap:wrap}.g-search-box{display:flex;align-items:center;gap:8px;padding:7px 12px;background:#fff;border:1.5px solid var(--border);border-radius:8px;flex:0 0 240px;transition:border-color .18s}.g-search-box:focus-within{border-color:var(--blue)}.g-search-box input{background:none;border:none;color:var(--text);font-size:13px;outline:none;width:100%;font-weight:600}.g-search-box input::placeholder{color:var(--text-muted);font-weight:400}.g-filter-tag{padding:5px 13px;border-radius:20px;background:#fff;border:1.5px solid var(--border);font-size:12px;font-weight:700;color:var(--text-dim);cursor:pointer;transition:all .15s;white-space:nowrap}.g-filter-tag.active{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.g-filter-tag:hover:not(.active){border-color:var(--blue-mid);color:var(--blue)}.g-view-toggle{display:flex;background:#fff;border:1.5px solid var(--border);border-radius:8px;overflow:hidden}.g-view-btn{padding:6px 14px;border:none;background:none;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:700;transition:all .15s}.g-view-btn.active{background:var(--blue);color:#fff}.g-legend{display:flex;align-items:center;gap:12px;padding:7px 20px;background:#fff;border-bottom:1.5px solid var(--border);flex-wrap:wrap}.g-legend-item{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--text-dim)}.g-legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.g-main{display:flex;height:600px;overflow:hidden}.g-hscroll-strip{display:flex;align-items:center;height:18px;border-top:1.5px solid var(--border);background:var(--surface);margin-bottom:46px}.g-hscroll-sidebar-spacer{width:var(--sidebar-w);min-width:var(--sidebar-w);height:100%;border-right:2px solid var(--border);background:var(--surface);flex-shrink:0}.g-hscroll-track-wrap{flex:1;overflow-x:auto;overflow-y:hidden;height:100%;scrollbar-width:auto;scrollbar-color:var(--blue) var(--blue-light)}.g-hscroll-track-wrap::-webkit-scrollbar{height:18px}.g-hscroll-track-wrap::-webkit-scrollbar-track{background:var(--blue-light);border-radius:0}.g-hscroll-track-wrap::-webkit-scrollbar-thumb{background:var(--blue);border-radius:9px;border:4px solid var(--blue-light)}.g-hscroll-track-wrap::-webkit-scrollbar-thumb:hover{background:var(--blue-dark)}.g-hscroll-inner{height:1px}.g-sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);overflow-y:auto;overflow-x:hidden;border-right:2px solid var(--border);background:#fff;scrollbar-width:thin;scrollbar-color:var(--blue-mid) transparent}.g-sidebar-header{display:grid;grid-template-columns:1fr 190px 68px 68px 48px;align-items:center;height:var(--header-h);padding:0 14px;border-bottom:2px solid var(--border);position:sticky;top:0;z-index:10;background:var(--surface);font-size:11px;color:var(--blue-dark);text-transform:uppercase;letter-spacing:.05em;gap:6px;font-weight:700}.g-task-row{display:grid;grid-template-columns:1fr 190px 68px 68px 48px;align-items:center;height:var(--row-h);padding:0 14px;border-bottom:1px solid var(--border);gap:6px;cursor:pointer;transition:background .12s}.g-task-row:hover{background:var(--blue-light)}.g-task-row.phase-row{background:var(--surface);border-bottom:1.5px solid var(--blue-mid)}.g-task-row.phase-row:hover{background:var(--blue-light)}.g-task-name{display:flex;align-items:center;gap:7px;min-width:0}.g-task-name-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px;font-weight:600}.g-phase-label{font-weight:800!important;color:var(--blue)!important;font-size:14px!important}.g-indent{width:16px;min-width:16px;border-left:2px solid var(--blue-mid);height:22px}.g-cat-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.g-prog-cell{display:flex;flex-direction:column;gap:4px;justify-content:center;padding:2px 0}.g-prog-top{display:flex;align-items:center;gap:5px}.g-prog-actual{font-size:12px;font-weight:700;min-width:32px}.g-prog-sep{font-size:10px;color:var(--text-muted)}.g-prog-exp{font-size:10px;color:var(--text-muted);min-width:28px}.g-gap-badge{font-size:10px;font-weight:700;padding:1px 5px;border-radius:4px;margin-left:auto;white-space:nowrap}.g-gap-ahead{color:var(--green);background:var(--green-lt)}.g-gap-behind{color:var(--orange);background:var(--orange-lt)}.g-gap-late{color:var(--red);background:var(--red-light)}.g-gap-done{color:var(--green);background:var(--green-lt)}.g-gap-ns{color:var(--text-muted);background:var(--surface)}.g-prog-bar-wrap{position:relative;height:7px;border-radius:4px;background:var(--border);overflow:visible}.g-prog-bar-actual{position:absolute;top:0;left:0;height:100%;border-radius:4px 0 0 4px;transition:width .4s}.g-prog-bar-exp-marker{position:absolute;top:-2px;bottom:-2px;width:2px;border-radius:1px;background:var(--text-dim);opacity:.7}.g-date-col{font-size:12px;color:var(--text-dim);white-space:nowrap;font-weight:600}.g-days-badge{font-size:12px;color:var(--text-muted);text-align:right;font-weight:700}.g-chart-area{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--blue-mid) transparent}.g-chart-inner{min-width:max-content}.g-chart-header{height:var(--header-h);position:sticky;top:0;z-index:10;background:var(--surface);border-bottom:2px solid var(--border)}.g-month-row{display:flex;border-bottom:1px solid var(--border);height:38px}.g-month-cell{border-right:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--blue);font-weight:700;letter-spacing:.04em}.g-day-row{display:flex;height:46px}.g-day-cell{border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;background:#fff}.g-day-cell.today{background:#fff5f5;border-right:2px solid var(--red)}.g-day-cell.today .g-day-num{color:var(--red);font-weight:800}.g-day-cell.weekend{background:var(--surface)}.g-day-cell .g-day-num{font-size:11px;font-weight:700;color:var(--text-dim)}.g-day-cell .g-day-name{font-size:9px;color:var(--text-muted);text-transform:uppercase}.g-chart-rows{position:relative}.g-chart-row{height:var(--row-h);display:flex;align-items:center;position:relative;border-bottom:1px solid var(--border)}.g-chart-row.phase-bg{background:var(--surface)}.g-chart-row:hover .g-row-hover{opacity:1}.g-row-hover{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;transition:opacity .12s;background:#1a7dc40a;pointer-events:none}.g-day-grid-line{position:absolute;top:0;bottom:0;width:1px;background:#dce8f3cc;pointer-events:none}.g-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--red);opacity:.5;z-index:5;pointer-events:none}.g-gantt-bar{position:absolute;height:28px;border-radius:7px;top:50%;transform:translateY(-50%);cursor:pointer;transition:filter .15s,box-shadow .15s;display:flex;align-items:center;overflow:visible;box-shadow:0 2px 6px #0000001f}.g-gantt-bar:hover{filter:brightness(1.07);box-shadow:0 4px 14px #0000002e}.g-bar-track{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:7px;overflow:hidden}.g-bar-fill-actual{height:100%;border-radius:7px 0 0 7px;background:#ffffff61;pointer-events:none;transition:width .4s}.g-bar-expected-marker{position:absolute;top:3px;bottom:3px;width:2px;background:#fff;opacity:.85;border-radius:1px;pointer-events:none;box-shadow:0 0 0 1px #0000002e}.g-bar-label{position:absolute;left:8px;font-size:11px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.45);max-width:calc(100% - 16px)}.g-bar-ahead{box-shadow:0 2px 6px #0000001f,0 0 0 2px #16a34a80}.g-bar-behind{box-shadow:0 2px 6px #0000001f,0 0 0 2px #ea6c0080}.g-bar-late{box-shadow:0 2px 6px #0000001f,0 0 0 2px #d9232d99}.g-bar-done{box-shadow:0 2px 6px #0000001f,0 0 0 2px #16a34ab3}.g-bar-notstarted{opacity:.65}.g-stats-bar{position:absolute;bottom:0;left:0;right:0;height:46px;background:#fff;border-top:2px solid var(--border);display:flex;align-items:center;gap:20px;padding:0 20px;z-index:50;font-size:11px;box-shadow:0 -2px 12px #1a7dc412}.g-stat-item{display:flex;align-items:center;gap:7px}.g-stat-label{color:var(--text-muted)}.g-stat-value{color:var(--text);font-weight:700}.g-overall-progress{display:flex;align-items:center;gap:10px;margin-left:auto}.g-overall-bar{width:150px;height:7px;background:var(--border);border-radius:4px;overflow:hidden}.g-overall-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--blue),#3a9de4);transition:width .5s}.g-tooltip{position:fixed;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;font-size:12px;pointer-events:none;z-index:300;opacity:0;transition:opacity .15s;max-width:300px;box-shadow:var(--shadow-lg)}.g-tooltip.show{opacity:1}.g-tooltip-title{font-weight:700;margin-bottom:9px;color:var(--blue);font-size:13px;border-bottom:1px solid var(--border);padding-bottom:7px}.g-tooltip-row{display:flex;justify-content:space-between;gap:16px;margin-bottom:5px}.g-tooltip-key{color:var(--text-muted);font-weight:600}.g-tooltip-val{color:var(--text);font-weight:700}.g-tooltip-status{margin-top:8px;padding:5px 10px;border-radius:6px;font-weight:700;font-size:12px;text-align:center}.g-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a223366;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}.g-modal-overlay.open{opacity:1;pointer-events:all}.g-modal{background:#fff;border:1.5px solid var(--border);border-radius:16px;padding:28px;width:520px;max-width:95vw;transform:translateY(16px);transition:transform .2s;box-shadow:var(--shadow-lg)}.g-modal-overlay.open .g-modal{transform:translateY(0)}.g-modal-title{font-size:18px;font-weight:800;margin-bottom:20px;display:flex;align-items:center;gap:10px;color:var(--blue)}.g-modal-title:before{content:"";width:4px;height:22px;background:var(--blue);border-radius:2px;flex-shrink:0}.g-progress-hint{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border-radius:10px;margin-bottom:14px;font-size:13px;font-weight:700;border:1.5px solid}.g-hint-ahead{background:var(--green-lt);border-color:#86efac;color:var(--green)}.g-hint-behind{background:var(--orange-lt);border-color:#fdba74;color:var(--orange)}.g-hint-late{background:var(--red-light);border-color:#fca5a5;color:var(--red)}.g-hint-done{background:var(--green-lt);border-color:#86efac;color:var(--green)}.g-hint-ns{background:var(--surface);border-color:var(--border);color:var(--text-muted)}.g-form-group{margin-bottom:14px}.g-form-group label{display:block;font-size:10px;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.g-form-group input,.g-form-group select,.g-form-group textarea{width:100%;background:#fff;border:1.5px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-size:13px;font-weight:600;outline:none;transition:border-color .15s;font-family:inherit}.g-form-group textarea{resize:vertical;min-height:60px}.g-form-group input:focus,.g-form-group select:focus,.g-form-group textarea:focus{border-color:var(--blue)}.g-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.g-modal-actions{display:flex;gap:10px;margin-top:22px;align-items:center}.g-cat-list{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;max-height:280px;overflow-y:auto}.g-cat-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;transition:border-color .12s}.g-cat-item:hover{border-color:var(--blue-mid)}.g-cat-color-swatch{width:28px;height:28px;border-radius:6px;flex-shrink:0;border:2px solid rgba(0,0,0,.1);cursor:pointer;padding:0;background:none}.g-cat-color-swatch::-webkit-color-swatch-wrapper{padding:0}.g-cat-color-swatch::-webkit-color-swatch{border:none;border-radius:4px}.g-cat-name-input{flex:1;border:none;background:transparent;font-size:14px;font-weight:700;color:var(--text);outline:none}.g-cat-name-input:focus{color:var(--blue)}.g-cat-del-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px;transition:all .12s;font-size:16px;display:flex;align-items:center;justify-content:center;width:28px;height:28px}.g-cat-del-btn:hover{color:var(--red);background:var(--red-light)}.g-add-cat-row{display:flex;gap:8px;align-items:center}.g-color-input{width:44px;height:36px;padding:0;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;background:#fff;overflow:hidden}.g-color-input::-webkit-color-swatch-wrapper{padding:0}.g-color-input::-webkit-color-swatch{border:none;border-radius:6px}/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.relative{position:relative}.static{position:static}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.table{display:table}.table-header-group{display:table-header-group}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.underline{text-decoration-line:underline}.outline{outline-style:var(--tw-outline-style);outline-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,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}input.no-arrows::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input.no-arrows::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input.no-arrows{-moz-appearance:textfield}*{box-sizing:border-box;margin:0;padding:0;font-family:Inter,sans-serif}body{color:#1e293b;background-color:#f1f5f9;overflow:hidden}#root{width:100%;height:100vh;display:flex}.sidebar{color:#1e293b;background-color:#9e9e9e;border-right:1px solid #cbd5e1;flex-direction:column;flex-shrink:0;width:380px;padding:30px 20px;display:flex}.logo-text-area{text-align:center;cursor:default;margin-bottom:30px}.logo-main{color:#0071bc;letter-spacing:1px;font-family:Montserrat,sans-serif;font-size:26px;font-weight:900;line-height:1;display:block}.logo-sub{color:#475569;letter-spacing:4px;text-transform:uppercase;margin-top:5px;font-family:Montserrat,sans-serif;font-size:12px;font-weight:700;display:block}.btn-confirm{color:#fff;cursor:pointer;background:#0071bc;border:none;border-radius:8px;justify-content:center;align-items:center;gap:10px;width:100%;padding:12px 25px;font-weight:700;transition:all .3s;display:flex}.btn-confirm:hover{background:#005a96}.search-container{margin-top:20px;margin-bottom:20px;position:relative}.search-input{color:#1e293b;background-color:#fff;border:1px solid #cbd5e1;border-radius:8px;outline:none;width:100%;padding:12px 12px 12px 40px;font-size:13px;transition:all .2s}.search-input:focus{border-color:#0071bc}.search-input::placeholder{color:#94a3b8}.sidebar-title{color:#1e293b;margin-bottom:15px;padding-left:5px;font-size:14px;font-weight:700}.project-list-wrapper{flex-grow:1;max-height:600px;overflow-y:auto}.project-list-wrapper::-webkit-scrollbar{width:6px}.project-list-wrapper::-webkit-scrollbar-track{background:0 0}.project-list-wrapper::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.project-list{list-style:none}.project-list li{cursor:pointer;background-color:#fff;border-left:4px solid #0000;border-radius:8px;flex-direction:column;gap:5px;margin-bottom:10px;padding:15px;transition:all .2s;display:flex;position:relative;box-shadow:0 1px 3px #0000000d}.project-list li.active{background-color:#f8fafc;border-left-color:#0071bc;box-shadow:0 2px 5px #0000001a}.p-name-row{justify-content:space-between;align-items:flex-start;display:flex}.p-name{color:#1e293b;align-items:center;gap:10px;font-size:14px;font-weight:700;display:flex}.p-name i{color:#0071bc;font-size:16px}.p-firm{color:#64748b;padding-left:26px;font-size:12px;font-weight:600}.p-date{color:#94a3b8;margin-top:2px;padding-left:26px;font-size:11px;font-weight:500}.delete-btn{color:#cbd5e1;cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.delete-btn:hover{color:#ef4444}.edit-btn{color:#cbd5e1;cursor:pointer;background:0 0;border:none;padding:0;font-size:12px}.edit-btn:hover{color:#0ea5e9}.main-content{flex:1;padding:30px 40px;overflow-y:auto}.header-section{background:#fff;border-left:6px solid #0071bc;border-radius:12px;justify-content:space-between;align-items:flex-start;margin-bottom:20px;padding:25px 30px;display:flex;position:relative;box-shadow:0 2px 4px #0000000d}.currency-top-bar{color:#64748b;text-align:right;margin-bottom:10px;font-size:12px;font-weight:600}.total-box{text-align:right;flex-direction:column;align-items:flex-end;display:flex}.val-current{color:#0071bc;margin-top:10px;font-size:32px;font-weight:800;line-height:1}.val-label{color:#64748b;text-transform:uppercase;margin-top:5px;font-size:11px;font-weight:600}.summary-row{color:#475569;justify-content:flex-end;gap:10px;margin-bottom:5px;font-size:12px;font-weight:600;display:flex}.summary-label{text-transform:uppercase}.summary-value{color:#1e293b;font-weight:700}.custom-dropdown{-webkit-user-select:none;user-select:none;width:100%;position:relative}.dropdown-selected{cursor:pointer;color:#334155;background:#fff;border:1px solid #e2e8f0;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.dropdown-selected.open{border-color:#0071bc;box-shadow:0 0 0 3px #0071bc1a}.dropdown-list{z-index:100;background:#fff;border:1px solid #e2e8f0;border-radius:8px;animation:.2s ease-out slideDown;position:absolute;top:calc(100% + 5px);left:0;right:0;overflow:hidden;box-shadow:0 4px 15px #0000001a}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{color:#334155;cursor:pointer;padding:10px 14px;font-size:13px;font-weight:500}.dropdown-item:hover{color:#0071bc;background:#f8fafc}.form-card{background:#fff;border-radius:12px;margin-bottom:20px;padding:25px 30px;box-shadow:0 2px 4px #0000000d}input{color:#334155;border:1px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:13px;font-weight:500}input:focus{border-color:#0071bc;box-shadow:0 0 0 3px #0071bc1a}label{color:#64748b;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.material-group{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;overflow:visible;box-shadow:0 2px 4px #0000000d}.group-head{background:#fff;border-bottom:1px solid #e2e8f0;border-top-left-radius:12px;border-top-right-radius:12px;justify-content:space-between;align-items:center;padding:20px 25px;display:flex}.group-head h4{align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.group-total-container{text-align:right}.group-total-val{font-size:18px;font-weight:800}.group-total-label{color:#94a3b8;text-transform:uppercase;margin-top:2px;font-size:10px;font-weight:600}table{border-collapse:collapse;width:100%}th{text-align:left;color:#64748b;text-transform:uppercase;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:15px 25px;font-size:11px;font-weight:700}td{color:#334155;vertical-align:top;border-bottom:1px solid #f1f5f9;padding:15px 25px;font-size:13px;font-weight:600}.sub-text{color:#94a3b8;margin-top:4px;font-size:11px;font-weight:500;display:block}.sub-text-colored{margin-top:4px;font-size:11px;font-weight:500;display:block}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a80;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal{background:#fff;border-top:6px solid #0071bc;border-radius:16px;width:480px;padding:30px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h3{color:#1e293b;font-size:18px;font-weight:700}.close-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:0;font-size:24px;line-height:1}.close-btn:hover{color:#ef4444}.modal input,.modal select,.modal textarea{background-color:#fff}.modal input:disabled{background-color:#f1f5f9!important}.group-colors{--c1:#0071bc;--c2:#10b981;--c3:#f59e0b;--c4:#ef4444;--c5:#8b5cf6}.btn-secondary{color:#334155;cursor:pointer;white-space:nowrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.btn-secondary:hover{background:#f1f5f9}.btn-cancel{color:#475569;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;justify-content:center;align-items:center;gap:10px;padding:12px 25px;font-weight:700;transition:all .3s;display:flex}.btn-cancel:hover{color:#1e293b;background:#e2e8f0}@media print{*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important}body{background-color:#fff;overflow:visible}#root{height:auto;display:block;overflow:visible}.no-print{display:none!important}.print-wrapper{padding:0!important}}.pdf-mode-wrapper{background-color:#f8fafc;width:100%;height:100vh;overflow-y:auto}.print-wrapper{padding:40px 20px}@media print{.pdf-mode-wrapper{background-color:#0000;height:auto;overflow-y:visible}}.pdf-page{color:#000;background-color:#fff;background-image:repeating-linear-gradient(#0000 0,#0000 296.5mm,#ef444480 296.5mm,#ef444480 297mm);width:210mm;min-height:297mm;margin:0 auto;padding:4px;font-family:Inter,sans-serif;box-shadow:0 0 10px #0000001a}@media print{.pdf-page{width:210mm;box-shadow:none;background-image:none;min-height:auto;margin:0 auto;padding:4px}@page{size:a4 portrait;margin:0}table{page-break-inside:auto}tr{page-break-inside:avoid;page-break-after:auto}thead{display:table-header-group}tfoot{display:table-footer-group}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
