/*! tailwindcss v4.2.4 | 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-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--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;--text-xs:.75rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #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}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.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}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.break-all{word-break:break-all}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,)}.underline{text-decoration-line:underline}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-\[var\(--primary\)\]{--tw-ring-color:var(--primary)}.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))}}:root{--primary:#4f46e5;--primary-hover:#4338ca;--primary-active:#3730a3;--primary-light:#eef2ff;--primary-fg:#fff;--bg:#fafaf9;--surface:#fff;--surface-hover:#f5f5f4;--surface-muted:#f5f5f4;--border:#e7e5e4;--border-strong:#d6d3d1;--text:#1c1917;--text-muted:#57534e;--text-subtle:#78716c;--text-placeholder:#a8a29e;--text-inverse:#fff;--success:#16a34a;--success-light:#dcfce7;--success-fg:#14532d;--warning:#d97706;--warning-light:#fef3c7;--warning-fg:#78350f;--danger:#dc2626;--danger-light:#fee2e2;--danger-fg:#7f1d1d;--info:#2563eb;--info-light:#dbeafe;--info-fg:#1e3a8a;--sidebar-width:240px;--header-height:56px;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", "Consolas", monospace;--text-xs:.6875rem;--text-sm:.8125rem;--text-base:.9375rem;--text-lg:1.0625rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--weight-normal:400;--weight-medium:500;--weight-semibold:600;--weight-bold:700;--leading-none:1;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--sp-1:.25rem;--sp-2:.5rem;--sp-3:.75rem;--sp-4:1rem;--sp-5:1.25rem;--sp-6:1.5rem;--sp-8:2rem;--sp-10:2.5rem;--sp-12:3rem;--sp-16:4rem;--radius-sm:.1875rem;--radius-md:.3125rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-full:9999px;--shadow-xs:0 1px 2px 0 #0000000a;--shadow-sm:0 1px 3px 0 #0000000f, 0 1px 2px -1px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000a;--shadow-lg:0 10px 15px -3px #00000012, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--z-raised:10;--z-dropdown:100;--z-sticky:200;--z-sidebar:300;--z-overlay:400;--z-modal:500;--z-toast:600;--t-fast:.12s ease;--t-base:.2s ease;--t-slow:.3s ease}html.dark{--primary:#818cf8;--primary-hover:#a5b4fc;--primary-active:#c7d2fe;--primary-light:#1e1b4b;--primary-fg:#1c1917;--bg:#1c1917;--surface:#292524;--surface-hover:#44403c;--surface-muted:#3c3830;--border:#44403c;--border-strong:#57534e;--text:#f5f5f4;--text-muted:#d6d3d1;--text-subtle:#a8a29e;--text-placeholder:#57534e;--text-inverse:#1c1917;--success:#4ade80;--success-light:#14532d;--success-fg:#a7f3d0;--warning:#fbbf24;--warning-light:#78350f;--warning-fg:#fde68a;--danger:#f87171;--danger-light:#7f1d1d;--danger-fg:#fecaca;--info:#60a5fa;--info-light:#1e3a8a;--info-fg:#bfdbfe;--shadow-xs:0 1px 2px 0 #0000004d;--shadow-sm:0 1px 3px 0 #0006, 0 1px 2px -1px #0000004d;--shadow-md:0 4px 6px -1px #00000073, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #00000059;--shadow-xl:0 20px 25px -5px #0000008c, 0 8px 10px -6px #0006}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:110%}body{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text);background:var(--bg);line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}img,svg{display:block}ul,ol{list-style:none}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--border);height:100%;z-index:var(--z-sidebar);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-brand{align-items:center;gap:var(--sp-3);padding:0 var(--sp-4);height:var(--header-height);border-bottom:1px solid var(--border);flex-shrink:0;display:flex}.sidebar-logo{background:var(--primary);border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex;overflow:hidden}.sidebar-brand-name{font-weight:var(--weight-semibold);font-size:var(--text-sm);color:var(--text);letter-spacing:-.01em}.sidebar-nav{padding:var(--sp-3) var(--sp-2);flex-direction:column;flex:1;gap:1px;display:flex;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.nav-section{margin-bottom:var(--sp-1)}.nav-section-label{font-size:10px;font-weight:var(--weight-semibold);color:var(--text-placeholder);text-transform:uppercase;letter-spacing:.07em;padding:var(--sp-3) var(--sp-3) var(--sp-1);display:block}.nav-item{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-muted);cursor:pointer;transition:background var(--t-fast),color var(--t-fast);-webkit-user-select:none;user-select:none;text-align:left;background:0 0;border:none;width:100%;min-height:34px;text-decoration:none;display:flex}.nav-item:hover{background:var(--surface-hover);color:var(--text)}.nav-item.active{background:var(--primary-light);color:var(--primary)}.nav-item.active .nav-icon{color:var(--primary)}.nav-icon{width:16px;height:16px;color:var(--text-placeholder);transition:color var(--t-fast);flex-shrink:0}.nav-item:hover .nav-icon{color:var(--text)}.nav-label{flex:1}.nav-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:var(--weight-bold);border-radius:var(--radius-full);margin-left:auto;padding:1px 5px;line-height:1.4}.nav-badge-muted{background:var(--border);color:var(--text-subtle);font-size:10px;font-weight:var(--weight-medium);border-radius:var(--radius-full);margin-left:auto;padding:1px 5px;line-height:1.4}.nav-divider{background:var(--border);height:1px;margin:var(--sp-2)}.sidebar-footer{border-top:1px solid var(--border);padding:var(--sp-3);flex-shrink:0}.main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.header{height:var(--header-height);background:var(--surface);border-bottom:1px solid var(--border);padding:0 var(--sp-5);align-items:center;gap:var(--sp-4);z-index:var(--z-sticky);flex-shrink:0;display:flex}.header-start{align-items:center;gap:var(--sp-3);display:flex}.header-page-title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text);white-space:nowrap}.header-search{flex:1;max-width:440px;margin:0 auto;position:relative}.header-search input{width:100%;height:34px;padding:0 var(--sp-4) 0 2.25rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--text);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.header-search input::placeholder{color:var(--text-placeholder)}.header-search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);background:var(--surface)}.search-icon{color:var(--text-placeholder);pointer-events:none;width:14px;height:14px;position:absolute;top:50%;left:.65rem;transform:translateY(-50%)}.header-end{align-items:center;gap:var(--sp-2);margin-left:auto;display:flex}.header-avatar-wrap{display:inline-flex;position:relative}.header-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:140px;z-index:var(--z-dropdown);padding:var(--sp-1);position:absolute;top:calc(100% + 8px);right:0}.btn{justify-content:center;align-items:center;gap:var(--sp-2);padding:0 var(--sp-4);border-radius:var(--radius-md);height:34px;font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast);white-space:nowrap;line-height:1;font-family:var(--font-sans);border:1px solid #0000;flex-shrink:0;text-decoration:none;display:inline-flex}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--primary);color:var(--primary-fg)}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--surface-hover)}.btn-ghost{color:var(--text-muted);background:0 0}.btn-ghost:hover{background:var(--surface-hover);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-danger-ghost{color:var(--danger);background:0 0}.btn-danger-ghost:hover{background:var(--danger-light)}.btn-icon{width:34px;height:34px;padding:0}.btn-sm{height:30px;padding:0 var(--sp-3);font-size:var(--text-xs)}.btn-sm.btn-icon{width:30px;height:30px}.btn-lg{height:42px;padding:0 var(--sp-6);font-size:var(--text-base)}.avatar{border-radius:var(--radius-full);font-weight:var(--weight-semibold);background:var(--primary-light);color:var(--primary);cursor:default;-webkit-user-select:none;user-select:none;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:clip}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-xs{width:24px;height:24px;font-size:9px}.avatar-sm{width:28px;height:28px;font-size:10px}.avatar-md{width:32px;height:32px;font-size:var(--text-xs)}.avatar-lg{width:40px;height:40px;font-size:var(--text-sm)}.avatar-xl{width:56px;height:56px;font-size:var(--text-lg)}.avatar-amber{color:#d97706;background:#fef3c7}.avatar-green{color:#16a34a;background:#dcfce7}.avatar-rose{color:#dc2626;background:#fee2e2}.avatar-sky{color:#0284c7;background:#e0f2fe}.avatar-violet{color:#7c3aed;background:#ede9fe}.avatar-teal{color:#0f766e;background:#ccfbf1}.avatar-orange{color:#c2410c;background:#ffedd5}.avatar-pink{color:#be185d;background:#fce7f3}.avatar-slate{color:#334155;background:#f1f5f9}.avatar-indigo{background:var(--primary-light);color:var(--primary)}.avatar-group{display:flex}.avatar-group .avatar{border:2px solid var(--surface);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.avatar.avatar-ring-indigo{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #4f46e5}.avatar.avatar-ring-amber{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #d97706}.avatar.avatar-ring-rose{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #dc2626}.avatar.avatar-ring-sky{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #0284c7}.avatar.avatar-ring-green{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #16a34a}.avatar.avatar-ring-teal{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #0f766e}.avatar.avatar-ring-violet{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #7c3aed}html.dark .avatar.avatar-ring-indigo{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #818cf8}html.dark .avatar.avatar-ring-amber{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #fbbf24}html.dark .avatar.avatar-ring-rose{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #f87171}html.dark .avatar.avatar-ring-sky{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #38bdf8}html.dark .avatar.avatar-ring-green{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #4ade80}html.dark .avatar.avatar-ring-teal{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #2dd4bf}html.dark .avatar.avatar-ring-violet{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #a78bfa}.avatar.avatar-ring-orange{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #ea580c}.avatar.avatar-ring-pink{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #db2777}.avatar.avatar-ring-slate{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #64748b}html.dark .avatar.avatar-ring-orange{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #fb923c}html.dark .avatar.avatar-ring-pink{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #f472b6}html.dark .avatar.avatar-ring-slate{box-shadow:0 0 0 2px var(--surface),0 0 0 5px #94a3b8}html.dark .avatar-amber{color:#fbbf24;background:#451a03}html.dark .avatar-green{color:#4ade80;background:#14532d}html.dark .avatar-rose{color:#f87171;background:#7f1d1d}html.dark .avatar-sky{color:#38bdf8;background:#0c4a6e}html.dark .avatar-violet{color:#c4b5fd;background:#2e1065}html.dark .avatar-teal{color:#2dd4bf;background:#134e4a}html.dark .avatar-orange{color:#fed7aa;background:#431407}html.dark .avatar-pink{color:#fbcfe8;background:#500724}html.dark .avatar-slate{color:#cbd5e1;background:#1e293b}.icon-btn-wrap{display:inline-flex;position:relative}.icon-btn-wrap .dot-badge{background:var(--danger);border-radius:var(--radius-full);border:2px solid var(--surface);pointer-events:none;width:7px;height:7px;position:absolute;top:5px;right:5px}.content{flex:1;overflow:hidden auto}.content::-webkit-scrollbar{width:6px}.content::-webkit-scrollbar-track{background:0 0}.content::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.content::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.page{padding:var(--sp-6);max-width:1400px}.page-header{justify-content:space-between;align-items:flex-start;gap:var(--sp-4);margin-bottom:var(--sp-5);flex-wrap:wrap;display:flex}.page-title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text);letter-spacing:-.02em;line-height:var(--leading-tight)}.page-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--sp-1)}.page-actions{align-items:center;gap:var(--sp-2);flex-shrink:0;display:flex}.toolbar{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-4);flex-wrap:wrap;display:flex}.toolbar-left{align-items:center;gap:var(--sp-2);flex-wrap:wrap;flex:1;display:flex}.toolbar-right{align-items:center;gap:var(--sp-2);flex-shrink:0;display:flex}.tabs{border-bottom:1px solid var(--border);margin-bottom:var(--sp-5);gap:0;display:flex}.tab-item{padding:var(--sp-2) var(--sp-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-muted);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tab-item:hover{color:var(--text)}.tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}.tabs-pill{background:var(--surface-muted);border-radius:var(--radius-lg);border-bottom:none;gap:2px;margin-bottom:0;padding:3px;display:flex}.tabs-pill .tab-item{border-radius:var(--radius-md);padding:4px var(--sp-3);font-size:var(--text-xs);border:none;height:auto;margin:0}.tabs-pill .tab-item.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs);border-color:#0000}.view-toggle{background:var(--surface-muted);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.view-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-placeholder);cursor:pointer;transition:background var(--t-fast),color var(--t-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.view-btn:hover{color:var(--text)}.view-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-xs)}@media(max-width:1200px){.filter-panel .filter-grid{grid-template-columns:repeat(3,1fr)!important}}@media(max-width:768px){.filter-panel .filter-grid{grid-template-columns:1fr 1fr!important}}.disattivati-link{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;transition:color var(--t-fast),background var(--t-fast);text-decoration:none;display:inline-flex}.disattivati-link:hover{color:var(--text);background:var(--surface-hover)}.filter-chip{align-items:center;gap:var(--sp-2);padding:3px var(--sp-3);background:var(--primary-light);color:var(--primary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-medium);cursor:default;display:inline-flex}.filter-chip-remove{cursor:pointer;opacity:.6;transition:opacity var(--t-fast);color:inherit;background:0 0;border:none;padding:0;line-height:0;display:flex}.filter-chip-remove:hover{opacity:1}.table-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}table{border-collapse:collapse;width:100%}th{padding:var(--sp-2) var(--sp-4);text-align:left;font-size:11px;font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg);-webkit-user-select:none;user-select:none}th.sortable{cursor:pointer}th.sortable:hover{color:var(--text)}td{padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);color:var(--text);border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{cursor:pointer;transition:background var(--t-fast)}tbody tr:hover{background:var(--surface-hover)}.td-link{color:var(--text);font-weight:var(--weight-medium);text-decoration:none}.td-link:hover{text-decoration:underline}.table-footer{padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--border);background:var(--bg);font-size:var(--text-xs);color:var(--text-muted);justify-content:space-between;align-items:center;display:flex}html.dark th{background:var(--surface-hover)}html.dark .table-footer{background:var(--surface)}.drag-handle{color:var(--text-placeholder);opacity:.4;cursor:grab;transition:opacity var(--t-fast);align-items:center;display:flex}tr:hover .drag-handle{opacity:1}.sort-icon{margin-left:var(--sp-1);vertical-align:middle;opacity:.4;display:inline-flex}th.sorted .sort-icon{opacity:1;color:var(--primary)}.badge{padding:2px var(--sp-2);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-medium);white-space:nowrap;align-items:center;gap:4px;line-height:1.4;display:inline-flex}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-success{background:var(--success-light);color:var(--success-fg)}.badge-warning{background:var(--warning-light);color:var(--warning-fg)}.badge-danger{background:var(--danger-light);color:var(--danger-fg)}.badge-muted{background:var(--surface-muted);color:var(--text-muted)}.badge-dot:before{content:"";border-radius:var(--radius-full);background:currentColor;flex-shrink:0;width:6px;height:6px}html .status-da-fare{color:#475569;background:#f1f5f9}html .status-in-lavorazione{color:#1d4ed8;background:#dbeafe}html .status-test{color:#6d28d9;background:#ede9fe}html .status-sospeso{color:#d97706;background:#fef3c7}html .status-fatto{color:#15803d;background:#dcfce7}html .status-archiviato{color:#78716c;background:#f5f5f4}html .status-bozza{color:#64748b;background:#f1f5f9}html .status-todo{color:#ea580c;background:#fff7ed}html .status-in-corso{color:#1d4ed8;background:#dbeafe}html .status-in-attesa{color:#d97706;background:#fef3c7}html .status-completato{color:#15803d;background:#dcfce7}html .status-qualificato{color:#0369a1;background:#e0f2fe}html .status-contattato{color:#1d4ed8;background:#dbeafe}html .status-trattativa{color:#6d28d9;background:#ede9fe}html .status-acquisito{color:#15803d;background:#dcfce7}html .status-non-acquisito{color:#dc2626;background:#fee2e2}html .status-disattivato{color:#78716c;background:#f5f5f4}html.dark .status-da-fare{color:#94a3b8;background:#1e293b}html.dark .status-in-lavorazione{color:#93c5fd;background:#1e3a8a}html.dark .status-test{color:#c4b5fd;background:#2e1065}html.dark .status-sospeso{color:#fcd34d;background:#78350f}html.dark .status-fatto{color:#86efac;background:#14532d}html.dark .status-archiviato{color:#a8a29e;background:#3c3530}html.dark .status-bozza{color:#94a3b8;background:#1e293b}html.dark .status-todo{color:#fb923c;background:#431407}html.dark .status-in-corso{color:#93c5fd;background:#1e3a8a}html.dark .status-in-attesa{color:#fcd34d;background:#78350f}html.dark .status-completato{color:#86efac;background:#14532d}html.dark .status-qualificato{color:#7dd3fc;background:#0c4a6e}html.dark .status-contattato{color:#93c5fd;background:#1e3a8a}html.dark .status-trattativa{color:#c4b5fd;background:#2e1065}html.dark .status-acquisito{color:#86efac;background:#14532d}html.dark .status-non-acquisito{color:#fca5a5;background:#7f1d1d}html.dark .status-disattivato{color:#a8a29e;background:#3c3530}.status-btn{all:unset;cursor:pointer;border-radius:var(--radius-full);padding:2px var(--sp-2);font-size:var(--text-xs);font-weight:var(--weight-medium);white-space:nowrap;transition:opacity var(--t-fast);align-items:center;gap:4px;line-height:1.4;display:inline-flex}.status-btn:hover{opacity:.8}.status-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.priority{align-items:center;gap:2px;display:flex}.priority-pip{background:var(--border);border-radius:2px;width:8px;height:8px}.priority-pip.on{background:var(--primary)}.priority-pip.on.warn{background:var(--warning)}.priority-pip.on.hot{background:var(--danger)}.priority-picker-trigger{padding:var(--sp-1) var(--sp-2);margin:calc(-1 * var(--sp-1)) calc(-1 * var(--sp-2));border-radius:var(--radius);cursor:pointer;background:0 0;border:none;align-items:center;display:inline-flex}.priority-picker-trigger:hover{background:var(--surface-hover)}.priority-picker-item{min-width:148px}.priority-picker-label{color:var(--text);font-size:var(--text-sm);flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs)}.card-padded{padding:var(--sp-6)}.card-header{padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--sp-4);display:flex}.card-title{font-weight:var(--weight-semibold);font-size:var(--text-base);color:var(--text)}.card-body{padding:var(--sp-6)}.card-footer{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:var(--sp-3);display:flex}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-5);box-shadow:var(--shadow-xs)}.stat-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--sp-2)}.stat-value{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);letter-spacing:-.02em;line-height:1}.stat-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--sp-1)}.modal-body form{gap:var(--sp-4);flex-direction:column;display:flex}.form-group{gap:var(--sp-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text);line-height:1}.form-label.required:after{content:" *";color:var(--danger)}.form-input,.form-textarea,.form-select{width:100%;padding:0 var(--sp-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);height:36px;font-size:var(--text-sm);color:var(--text);transition:border-color var(--t-fast),box-shadow var(--t-fast);font-family:var(--font-sans);outline:none}.form-textarea{resize:vertical;height:auto;min-height:80px;padding:var(--sp-2) var(--sp-3)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-placeholder)}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-hint{font-size:var(--text-xs);color:var(--text-muted)}.form-error{font-size:var(--text-xs);color:var(--danger)}.form-grid{gap:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}.form-grid-3{gap:var(--sp-4);grid-template-columns:1fr 1fr 1fr;display:grid}.modal-backdrop{z-index:var(--z-overlay);padding:var(--sp-4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1c191780;justify-content:center;align-items:center;display:flex;position:fixed;top:0;right:0;bottom:0;left:0}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:calc(100% - 2rem);max-width:520px;max-height:90vh;z-index:var(--z-modal);flex-direction:column;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.modal-wide{max-width:720px}.modal-narrow{max-width:400px}.modal-header{padding:var(--sp-5) var(--sp-6);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--sp-4);flex-shrink:0;display:flex}.modal-header .btn-icon{width:36px;height:36px;color:var(--text-muted);flex-shrink:0}.modal-title{font-weight:var(--weight-semibold);font-size:var(--text-base);color:var(--text)}.modal-body{padding:var(--sp-6);flex:1;overflow-y:auto}.modal-footer{padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:var(--sp-3);flex-shrink:0;display:flex}.dropdown{display:inline-flex;position:relative}.dropdown-menu{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;z-index:var(--z-dropdown);padding:var(--sp-1)}.dropdown-item{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);color:var(--text);border-radius:var(--radius-md);cursor:pointer;transition:background var(--t-fast);text-align:left;width:100%;font-family:var(--font-sans);background:0 0;border:none;display:flex}.dropdown-item:hover{background:var(--surface-hover)}.dropdown-item.danger{color:var(--danger)}.dropdown-item.danger:hover{background:var(--danger-light)}.dropdown-separator{background:var(--border);height:1px;margin:var(--sp-1) 0}.status-picker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:180px;z-index:var(--z-dropdown);padding:var(--sp-1)}.status-picker-item{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--t-fast);text-align:left;width:100%;font-family:var(--font-sans);font-size:var(--text-sm);background:0 0;border:none;display:flex}.status-picker-item:hover{background:var(--surface-hover)}.empty-state{padding:var(--sp-16) var(--sp-8);text-align:center;justify-content:center;align-items:center;gap:var(--sp-3);flex-direction:column;display:flex}.empty-state-icon{width:40px;height:40px;color:var(--text-placeholder)}.empty-state-title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text)}.empty-state-desc{font-size:var(--text-sm);color:var(--text-muted);max-width:300px;line-height:var(--leading-relaxed)}.skeleton{background:linear-gradient(90deg,var(--border) 25%,var(--surface-muted) 50%,var(--border) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-shimmer;display:inline-block}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skel-text{height:14px}.skel-text-sm{height:11px}.skel-circle{border-radius:var(--radius-full)}.kanban{gap:var(--sp-4);padding-bottom:var(--sp-4);align-items:flex-start;display:flex;overflow-x:auto}.kanban::-webkit-scrollbar{height:6px}.kanban::-webkit-scrollbar-track{background:0 0}.kanban::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.kanban-col{background:var(--bg);border-radius:var(--radius-lg);border:1px solid var(--border);flex:1;min-width:160px;overflow:hidden}.kanban-col-header{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;display:flex}.kanban-col-title{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.kanban-col-count{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-placeholder);background:var(--border);border-radius:var(--radius-full);padding:1px 6px}.kanban-cards{padding:var(--sp-3);gap:var(--sp-2);flex-direction:column;min-height:80px;display:flex}.kanban-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-3);cursor:pointer;transition:box-shadow var(--t-fast);box-shadow:var(--shadow-xs)}.kanban-card:hover{box-shadow:var(--shadow-md)}.kanban-card-title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text);margin-bottom:var(--sp-2);line-height:var(--leading-snug)}.kanban-card-meta{align-items:center;gap:var(--sp-2);flex-wrap:wrap;display:flex}.kanban-col-header.col-bozza{border-top:2px dashed var(--border-strong)}.kanban-col-header.col-da-fare{border-top:2px solid #ea580c}.kanban-col-header.col-in-lav{border-top:2px solid var(--info)}.kanban-col-header.col-sospeso{border-top:2px solid var(--warning-fg)}.kanban-col-header.col-fatto{border-top:2px solid var(--success)}.kanban-col-header.col-violet{border-top:2px solid var(--primary)}.kanban-col-header.col-sky{border-top:2px solid #0369a1}html.dark .kanban-col-header.col-sky{border-top:2px solid #7dd3fc}.kanban-col-header.col-danger{border-top:2px solid var(--danger)}.kanban-col-archived{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:36px;padding:var(--sp-3) 0;align-items:center;gap:var(--sp-3);cursor:default;opacity:.6;transition:opacity var(--t-fast);flex-direction:column;flex-shrink:0;display:flex}.kanban-col-archived:hover{opacity:1}.kanban-col-archived-label{writing-mode:vertical-rl;font-size:10px;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);transform:rotate(180deg)}.kanban-col-archived-count{color:var(--text-placeholder);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);width:20px;height:20px;font-size:10px;font-weight:var(--weight-semibold);justify-content:center;align-items:center;display:flex}.card-client{color:var(--text-muted);background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius-sm);white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:10px;font-weight:var(--weight-medium);padding:1px 6px;overflow:hidden}.card-dates{color:var(--text-muted);align-items:center;gap:3px;font-size:10px;display:flex}.card-dates.overdue{color:var(--danger)}.card-dates.soon{color:var(--warning-fg)}.card-dates.done{color:var(--success)}.kanban-page{padding:var(--sp-6) var(--sp-6) 0;flex-direction:column;flex:1;max-width:none;display:flex;overflow:hidden}.kanban-page .page-header{margin-bottom:0}.kanban-area{padding-bottom:var(--sp-6);margin-top:var(--sp-4);flex:1;overflow:auto hidden}.kanban-area .kanban{align-items:stretch;height:100%;min-height:400px}.kanban-area .kanban-cards{flex:1;overflow-y:auto}.kanban-area .kanban-cards::-webkit-scrollbar{width:4px}.kanban-area .kanban-cards::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--radius-full)}.kanban-area .kanban-col{flex-direction:column;max-height:100%;display:flex;overflow:hidden}.detail-layout{gap:var(--sp-6);grid-template-columns:1fr 280px;align-items:flex-start;display:grid}@media(max-width:1024px){.detail-layout{grid-template-columns:1fr}.detail-sidebar{order:-1}}.detail-breadcrumb a{color:var(--text-muted)}.detail-breadcrumb a:hover{color:var(--text);text-decoration:underline}.detail-title-row{align-items:flex-start;gap:var(--sp-3);margin-bottom:var(--sp-3);display:flex}.detail-title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text);line-height:var(--leading-snug);border-radius:var(--radius-sm);transition:background var(--t-fast);resize:none;background:0 0;border:none;outline:none;flex:1;margin:-2px -6px;padding:2px 6px;font-family:inherit}.detail-title:hover,.detail-title:focus{background:var(--surface-hover)}.detail-meta-row{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-12);flex-wrap:wrap;display:flex}.detail-sidebar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.sidebar-section{padding:var(--sp-4);border-bottom:1px solid var(--border)}.sidebar-section:last-child{border-bottom:none}.sidebar-section-label{font-size:10px;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.07em;color:var(--text-placeholder);margin-bottom:var(--sp-3);display:block}.sidebar-field{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-2) 0;display:flex}.sidebar-field-label{font-size:var(--text-xs);color:var(--text-muted);flex-shrink:0;width:72px;padding-top:2px}.sidebar-field-value{font-size:var(--text-sm);color:var(--text);flex:1}.sidebar-field-value.placeholder{color:var(--text-placeholder);font-style:italic}.sidebar-date{border-radius:var(--radius-sm);height:24px;font-size:var(--text-sm);color:var(--text);font-family:var(--font-sans);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);background:0 0;border:1px solid #0000;outline:none;width:100%;padding:0 4px}.sidebar-date:hover{background:var(--surface-hover);border-color:var(--border)}.sidebar-date:focus{border-color:var(--primary);background:var(--surface-hover)}html.dark input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.task-compact-list{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);overflow:hidden}.task-compact-item{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);color:var(--text);transition:background var(--t-fast);cursor:pointer;display:flex}.task-compact-item:last-child{border-bottom:none}.task-compact-item:hover{background:var(--surface-hover)}.task-compact-name{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.task-compact-name.done{color:var(--text-muted);text-decoration:line-through}.task-due{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;flex-shrink:0}.task-due.overdue{color:var(--danger)}.task-due.soon{color:var(--warning-fg)}.task-list-add{align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);color:var(--text-placeholder);cursor:pointer;border:none;border-top:1px solid var(--border);width:100%;transition:color var(--t-fast),background var(--t-fast);background:0 0;display:flex}.task-list-add:hover{color:var(--primary);background:var(--surface-hover)}.sidebar-assignees{gap:var(--sp-2);flex-direction:column;display:flex}.sidebar-assignee{align-items:center;gap:var(--sp-2);display:flex}.sidebar-assignee-name{font-size:var(--text-sm);color:var(--text);flex:1;min-width:0}.danger-zone{padding:var(--sp-4);gap:var(--sp-2);flex-direction:column;display:flex}.detail-desc{border-radius:var(--radius-lg);width:100%;min-height:80px;padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);font-family:var(--font-sans);color:var(--text);line-height:var(--leading-relaxed);resize:vertical;transition:border-color var(--t-fast),background var(--t-fast);margin-bottom:var(--sp-5);background:0 0;border:1px solid #0000;outline:none}.detail-desc::placeholder{color:var(--text-placeholder)}.detail-desc:hover{border-color:var(--border);background:var(--bg)}.detail-desc:focus{border-color:var(--primary);background:var(--bg);box-shadow:0 0 0 3px var(--primary-light)}.project-compact-list{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-4);overflow:hidden}.project-compact-item{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);color:var(--text);transition:background var(--t-fast);cursor:pointer;text-decoration:none;display:flex}.project-compact-item:last-child{border-bottom:none}.project-compact-item:hover{background:var(--surface-hover)}.project-compact-name{font-size:var(--text-sm);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.project-compact-name.done{color:var(--text-muted)}.project-compact-meta{align-items:center;gap:var(--sp-3);flex-shrink:0;display:flex}.contact-name-row{align-items:center;gap:var(--sp-2);padding:var(--sp-1) 0 var(--sp-2);display:flex}.contact-name-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.contact-field{align-items:center;gap:var(--sp-2);padding:var(--sp-2) 0;font-size:var(--text-sm);color:var(--text);display:flex}.contact-field-icon{color:var(--text-muted);flex-shrink:0}.contact-field a{color:var(--text);transition:color var(--t-fast);text-decoration:none}.contact-field a:hover{color:var(--primary);text-decoration:underline}.assistance-mini{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-3)}.assistance-mini-header{margin-bottom:var(--sp-2);justify-content:space-between;align-items:center;display:flex}.assistance-mini-row{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--sp-2);justify-content:space-between;align-items:center;display:flex}.assistance-mini-row strong{color:var(--text)}.ore-bar{background:var(--border);border-radius:var(--radius-full);height:4px;margin-bottom:var(--sp-2);overflow:hidden}.ore-bar-fill{border-radius:var(--radius-full);background:var(--primary);height:100%}.assistance-mini-link{font-size:var(--text-xs);color:var(--primary);margin-top:var(--sp-1);align-items:center;gap:4px;text-decoration:none;display:inline-flex}.assistance-mini-link:hover{text-decoration:underline}.url-cell{font-size:var(--text-sm);font-family:var(--font-mono);letter-spacing:-.01em}.ore-cell{font-size:var(--text-sm);font-variant-numeric:tabular-nums;white-space:nowrap;align-items:center;gap:4px;display:inline-flex}.ore-ok{color:var(--text)}.ore-warn{color:var(--warning);font-weight:var(--weight-semibold)}.ore-neg{color:var(--danger);font-weight:var(--weight-semibold)}.ore-widget{text-align:center;padding:var(--sp-5) var(--sp-4)}.ore-widget-label{font-size:10px;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.07em;color:var(--text-placeholder);margin-bottom:var(--sp-3);display:block}.ore-widget-number{font-size:42px;font-weight:var(--weight-bold);color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:-.03em;line-height:1}.ore-widget-number.warn{color:var(--warning)}.ore-widget-number.neg{color:var(--danger)}.ore-widget-unit.warn{color:var(--warning)}.ore-widget-unit.neg{color:var(--danger)}.ore-widget-unit{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--text-muted);margin-left:2px}.ore-widget-bar{background:var(--border);border-radius:var(--radius-full);height:6px;margin:var(--sp-3) 0 var(--sp-2);overflow:hidden}.ore-widget-bar-fill{border-radius:var(--radius-full);background:var(--primary);height:100%}.ore-widget-meta{font-size:var(--text-xs);color:var(--text-placeholder);margin-bottom:var(--sp-2);justify-content:space-between;display:flex}.detail-fields-grid{gap:var(--sp-5) var(--sp-6);margin-bottom:var(--sp-6);grid-template-columns:1fr 1fr;display:grid}.detail-field-full{grid-column:1/-1}.detail-field-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-2);display:block}.detail-field-value{font-size:var(--text-sm);color:var(--text)}.detail-inline-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);color:var(--text);width:100%;transition:border-color var(--t-fast);outline:none}.detail-inline-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.detail-inline-input:read-only{opacity:.6;cursor:default}.ore-calcolate{align-items:baseline;gap:var(--sp-2);display:flex}.ore-number-large{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);font-variant-numeric:tabular-nums;line-height:1}.ore-number-large.warn{color:var(--warning)}.ore-number-large.neg{color:var(--danger)}.ore-unit-label{font-size:var(--text-sm);color:var(--text-muted)}.ore-calcolate-note{font-size:var(--text-xs);color:var(--text-placeholder);margin-top:var(--sp-1)}.registro-toolbar{margin-bottom:var(--sp-4);justify-content:space-between;align-items:center;display:flex}.registro-summary{font-size:var(--text-sm);color:var(--text-muted)}.registro-summary strong{color:var(--text)}.registro-add{align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);color:var(--text-placeholder);border:1px dashed var(--border);border-radius:var(--radius-md);cursor:pointer;text-align:left;width:100%;margin-top:var(--sp-3);transition:color var(--t-fast),border-color var(--t-fast);background:0 0;display:flex}.registro-add:hover{color:var(--primary);border-color:var(--primary)}.member-cell{align-items:center;gap:var(--sp-3);display:flex}.member-info-name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.member-info-email{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.role-badge{font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:2px 8px;display:inline-flex}.role-admin{color:var(--primary);background:#4f46e51f}.role-membro{background:var(--surface-muted);color:var(--text-subtle)}html.dark .role-admin{color:#a5b4fc;background:#818cf826}.status-membro-attivo{color:#15803d;background:#16a34a1f}html.dark .status-membro-attivo{color:#4ade80;background:#4ade8026}.status-membro-inattivo{background:var(--surface-muted);color:var(--text-placeholder)}.skills-cell{flex-wrap:nowrap;align-items:center;gap:3px;display:flex}.skill-tag{font-size:10px;font-weight:var(--weight-medium);border-radius:var(--radius-full);background:var(--surface-muted);color:var(--text-subtle);border:1px solid var(--border);white-space:nowrap;align-items:center;padding:1px 6px;display:inline-flex}.skill-more{font-size:var(--text-xs);color:var(--text-placeholder);white-space:nowrap}.tasks-count{font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--text)}.tasks-count.none{color:var(--text-placeholder)}.activity-cell{font-size:var(--text-sm);color:var(--text-muted);white-space:nowrap}.activity-cell.recent{color:var(--text)}.id-chip{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm);white-space:nowrap;letter-spacing:.04em;padding:2px 7px}.freq-badge{font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);white-space:nowrap;align-items:center;padding:2px 8px;display:inline-flex}.freq-on-demand{color:#9333ea;background:#a855f71f}.freq-quotidiana{color:#dc2626;background:#ef44441f}.freq-settimanale{color:var(--primary);background:#4f46e51f}.freq-mensile{color:#0d9488;background:#14b8a61f}.freq-trimestrale{color:#ca8a04;background:#eab3081f}html.dark .freq-on-demand{color:#c084fc;background:#c084fc26}html.dark .freq-quotidiana{color:#f87171;background:#f8717126}html.dark .freq-settimanale{color:#818cf8;background:#818cf826}html.dark .freq-mensile{color:#2dd4bf;background:#2dd4bf26}html.dark .freq-trimestrale{color:#facc15;background:#facc1526}.role-chip{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-subtle);background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-full);white-space:nowrap;padding:2px 8px}.referenti-cell{align-items:center;display:flex}.referenti-cell .avatar{border:2px solid var(--surface);flex-shrink:0;margin-left:-6px}.referenti-cell .avatar:first-child{margin-left:0}.referenti-more{font-size:var(--text-xs);color:var(--text-placeholder);white-space:nowrap;margin-left:6px}.no-referenti{font-size:var(--text-xs);color:var(--text-placeholder);font-style:italic}.task-name-cell{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.summary-bar{gap:var(--sp-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-4) var(--sp-5);margin-bottom:var(--sp-4);flex-wrap:wrap;align-items:center;display:flex}.summary-item{flex-direction:column;gap:2px;display:flex}.summary-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--weight-semibold)}.summary-value{font-size:var(--text-lg);font-weight:var(--weight-semibold);font-variant-numeric:tabular-nums;color:var(--text)}.summary-divider{background:var(--border);flex-shrink:0;width:1px;height:36px}.month-group-row td{background:var(--bg);border-top:2px solid var(--border);padding:var(--sp-2) var(--sp-4)}.month-group-row:first-child td{border-top:none}.month-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:var(--sp-2);display:flex}.month-total{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-subtle);margin-left:auto}.amount{font-family:var(--font-mono);font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--text);white-space:nowrap}.amount-muted{font-family:var(--font-mono);font-size:var(--text-xs);font-variant-numeric:tabular-nums;color:var(--text-placeholder)}.lock-badge{font-size:var(--text-xs);color:var(--text-placeholder);align-items:center;gap:3px;display:inline-flex}.compito-cell{flex-direction:column;gap:2px;display:flex}.compito-name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.compito-meta{font-size:var(--text-xs);color:var(--text-muted)}.num-cell{font-family:var(--font-mono);font-size:var(--text-sm);font-variant-numeric:tabular-nums;text-align:right;color:var(--text)}.num-cell-muted{font-family:var(--font-mono);font-size:var(--text-sm);font-variant-numeric:tabular-nums;text-align:right;color:var(--text-muted)}.month-summary{gap:var(--sp-4);align-items:center;margin-left:auto;display:flex}.month-summary-item{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap}.month-summary-value{font-family:var(--font-mono);font-weight:var(--weight-semibold);color:var(--text)}.member-header{align-items:flex-start;gap:var(--sp-4);margin-bottom:var(--sp-10);display:flex}.member-header-info{flex:1;min-width:0}.member-header-actions{gap:var(--sp-2);flex-shrink:0;padding-top:2px;display:flex}.member-name-heading{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text);line-height:var(--leading-snug)}.member-email-line{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--sp-1)}.member-meta-row{align-items:center;gap:var(--sp-2);margin-top:var(--sp-2);flex-wrap:wrap;display:flex}.tag-list{gap:var(--sp-1);flex-wrap:wrap;align-items:center;display:flex}.tag-chip{font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);background:var(--primary-light);color:var(--primary);align-items:center;gap:3px;padding:2px 8px;display:inline-flex}.tag-chip-role{background:var(--surface-muted);color:var(--text-subtle);border:1px solid var(--border)}.tag-chip-remove{color:inherit;cursor:pointer;opacity:.55;transition:opacity var(--t-fast);background:0 0;border:none;align-items:center;padding:0;line-height:0;display:inline-flex}.tag-chip-remove:hover{opacity:1}.tag-add-btn{font-size:var(--text-xs);color:var(--text-placeholder);border:1px dashed var(--border);border-radius:var(--radius-full);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast);background:0 0;align-items:center;gap:3px;padding:2px 8px;display:inline-flex}.tag-add-btn:hover{color:var(--primary);border-color:var(--primary)}.compiti-list{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-4);overflow:hidden}.compiti-item{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);font-size:var(--text-sm);color:var(--text);display:flex}.compiti-item:last-child{border-bottom:none}.compiti-name{flex:1}.compiti-role{font-size:var(--text-xs);color:var(--text-placeholder);white-space:nowrap}.compiti-add{align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);color:var(--text-placeholder);cursor:pointer;text-align:left;border:none;border-top:1px solid var(--border);width:100%;transition:color var(--t-fast),background var(--t-fast);border-radius:0 0 var(--radius-lg) var(--radius-lg);background:0 0;display:flex}.compiti-add:hover{color:var(--primary);background:var(--surface-hover)}.admin-only-label{font-size:9px;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.06em;color:var(--primary);background:var(--primary-light);border-radius:var(--radius-sm);align-items:center;gap:3px;padding:1px 5px;display:inline-flex}html.dark .admin-only-label{color:#a5b4fc;background:#818cf826}.sidebar-stats{gap:var(--sp-3);grid-template-columns:1fr 1fr;display:grid}.sidebar-stat{text-align:center}.sidebar-stat-value{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--text);font-variant-numeric:tabular-nums;line-height:1}.sidebar-stat-label{font-size:var(--text-xs);color:var(--text-placeholder);margin-top:var(--sp-1)}.alert{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-4);border-radius:var(--radius-lg);font-size:var(--text-sm);border:1px solid;display:flex}.alert-success{background:var(--success-light);color:var(--success-fg);border-color:#86efac}.alert-warning{background:var(--warning-light);color:var(--warning-fg);border-color:#fcd34d}.alert-danger{background:var(--danger-light);color:var(--danger-fg);border-color:#fca5a5}.alert-info{background:var(--info-light);color:var(--info-fg);border-color:#93c5fd}html.dark .alert-success{border-color:#166534}html.dark .alert-warning{border-color:#92400e}html.dark .alert-danger{border-color:#991b1b}html.dark .alert-info{border-color:#1e40af}.divider{background:var(--border);height:1px;margin:var(--sp-6) 0}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);background:var(--text);color:var(--text-inverse);font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-md);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--t-fast);z-index:var(--z-dropdown);padding:4px 8px;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1}.hamburger{border-radius:var(--radius-md);width:34px;height:34px;color:var(--text-muted);cursor:pointer;transition:background var(--t-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:none}.hamburger:hover{background:var(--surface-hover);color:var(--text)}.overlay{z-index:calc(var(--z-sidebar) - 1);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#1c191780;display:none;position:fixed;top:0;right:0;bottom:0;left:0}@media(max-width:1024px){.sidebar{height:100vh;transition:transform var(--t-slow);box-shadow:none;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{box-shadow:var(--shadow-xl);transform:translate(0)}.overlay.active{display:block}.hamburger{display:flex}.header-search{max-width:260px}}@media(max-width:768px){.header-search{display:none}.page{padding:var(--sp-4)}.form-grid,.form-grid-3{grid-template-columns:1fr}}.auth-layout{background:var(--bg);min-height:100vh;padding:var(--sp-6) var(--sp-4);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--sp-8) var(--sp-8);gap:var(--sp-5);box-shadow:var(--shadow-lg);flex-direction:column;display:flex}.auth-logo{background:var(--primary);border-radius:var(--radius-full);color:#fff;width:48px;height:48px;margin-bottom:var(--sp-1);flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.auth-title{font-size:var(--text-xl);font-weight:var(--weight-semibold);color:var(--text);line-height:var(--leading-tight)}.auth-description{font-size:var(--text-sm);color:var(--text-muted);margin-top:calc(var(--sp-5) * -1 + var(--sp-1))}.auth-card form{gap:var(--sp-4);flex-direction:column;display:flex}.auth-links{justify-content:center;gap:var(--sp-4);font-size:var(--text-sm);color:var(--text-muted);display:flex}.auth-links a{color:var(--primary)}.auth-links a:hover{text-decoration:underline}@media(max-width:480px){.auth-card{padding:var(--sp-6) var(--sp-5)}}.comment-list{gap:var(--sp-4);margin-bottom:var(--sp-5);flex-direction:column;display:flex}.comment{gap:var(--sp-3);display:flex}.comment-body{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-3) var(--sp-4);flex:1}.comment-header{align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2);display:flex}.comment-author{font-weight:var(--weight-semibold);font-size:var(--text-sm);color:var(--text)}.comment-time{font-size:var(--text-xs);color:var(--text-placeholder);margin-left:auto}.comment-text{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text)}.comment-text .mention{color:var(--primary);font-weight:var(--weight-medium)}.comment-text p{margin-bottom:var(--sp-2)}.comment-text p:last-child{margin-bottom:0}.comment-text ul,.comment-text ol{margin:var(--sp-1) 0;padding-left:1.25rem}.comment-text li{margin-bottom:2px;list-style:outside}.comment-text a{color:var(--primary);text-decoration:underline}.comment-text strong{font-weight:var(--weight-semibold)}.comment-text em{font-style:italic}.comment-input-row{gap:var(--sp-3);align-items:flex-start;display:flex}.comment-replies{margin-top:var(--sp-3);padding-left:var(--sp-4);border-left:2px solid var(--border);gap:var(--sp-3);flex-direction:column;display:flex}.comment-is-reply .comment-body{background:0 0;padding:0}.comment-reply-editor{margin-top:var(--sp-3)}.rte-compact .rte-toolbar{display:none}.rte-compact .rte-content{min-height:2.5rem;padding:var(--sp-2) var(--sp-3)}.rte-compact .rte-footer{padding:var(--sp-2) var(--sp-3)}.rte{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--t-fast),box-shadow var(--t-fast);overflow:hidden}.rte:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.rte-toolbar{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:1px;display:flex}.rte-sep{background:var(--border);width:1px;height:16px;margin:0 var(--sp-2);flex-shrink:0}.rte-btn{border-radius:var(--radius-sm);width:30px;height:28px;color:var(--text-muted);cursor:pointer;transition:background var(--t-fast),color var(--t-fast);font-family:var(--font-sans);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.rte-btn:hover{background:var(--surface-hover);color:var(--text)}.rte-btn.active{background:var(--primary-light);color:var(--primary)}.rte .ProseMirror{padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--text);outline:none;min-height:80px}.rte .ProseMirror p.is-editor-empty:first-child:before{content:attr(data-placeholder);color:var(--text-placeholder);pointer-events:none;float:left;height:0}.rte .ProseMirror ul{margin:var(--sp-1) 0;padding-left:1.25rem}.rte .ProseMirror li{margin-bottom:2px;list-style:outside}.rte .ProseMirror ol{margin:var(--sp-1) 0;padding-left:1.25rem}.rte .ProseMirror ol li{list-style:decimal}.rte .ProseMirror a{color:var(--primary);text-decoration:underline}.rte .ProseMirror .mention{color:var(--primary);font-weight:var(--weight-medium)}.rte-footer{padding:var(--sp-2) var(--sp-3);border-top:1px solid var(--border);background:var(--surface);justify-content:flex-end;align-items:center;display:flex}.rte-content-preview{line-height:var(--leading-relaxed)}.rte-content-preview p{margin:0}.rte-content-preview ul,.rte-content-preview ol{margin:2px 0;padding-left:1.25rem}.rte-content-preview li{margin-bottom:1px}.rte-content-preview ul li{list-style:outside}.rte-content-preview ol li{list-style:decimal}.rte-content-preview strong{font-weight:var(--weight-semibold)}.rte-content-preview em{font-style:italic}.rte-content-preview a{color:var(--primary);text-decoration:underline}.mention-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);min-width:180px;max-height:200px;overflow:hidden auto}.mention-item{align-items:center;gap:var(--sp-2);width:100%;padding:6px var(--sp-3);font-size:var(--text-sm);color:var(--text);cursor:pointer;text-align:left;font-family:var(--font-sans);background:0 0;border:none;display:flex}.mention-item:hover,.mention-item.selected{background:var(--surface-hover)}.mention-empty{padding:var(--sp-3);font-size:var(--text-xs);color:var(--text-placeholder);text-align:center}.log-list{flex-direction:column;display:flex}.log-item{gap:var(--sp-3);padding:var(--sp-3) 0;border-bottom:1px solid var(--border);display:flex}.log-item:last-child{border-bottom:none}.log-dot{border-radius:var(--radius-full);background:var(--border-strong);flex-shrink:0;width:8px;height:8px;margin-top:5px}.log-text{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-relaxed);flex:1}.log-text strong{color:var(--text);font-weight:var(--weight-medium)}.log-time{font-size:var(--text-xs);color:var(--text-placeholder);white-space:nowrap;flex-shrink:0}.search-bar{flex:1;max-width:360px;position:relative}.search-bar-input{width:100%;height:32px;padding:0 var(--sp-3) 0 var(--sp-8);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:var(--text-sm);font-family:var(--font-sans);transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}.search-bar-input::placeholder{color:var(--text-placeholder)}.search-bar-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.search-bar-icon{left:var(--sp-2);color:var(--text-placeholder);pointer-events:none;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.search-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);z-index:var(--z-dropdown);max-height:320px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden auto}.search-result-item{align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);color:var(--text);cursor:pointer;text-align:left;width:100%;font-family:var(--font-sans);background:0 0;border:none;text-decoration:none;display:flex}.search-result-item:hover{background:var(--surface-hover)}.search-result-type{font-size:10px;font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.06em;color:var(--text-placeholder);flex-shrink:0;width:60px}.search-result-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.search-result-sub{font-size:var(--text-xs);color:var(--text-muted)}.notif-list{flex-direction:column;gap:0;display:flex}.notif-item{gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);background:var(--surface);transition:background var(--t-fast);cursor:default;color:inherit;display:flex;position:relative}.notif-item:first-child{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.notif-item:last-child{border-radius:0 0 var(--radius-lg) var(--radius-lg);border-bottom:none}.notif-item:only-child{border-radius:var(--radius-lg)}.notif-item:hover{background:var(--surface-hover)}.notif-item.unread{cursor:pointer;background:#4f46e50a}html.dark .notif-item.unread{background:#818cf80f}.notif-item.unread:hover{background:#4f46e514}html.dark .notif-item.unread:hover{background:#818cf81a}.unread-dot{top:50%;left:var(--sp-2);border-radius:var(--radius-full);background:var(--primary);flex-shrink:0;width:7px;height:7px;position:absolute;transform:translateY(-50%)}.notif-icon-wrap{border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.notif-icon-task{color:var(--primary);background:#4f46e51f}.notif-icon-mention{color:#0d9488;background:#14b8a61f}.notif-icon-reminder{color:#ca8a04;background:#eab3081f}.notif-icon-overdue{color:var(--danger);background:#ef44441f}.notif-icon-hours{color:#9333ea;background:#a855f71f}.notif-icon-system{background:var(--surface-muted);color:var(--text-subtle)}html.dark .notif-icon-task{color:#818cf8;background:#818cf826}html.dark .notif-icon-mention{color:#2dd4bf;background:#2dd4bf26}html.dark .notif-icon-reminder{color:#facc15;background:#facc1526}html.dark .notif-icon-overdue{color:#f87171;background:#f8717126}html.dark .notif-icon-hours{color:#c084fc;background:#c084fc26}.notif-content{flex:1;min-width:0}.notif-text{font-size:var(--text-sm);color:var(--text);margin-bottom:3px;line-height:1.45}.notif-text strong{font-weight:var(--weight-semibold)}.notif-link{color:var(--primary);font-weight:var(--weight-medium);text-decoration:none}.notif-link:hover{text-decoration:underline}.notif-meta{font-size:var(--text-xs);color:var(--text-placeholder);align-items:center;gap:var(--sp-2);display:flex}.notif-category{font-size:10px;font-weight:var(--weight-medium);color:var(--text-placeholder);background:var(--surface-muted);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:3px;padding:1px 5px;display:inline-flex}.notif-actions{align-items:flex-end;gap:var(--sp-1);flex-direction:column;flex-shrink:0;display:flex}.notif-dismiss-btn{opacity:0;transition:opacity var(--t-fast)}.notif-item:hover .notif-dismiss-btn{opacity:1}.notif-group-header{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;padding:var(--sp-4) 0 var(--sp-2)}.notif-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);overflow:hidden}.filter-tabs-notif{gap:var(--sp-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-full);padding:3px;display:flex}.filter-tab-notif{font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;transition:all var(--t-fast);background:0 0;border:none;padding:4px 12px;font-family:inherit}.filter-tab-notif.active{background:var(--primary);color:#fff}.profile-layout{gap:var(--sp-6);grid-template-columns:1fr 260px;align-items:start;display:grid}@media(max-width:900px){.profile-layout{grid-template-columns:1fr}}.avatar-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-6);align-items:center;gap:var(--sp-3);text-align:center;flex-direction:column;display:flex}.avatar-upload-wrap{cursor:pointer;position:relative}.avatar-upload-btn{border-radius:var(--radius-full);background:var(--primary);color:#fff;border:2px solid var(--surface);cursor:pointer;width:28px;height:28px;transition:background var(--t-fast);justify-content:center;align-items:center;display:flex;position:absolute;bottom:0;right:0}.avatar-upload-btn:hover{background:var(--primary-hover)}.avatar-name{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text)}.avatar-role{font-size:var(--text-sm);color:var(--text-muted)}.avatar-card-divider{background:var(--border);width:100%;height:1px;margin:var(--sp-2) 0}.avatar-meta{width:100%;font-size:var(--text-xs);color:var(--text-muted);text-align:left;gap:var(--sp-2);flex-direction:column;display:flex}.avatar-meta-row{align-items:center;gap:var(--sp-2);display:flex}.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);overflow:hidden}.section-card:last-child{margin-bottom:0}.section-card-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;display:flex}.section-card-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.section-card-body{padding:var(--sp-5)}.form-grid-2{gap:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}@media(max-width:600px){.form-grid-2{grid-template-columns:1fr}}.profile-stats{gap:var(--sp-2);width:100%;margin-top:var(--sp-2);grid-template-columns:1fr 1fr;display:grid}.profile-stat{text-align:center;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-2) var(--sp-3)}.profile-stat-value{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text);line-height:1.2}.profile-stat-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.avatar-color-picker{gap:var(--sp-2);flex-wrap:wrap;justify-content:center;align-items:center;display:flex}.color-swatch{border-radius:var(--radius-full);cursor:pointer;width:22px;height:22px;transition:transform var(--t-fast),border-color var(--t-fast);border:2px solid #0000}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--text);transform:scale(1.15)}.password-hint{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--sp-1)}.email-current-row{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:var(--sp-4);display:flex}.email-current-value{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text);flex:1}.email-pending-banner{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--warning-light);border:1px solid var(--warning);border-radius:var(--radius-md);margin-bottom:var(--sp-4);display:flex}html.dark .email-pending-banner{background:#d977061f;border-color:#d9770666}.email-pending-text{font-size:var(--text-xs);color:var(--warning-fg);flex:1}html.dark .email-pending-text{color:#fcd34d}.email-pending-text strong{margin-bottom:2px;display:block}.notif-table{border-collapse:collapse;width:100%}.notif-table th{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;padding:var(--sp-2) var(--sp-3);text-align:center;border-bottom:1px solid var(--border)}.notif-table th:first-child{text-align:left}.notif-table td{padding:var(--sp-3) var(--sp-3);border-bottom:1px solid var(--border);vertical-align:middle}.notif-table tr:last-child td{border-bottom:none}.notif-table td:not(:first-child){text-align:center}.notif-event-name{font-size:var(--text-sm);color:var(--text)}.notif-event-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.toggle-wrap{align-items:center;gap:var(--sp-2);cursor:pointer;display:inline-flex}.toggle{flex-shrink:0;width:36px;height:20px;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{border-radius:var(--radius-full);background:var(--surface-muted);border:1px solid var(--border);transition:background var(--t-fast),border-color var(--t-fast);position:absolute;top:0;right:0;bottom:0;left:0}.toggle-slider:after{content:"";border-radius:var(--radius-full);width:14px;height:14px;transition:transform var(--t-fast);background:#fff;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0003}.toggle input:checked~.toggle-slider{background:var(--primary);border-color:var(--primary)}.toggle input:checked~.toggle-slider:after{transform:translate(16px)}.toggle input:focus-visible~.toggle-slider{outline:2px solid var(--primary);outline-offset:2px}.toggle input:disabled~.toggle-slider{opacity:.4;cursor:not-allowed}.settings-layout{gap:var(--sp-6);grid-template-columns:220px 1fr;align-items:start;display:grid}@media(max-width:860px){.settings-layout{grid-template-columns:1fr}.settings-sidenav{display:none}}.settings-sidenav{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);top:var(--sp-4);position:sticky;overflow:hidden}.settings-sidenav-header{padding:var(--sp-3) var(--sp-4);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);background:var(--bg)}.settings-sidenav-item{align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;transition:all var(--t-fast);text-align:left;background:0 0;border:none;width:100%;font-family:inherit;text-decoration:none;display:flex}.settings-sidenav-item:hover{background:var(--surface-hover);color:var(--text)}.settings-sidenav-item.active{color:var(--primary);font-weight:var(--weight-medium);background:#4f46e514}html.dark .settings-sidenav-item.active{color:#818cf8;background:#818cf81a}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);overflow:hidden}.settings-section:last-child{margin-bottom:0}.settings-section-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:var(--sp-3);display:flex}.settings-section-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.settings-section-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.settings-section-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:1px}.settings-section-body{padding:var(--sp-5)}.settings-section-footer{padding:var(--sp-4) var(--sp-5);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--sp-3);display:flex}.settings-row{gap:var(--sp-4);margin-bottom:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}.settings-row:last-child{margin-bottom:0}.settings-row.single{grid-template-columns:1fr}.settings-row.triple{grid-template-columns:2fr 1fr 1fr}@media(max-width:600px){.settings-row,.settings-row.triple{grid-template-columns:1fr}}.settings-link{align-items:center;gap:var(--sp-1);font-size:var(--text-sm);color:var(--primary);font-weight:var(--weight-medium);flex-shrink:0;margin-left:auto;text-decoration:none;display:inline-flex}.settings-link:hover{text-decoration:underline}.status-grid{gap:var(--sp-4);grid-template-columns:repeat(3,1fr);display:grid}@media(max-width:700px){.status-grid{grid-template-columns:1fr 1fr}}.status-stat{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-4)}.status-stat-label{font-size:var(--text-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:var(--weight-semibold);margin-bottom:var(--sp-1)}.status-stat-value{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text);font-variant-numeric:tabular-nums}.status-stat-sub{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.status-ok{color:#16a34a}.status-warn{color:#ca8a04}html.dark .status-ok{color:#4ade80}html.dark .status-warn{color:#facc15}.toggle-row{justify-content:space-between;align-items:flex-start;gap:var(--sp-4);padding:var(--sp-3) 0;border-bottom:1px solid var(--border);display:flex}.toggle-row:last-child{border-bottom:none;padding-bottom:0}.toggle-row:first-child{padding-top:0}.toggle-row-info{flex:1}.toggle-row-label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.toggle-row-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.color-swatch-row{align-items:center;gap:var(--sp-3);display:flex}.color-swatch{border-radius:var(--radius-md);border:2px solid var(--border);cursor:pointer;flex-shrink:0;width:32px;height:32px}.secret-field-wrap{position:relative}.secret-field-wrap .form-input{font-family:var(--font-mono);letter-spacing:.1em;padding-right:40px}.secret-reveal-btn{cursor:pointer;color:var(--text-muted);transition:color var(--t-fast);background:0 0;border:none;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.secret-reveal-btn:hover{color:var(--text)}.test-result{align-items:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);display:flex}.test-result.success{color:#16a34a;background:#16a34a1a;border:1px solid #16a34a33}.test-result.error{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}html.dark .test-result.success{color:#4ade80;background:#4ade801a;border-color:#4ade8033}html.dark .test-result.error{color:#f87171;background:#f871711a;border-color:#f8717133}.fallback-banner{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--text-muted);background:#eab30814;border:1px solid #eab30833;display:flex}html.dark .fallback-banner{background:#facc150f;border-color:#facc1526}.enc-tabs{border:1px solid var(--border);border-radius:var(--radius-md);display:flex;overflow:hidden}.enc-tab{padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);background:var(--surface);color:var(--text-muted);cursor:pointer;transition:all var(--t-fast);border:none;flex:1;font-family:inherit}.enc-tab:not(:first-child){border-left:1px solid var(--border)}.enc-tab.active{background:var(--primary);color:#fff;font-weight:var(--weight-medium)}.template-layout{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);grid-template-columns:260px 1fr;gap:0;min-height:500px;display:grid;overflow:hidden}@media(max-width:700px){.template-layout{grid-template-columns:1fr}}.template-list{border-right:1px solid var(--border);max-height:72vh;overflow-y:auto}.template-list-header{padding:var(--sp-3) var(--sp-4);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:var(--sp-2);display:flex;position:sticky;top:0}.template-item{padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t-fast);flex-direction:column;gap:2px;display:flex}.template-item:last-child{border-bottom:none}.template-item:hover{background:var(--surface-hover)}.template-item.active{background:#4f46e514}html.dark .template-item.active{background:#818cf814}.template-item-name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.template-item.active .template-item-name{color:var(--primary)}html.dark .template-item.active .template-item-name{color:#818cf8}.template-item-key{font-size:10px;font-family:var(--font-mono);color:var(--text-placeholder)}.override-dot{border-radius:var(--radius-full);background:var(--primary);flex-shrink:0;width:6px;height:6px;margin-right:4px;display:inline-block}.editor-pane{flex-direction:column;display:flex}.editor-pane-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;gap:var(--sp-3);flex-wrap:wrap;display:flex}.editor-pane-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.editor-pane-subtitle{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.editor-pane-body{grid-template-columns:1fr 200px;display:grid}@media(max-width:900px){.editor-pane-body{grid-template-columns:1fr}.vars-panel{display:none}}.editor-tabs{border-bottom:1px solid var(--border);background:var(--bg);padding:0 var(--sp-5);display:flex}.editor-tab{padding:var(--sp-3) var(--sp-4);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;transition:all var(--t-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-family:inherit}.editor-tab:hover{color:var(--text)}.editor-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:var(--weight-medium)}.code-editor-wrap{flex:1;overflow:hidden}.code-editor{background:var(--bg);resize:none;width:100%;height:380px;font-family:var(--font-mono);color:var(--text);padding:var(--sp-4) var(--sp-5);-moz-tab-size:2;tab-size:2;border:none;outline:none;font-size:12px;line-height:1.6}.plain-text-editor{background:var(--bg);resize:none;width:100%;height:240px;font-family:var(--font-mono);color:var(--text);padding:var(--sp-4) var(--sp-5);border:none;outline:none;font-size:12px;line-height:1.6}.preview-pane{background:var(--bg);height:380px;padding:var(--sp-4) var(--sp-5);overflow-y:auto}.vars-panel{border-left:1px solid var(--border);padding:var(--sp-4);overflow-y:auto}.vars-panel-title{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:var(--sp-3)}.var-chip{font-size:11px;font-family:var(--font-mono);background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-subtle);transition:all var(--t-fast);align-items:center;gap:3px;margin:2px;padding:2px 6px;display:inline-flex}.var-chip:hover{color:var(--primary);border-color:var(--primary);background:#4f46e51a}.var-chip-req{color:var(--primary);background:#4f46e514;border-color:#4f46e533}.editor-footer{padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--sp-3);flex-wrap:wrap;display:flex}.email-preview-mock{border-radius:var(--radius-lg);color:#1a1a1a;background:#fff;max-width:520px;margin:0 auto;font-family:sans-serif;font-size:14px;overflow:hidden;box-shadow:0 2px 8px #00000026}.ep-header{color:#fff;background:#4f46e5;align-items:center;gap:10px;padding:20px 24px;display:flex}.ep-logo{background:#fff3;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.ep-orgname{font-size:15px;font-weight:600}.ep-body{padding:28px 24px}.ep-greeting{margin-bottom:12px;font-size:16px;font-weight:600}.ep-text{color:#444;margin-bottom:12px;font-size:14px;line-height:1.6}.ep-btn{color:#fff;background:#4f46e5;border-radius:6px;padding:11px 22px;font-size:14px;font-weight:600;text-decoration:none;display:inline-block}.ep-footer{color:#888;background:#f9f9f9;border-top:1px solid #eee;padding:14px 24px;font-size:12px}.role-name-cell{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.role-rate-cell{font-family:var(--font-mono);font-size:var(--text-sm);font-variant-numeric:tabular-nums;text-align:right}.role-row-inactive{opacity:.5}.inactive-badge{font-size:10px;font-weight:var(--weight-medium);border-radius:var(--radius-full);background:var(--surface-muted);color:var(--text-placeholder);border:1px solid var(--border);align-items:center;gap:3px;padding:1px 6px;display:inline-flex}.rate-input{width:80px;font-family:var(--font-mono);font-size:var(--text-sm);background:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);text-align:right;padding:3px 6px}.rate-input:focus{outline:2px solid var(--primary);border-color:var(--primary)}.err-page{min-height:100vh;padding:var(--sp-6);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative}.err-brand{top:var(--sp-6);left:var(--sp-6);align-items:center;gap:var(--sp-3);text-decoration:none;display:flex;position:fixed}.err-logo-mark{background:var(--primary);border-radius:var(--radius-xl);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.err-brand-name{font-size:var(--text-base);font-weight:var(--weight-bold);color:var(--text);letter-spacing:-.02em}.error-wrap{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:440px;display:flex}.error-num{font-size:8rem;font-weight:var(--weight-bold);letter-spacing:-.05em;line-height:1;font-family:var(--font-mono);opacity:.1;z-index:0;-webkit-user-select:none;user-select:none;margin-bottom:-3rem;position:relative}.error-404 .error-num{color:var(--primary)}.error-500 .error-num{color:#d97706}.error-icon-wrap{z-index:1;border-radius:var(--radius-full);width:72px;height:72px;margin-bottom:var(--sp-5);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.error-404 .error-icon-wrap{color:var(--primary);background:#4f46e51f}.error-500 .error-icon-wrap{color:#d97706;background:#d977061f}html.dark .error-404 .error-icon-wrap{color:#818cf8;background:#818cf826}html.dark .error-500 .error-icon-wrap{color:#fbbf24;background:#fbbf241f}.error-tag{padding:.2rem var(--sp-3);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold);font-family:var(--font-mono);letter-spacing:.02em;margin-bottom:var(--sp-3);align-items:center;display:inline-flex}.error-404 .error-tag{color:var(--primary);background:#4f46e51a}.error-500 .error-tag{color:#ca8a04;background:#d977061a}html.dark .error-404 .error-tag{color:#a5b4fc;background:#818cf81f}html.dark .error-500 .error-tag{color:#fcd34d;background:#fbbf241a}.error-title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);letter-spacing:-.02em;line-height:var(--leading-tight);margin-bottom:var(--sp-3)}.error-desc{font-size:var(--text-sm);color:var(--text-muted);line-height:var(--leading-relaxed);max-width:360px;margin-bottom:var(--sp-8)}.error-actions{gap:var(--sp-3);flex-wrap:wrap;justify-content:center;display:flex}.error-request-id{margin-top:var(--sp-6);font-size:var(--text-xs);color:var(--text-placeholder);font-family:var(--font-mono)}.checklist-item-row{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:box-shadow 80ms;display:flex}.checklist-item-row:hover{box-shadow:var(--shadow-sm)}.drag-handle{color:var(--text-placeholder);cursor:grab;border-radius:var(--radius-sm);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;padding:2px;display:flex}.drag-handle:hover{color:var(--text-muted);background:var(--surface-2)}.drag-handle:active{cursor:grabbing}.task-checklist-item{align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3) var(--sp-2);border-bottom:1px solid var(--border-light,var(--border));display:flex}.task-checklist-item:last-child{border-bottom:none}.task-checklist-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;margin-top:2px}.task-checklist-item input[type=checkbox]:disabled{cursor:default}.task-checklist-item-title{font-size:var(--text-sm);color:var(--text);font-weight:var(--weight-medium)}.task-checklist-item-title.checked{color:var(--text-muted);text-decoration:line-through}.task-checklist-item-desc{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.audit-log-wrap{overflow-x:auto}.audit-log-table{border-collapse:collapse;width:100%;font-size:var(--text-sm)}.audit-log-table thead tr{border-bottom:1px solid var(--border)}.audit-log-table th{text-align:left;padding:var(--sp-2) var(--sp-3);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-muted);white-space:nowrap}.audit-log-row td{padding:var(--sp-3);border-bottom:1px solid var(--border);vertical-align:middle}.audit-log-row:last-child td{border-bottom:none}.audit-log-ts{white-space:nowrap;color:var(--text-muted);font-size:var(--text-xs);min-width:130px}.audit-log-actor{min-width:140px}.audit-log-action{color:var(--text)}.audit-log-pagination{justify-content:center;align-items:center;gap:var(--sp-3);padding:var(--sp-3) 0;display:flex}.dashboard-page{container-type:inline-size}.kpi-grid{gap:var(--sp-4);margin-bottom:var(--sp-6);grid-template-columns:.85fr 1fr 1fr .85fr 1.15fr;display:grid}@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:600px){.kpi-grid{grid-template-columns:1fr}}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-3) var(--sp-5);box-shadow:var(--shadow-xs);gap:var(--sp-1);flex-direction:column;display:flex}.kpi-header{justify-content:space-between;align-items:center;display:flex}.kpi-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.kpi-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.kpi-icon-info{color:#1d4ed8;background:#dbeafe}.kpi-icon-danger{background:var(--danger-light);color:var(--danger)}.kpi-icon-success{background:var(--success-light);color:var(--success)}.kpi-icon-warning{background:var(--warning-light);color:var(--warning)}.kpi-value{font-size:var(--text-3xl);font-weight:var(--weight-bold);color:var(--text);letter-spacing:-.03em;line-height:1}.kpi-value.danger{color:var(--danger)}.kpi-value.warning{color:var(--warning)}.kpi-value.success{color:var(--success)}.kpi-sub{font-size:var(--text-xs);color:var(--text-muted)}.donut-wrap{align-items:center;gap:var(--sp-4);flex-direction:column;width:100%;display:flex}.donut-center{flex-shrink:0;width:120px;height:120px;position:relative}.donut-center-text{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;top:0;right:0;bottom:0;left:0}.donut-num{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);letter-spacing:-.02em;line-height:1}.donut-num-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:3px}.donut-legend{flex-direction:column;gap:3px;width:100%;display:flex}.legend-item{font-size:var(--text-xs);align-items:center;gap:5px;display:flex}.legend-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.legend-name{color:var(--text-muted);flex:1}.legend-count{font-weight:var(--weight-semibold);color:var(--text);font-variant-numeric:tabular-nums}.legend-pct{color:var(--text-placeholder);text-align:right;min-width:22px;font-size:10px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.panel-header{padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.panel-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.panel-sub{font-size:var(--text-xs);color:var(--text-muted)}.panel-body{padding:var(--sp-5)}.dashboard-bottom-grid{gap:var(--sp-4);margin-bottom:var(--sp-6);grid-template-columns:1fr 280px;display:grid}@media(max-width:1100px){.dashboard-bottom-grid{grid-template-columns:1fr}}@media(max-width:768px){.gantt-section{display:none}}.gantt-svg{width:100%;display:block;overflow:visible}.gantt-label{font-family:var(--font-sans);fill:var(--text);dominant-baseline:middle;font-size:6px}.gantt-month{font-family:var(--font-sans);fill:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:6px;font-weight:600}.deadline-list{flex-direction:column;display:flex}.deadline-item{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t-fast);color:inherit;text-decoration:none;display:flex}.deadline-item:last-child{border-bottom:none}.deadline-item:hover{background:var(--surface-hover)}.deadline-prio{flex-shrink:0;align-items:center;gap:2px;display:flex}.deadline-prio-pip{background:var(--border);border-radius:1.5px;width:7px;height:7px}.deadline-prio-pip.on{background:var(--primary)}.deadline-prio-pip.on.warn{background:var(--warning)}.deadline-prio-pip.on.hot{background:var(--danger)}.deadline-info{flex:1;min-width:0}.deadline-name{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.deadline-client{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;overflow:hidden}.deadline-badge{font-size:11px;font-weight:var(--weight-semibold);border-radius:var(--radius-full);white-space:nowrap;flex-shrink:0;padding:2px 6px}.deadline-badge.urgente{background:var(--danger-light);color:var(--danger)}.deadline-badge.vicino{background:var(--warning-light);color:var(--warning-fg,var(--warning))}.deadline-badge.ok{background:var(--surface-muted,var(--bg));color:var(--text-muted)}.date-picker-wrap{display:inline-flex;position:relative}.period-btn{align-items:center;gap:var(--sp-2);padding:5px var(--sp-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text);cursor:pointer;font-family:var(--font-sans);transition:background var(--t-fast),border-color var(--t-fast);display:inline-flex}.period-btn:hover{background:var(--surface-hover)}.period-btn.open{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.date-picker-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);flex-direction:column;width:580px;display:flex;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden}.dp-body{display:flex}.dp-shortcuts{border-right:1px solid var(--border);width:152px;padding:var(--sp-3) var(--sp-2);flex-direction:column;flex-shrink:0;gap:1px;display:flex}.dp-shortcuts-label{font-size:10px;font-weight:var(--weight-semibold);color:var(--text-placeholder);text-transform:uppercase;letter-spacing:.06em;padding:var(--sp-1) var(--sp-2) var(--sp-2)}.dp-shortcut{padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--text-muted);cursor:pointer;text-align:left;font-family:var(--font-sans);transition:background var(--t-fast),color var(--t-fast);background:0 0;border:none;width:100%}.dp-shortcut:hover{background:var(--surface-hover);color:var(--text)}.dp-shortcut.active{background:var(--primary-light);color:var(--primary);font-weight:var(--weight-medium)}.dp-calendars{padding:var(--sp-4) var(--sp-5);gap:var(--sp-5);flex:1;display:flex}.dp-calendar{flex:1}.dp-cal-header{margin-bottom:var(--sp-3);justify-content:space-between;align-items:center;display:flex}.dp-cal-month{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.dp-cal-nav{border-radius:var(--radius-sm);width:22px;height:22px;color:var(--text-muted);cursor:pointer;transition:background var(--t-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.dp-cal-nav:hover{background:var(--surface-hover);color:var(--text)}.dp-cal-grid{grid-template-columns:repeat(7,1fr);gap:1px;display:grid}.dp-dayname{font-size:10px;font-weight:var(--weight-semibold);color:var(--text-placeholder);text-align:center;padding-bottom:var(--sp-2);text-transform:uppercase}.dp-day{aspect-ratio:1;font-size:var(--text-xs);color:var(--text);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--t-fast);-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex;position:relative}.dp-day.empty{pointer-events:none}.dp-day:not(.empty):not(.in-range):not(.range-start):not(.range-end):hover{background:var(--surface-hover)}.dp-day.in-range{background:var(--primary-light);color:var(--primary);border-radius:0}.dp-day.range-start,.dp-day.range-end{background:var(--primary);color:#fff;font-weight:var(--weight-semibold);border-radius:var(--radius-sm)}.dp-day.range-start{border-radius:var(--radius-md) 0 0 var(--radius-md)}.dp-day.range-end{border-radius:0 var(--radius-md) var(--radius-md) 0}.dp-day.today:not(.range-start):not(.range-end){font-weight:var(--weight-bold);color:var(--primary)}.dp-day.today:not(.range-start):not(.range-end):after{content:"";background:var(--primary);border-radius:50%;width:3px;height:3px;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.dp-day.in-range.row-start{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.dp-day.in-range.row-end{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.dp-divider{background:var(--border);flex-shrink:0;width:1px}.dp-footer{padding:var(--sp-3) var(--sp-5);border-top:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;display:flex}.dp-range-display{align-items:center;gap:var(--sp-2);font-size:var(--text-xs);color:var(--text-muted);display:flex}.dp-range-value{font-weight:var(--weight-semibold);color:var(--text)}.dp-range-days{color:var(--text-placeholder)}.tabs-pill-bar{align-items:center;gap:var(--sp-1);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:fit-content;margin-bottom:var(--sp-5);padding:3px;display:flex}.tab-pill{padding:6px var(--sp-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;color:var(--text-muted);transition:background var(--t-fast),color var(--t-fast),box-shadow var(--t-fast);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;display:flex}.tab-pill:hover{color:var(--text)}.tab-pill.active{background:var(--bg);color:var(--text);box-shadow:0 1px 3px #00000026,0 0 0 1px var(--border)}.proposal-badge{font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:5px;padding:2px 8px;display:inline-flex}.proposal-badge:before{content:"";border-radius:var(--radius-full);flex-shrink:0;width:6px;height:6px}.proposal-draft{color:var(--text-muted);background:#64748b1f}.proposal-draft:before{background:#64748b}.proposal-sent{color:var(--primary);background:#4f46e51f}.proposal-sent:before{background:var(--primary)}.proposal-accepted{color:#15803d;background:#16a34a1f}.proposal-accepted:before{background:#22c55e}.proposal-rejected{color:var(--danger);background:#dc26261f}.proposal-rejected:before{background:var(--danger)}.dark .proposal-draft{color:#94a3b8;background:#64748b2e}.dark .proposal-sent{color:#a5b4fc;background:#818cf82e}.dark .proposal-accepted{color:#4ade80;background:#4ade8021}.dark .proposal-rejected{color:#f87171;background:#f8717126}.filter-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--sp-4);overflow:hidden}.filter-panel-header{padding:var(--sp-3) var(--sp-5);border-bottom:1px solid var(--border);background:var(--bg);justify-content:space-between;align-items:center;display:flex}.filter-panel-title{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.filter-grid{gap:var(--sp-4);padding:var(--sp-4) var(--sp-5);grid-template-columns:repeat(3,1fr);display:grid}@media(max-width:768px){.filter-grid{grid-template-columns:1fr}}.template-actions{gap:var(--sp-2);justify-content:flex-end;display:flex}.settings-cards{gap:var(--sp-5);align-items:flex-start;display:flex}.settings-card-intro{flex:2;min-width:0}.settings-card-firma{flex:1;min-width:240px}@media(max-width:900px){.settings-cards{flex-direction:column}.settings-card-firma{width:100%;min-width:0}}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-5)}.settings-card-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text);margin-bottom:var(--sp-1)}.settings-card-desc{font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--sp-4);line-height:var(--leading-relaxed)}.firma-upload{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:var(--sp-6) var(--sp-4);text-align:center;cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast)}.firma-upload:hover{border-color:var(--primary);background:var(--primary-light)}.firma-upload-icon{color:var(--text-placeholder);margin-bottom:var(--sp-2)}.firma-upload-label{font-size:var(--text-sm);color:var(--text-muted)}.firma-upload-hint{font-size:var(--text-xs);color:var(--text-placeholder);margin-top:var(--sp-1)}.firma-preview{align-items:center;gap:var(--sp-3);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);display:flex}.firma-preview img{object-fit:contain;max-width:160px;height:40px}.dark .firma-preview img{filter:invert(.9)}.questions-list{gap:var(--sp-2);margin-bottom:var(--sp-2);flex-direction:column;display:flex}.question-row{align-items:center;gap:var(--sp-2);display:flex}.question-row input{flex:1}.question-remove{border-radius:var(--radius-md);width:28px;height:28px;color:var(--text-placeholder);cursor:pointer;transition:background var(--t-fast),color var(--t-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.question-remove:hover{background:var(--danger-light);color:var(--danger)}.detail-breadcrumb{align-items:center;gap:var(--sp-2);font-size:var(--text-xs);color:var(--text-muted);margin-bottom:var(--sp-4);display:flex}.proposal-header{justify-content:space-between;align-items:flex-start;gap:var(--sp-4);margin-bottom:var(--sp-5);display:flex}.proposal-header-left{gap:var(--sp-2);flex-direction:column;display:flex}.proposal-oggetto{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text);line-height:var(--leading-snug);border-radius:var(--radius-md);cursor:text;transition:border-color var(--t-fast),background var(--t-fast);border:1px solid #0000;outline:none;margin-left:-6px;padding:2px 6px}.proposal-oggetto:hover{border-color:var(--border);background:var(--bg)}.proposal-oggetto:focus{border-color:var(--primary);background:var(--bg);box-shadow:0 0 0 3px var(--primary-light)}.proposal-oggetto:empty:before{content:attr(data-placeholder);color:var(--text-placeholder);font-style:italic}.proposal-meta{align-items:center;gap:var(--sp-3);margin-top:var(--sp-2);flex-wrap:wrap;display:flex}.proposal-meta-item{font-size:var(--text-xs);color:var(--text-muted);align-items:center;gap:4px;display:flex}.proposal-code-chip{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);letter-spacing:.04em;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:1px 7px}.proposal-header-actions{gap:var(--sp-2);flex-shrink:0;padding-top:4px;display:flex}.tabs-underline{border-bottom:1px solid var(--border);margin-bottom:var(--sp-5);gap:0;display:flex}.tab-underline-item{padding:var(--sp-2) var(--sp-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-muted);cursor:pointer;transition:color var(--t-fast),border-color var(--t-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tab-underline-item:hover{color:var(--text)}.tab-underline-item.active{color:var(--primary);border-bottom-color:var(--primary)}.service-list{gap:var(--sp-3);margin-bottom:var(--sp-4);flex-direction:column;display:flex}.service-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--t-fast);overflow:hidden}.service-card:hover{border-color:var(--border-strong)}.service-card.editing{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.service-card-header{align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);cursor:pointer;display:flex}.service-drag-handle{color:var(--text-placeholder);cursor:grab;opacity:0;transition:opacity var(--t-fast);flex-shrink:0;align-items:center;display:flex}.service-card:hover .service-drag-handle{opacity:1}.service-card-info{flex:1;min-width:0}.service-card-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.service-card-chips{align-items:center;gap:var(--sp-2);margin-top:var(--sp-1);flex-wrap:wrap;display:flex}.service-chip{font-size:var(--text-xs);color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);align-items:center;gap:4px;padding:1px 7px;display:inline-flex}.service-card-price{font-size:var(--text-sm);font-weight:var(--weight-semibold);font-variant-numeric:tabular-nums;color:var(--text);text-align:right;flex-shrink:0}.service-card-price-original{font-size:var(--text-xs);color:var(--text-placeholder);text-align:right;text-decoration:line-through;display:block}.service-card-actions{align-items:center;gap:var(--sp-1);flex-shrink:0;display:flex}.service-edit-panel{border-top:1px solid var(--border);padding:var(--sp-4) var(--sp-5);background:var(--bg)}.edit-panel-grid{gap:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}.edit-panel-full{grid-column:1/-1}.edit-field-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--sp-2);display:block}.edit-field-hint{font-size:var(--text-xs);color:var(--text-placeholder);margin-top:var(--sp-1)}.edit-panel-footer{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.questionario-section{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--border)}.questionario-title{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--sp-3)}.question-answer-row{gap:var(--sp-1);margin-bottom:var(--sp-3);flex-direction:column;display:flex}.question-text{font-size:var(--text-sm);color:var(--text);font-weight:var(--weight-medium)}.economic-header{margin-bottom:var(--sp-5);justify-content:space-between;align-items:center;display:flex}.economic-discount-row{align-items:center;gap:var(--sp-3);display:flex}.discount-input-wrap{align-items:center;gap:var(--sp-2);display:flex}.discount-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-md);width:80px;padding:var(--sp-2) var(--sp-3);font-size:var(--text-sm);color:var(--text);text-align:right;font-family:var(--font-sans);transition:border-color var(--t-fast);outline:none}.discount-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.economic-table{border-collapse:collapse;width:100%;margin-bottom:var(--sp-5)}.economic-table th{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--border);text-align:left}.economic-table th:not(:first-child){text-align:right}.economic-table td{padding:var(--sp-3) var(--sp-3);border-bottom:1px solid var(--border);font-size:var(--text-sm);color:var(--text);vertical-align:middle}.economic-table td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}.price-strikethrough{font-size:var(--text-xs);color:var(--text-placeholder);margin-bottom:1px;text-decoration:line-through;display:block}.price-final{font-weight:var(--weight-semibold);color:var(--text)}.economic-total-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--sp-4) var(--sp-5);justify-content:space-between;align-items:center;display:flex}.economic-total-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.economic-total-value{font-size:var(--text-xl);font-weight:var(--weight-bold);font-variant-numeric:tabular-nums;color:var(--text)}.intro-tab{gap:var(--sp-4);flex-direction:column;display:flex}.intro-hint{font-size:var(--text-xs);color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);gap:var(--sp-2);align-items:flex-start;display:flex}.export-tab{gap:var(--sp-5);flex-direction:column;max-width:640px;display:flex}.export-buttons{gap:var(--sp-4);display:flex}.export-btn{justify-content:center;align-items:center;gap:var(--sp-3);padding:var(--sp-6) var(--sp-8);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);text-align:center;flex-direction:column;flex:1;display:flex}.export-btn:hover{border-color:var(--primary);background:var(--primary-light)}.export-btn-icon{color:var(--text-muted)}.export-btn:hover .export-btn-icon{color:var(--primary)}.export-btn-label{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text)}.export-btn-sub{font-size:var(--text-xs);color:var(--text-muted)}@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-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@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}
