:root{--font-family-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--app-background:#f7f8fc;--content-background:#fff;--background-primary:#f7f8fc;--background-secondary:#f1f5f9;--background-tertiary:#e2e8f0;--background-hover:#f8fafc;--background-alt:#fafbfc;--background-body:#fff;--background-card:#fff;--sidebar-background:#fff;--sidebar-text:#6e758b;--sidebar-text-header:#b0b7c9;--sidebar-link-active:#4a69ff;--sidebar-link-active-background:#f0f3ff;--text-primary:#2d3748;--text-secondary:#5a647b;--text-tertiary:#94a3b8;--text-white:#fff;--primary:#4a69ff;--primary-hover:#3553e6;--primary-color:#4a69ff;--primary-light:#eef2ff;--primary-rgb:74,105,255;--primary-hsl:227,100%,65%;--light-blue:#eff6ff;--dark-blue:#1e40af;--border-color:#d1d5db;--border-color-light:#e6e8ee;--border-color-grey:#d1d5db;--border-color-strong:#cbd5e1;--status-green:#34c759;--status-green-bg:#dcfce7;--status-red:#ff3b30;--status-red-bg:#fee2e2;--status-yellow:#f59e0b;--status-yellow-bg:#fef3c7;--status-blue:#3b82f6;--status-blue-bg:#dbeafe;--chart-blue:#4a69ff;--chart-lightblue:#869dff;--chart-yellow:#ffd452;--chart-cyan:#32ade6;--chart-purple:#9060f9;--skeleton-base:#edf0f7;--skeleton-shine:#f5f7fc;--radius:12px;--shadow-subtle:0 4px 12px #d2d6e34d;--shadow-card:0px 2px 8px #bbc2d333;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 15px #0000001a}[data-theme=dark]{--app-background:#0e1019;--content-background:#161a26;--background-primary:#0e1019;--background-secondary:#1c2033;--background-tertiary:#232840;--background-hover:#1e2338;--background-alt:#131620;--background-body:#0e1019;--background-card:#161a26;--sidebar-background:#111420;--sidebar-text:#7a839c;--sidebar-text-header:#3a4155;--sidebar-link-active:#6b84ff;--sidebar-link-active-background:#1e2448;--text-primary:#dde3f0;--text-secondary:#8892ab;--text-tertiary:#4f5a72;--text-white:#dde3f0;--primary:#4a69ff;--primary-color:#4a69ff;--primary-hover:#627fff;--primary-light:#1e2448;--primary-rgb:74,105,255;--border-color:#252a3a;--border-color-light:#1c2030;--border-color-grey:#252a3a;--border-color-strong:#2e3450;--status-green:#34d399;--status-green-bg:#0f2a1e;--status-red:#f87171;--status-red-bg:#2a1016;--status-yellow:#fbbf24;--status-yellow-bg:#2a1e0a;--status-blue:#60a5fa;--status-blue-bg:#0f1e38;--chart-blue:#4a69ff;--chart-lightblue:#7b96ff;--chart-yellow:#fbbf24;--chart-cyan:#22d3ee;--chart-purple:#a78bfa;--shadow-subtle:0 4px 20px #00000080;--shadow-card:0px 2px 8px #0006;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 8px #0006;--shadow-lg:0 10px 20px #00000080;--skeleton-base:#1e2235;--skeleton-shine:#252a42}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-family-sans);background-color:var(--app-background);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}input,select,textarea,button{color:inherit;font-family:inherit}input,select,textarea{background-color:var(--content-background);color:var(--text-primary);border-color:var(--border-color)}select{appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}[data-theme=light]{--background-color:#f7f8fc;--card-background-color:#fff;--text-color:#2d3748;--primary-color:#4a69ff;--primary-hover:#3553e6;--border-color:#e2e6ef;--status-green:#22c55e;--status-yellow:#f59e0b;--status-red:#ef4444;--status-gray:#94a3b8;--status-green-bg:#eaf9ee;--status-yellow-bg:#fffbeb;--status-red-bg:#fff0f0;--info-bg:#eff6ff;--info-text:#1e40af;--chart-blue:#4a69ff;--chart-purple:#9060f9;--chart-green:#10b981;--chart-orange:#f59e0b;--chart-red:#ef4444;--chart-cyan:#06b6d4;--chart-pink:#ec4899;--chart-indigo:#6366f1;--net-positive:#059669;--net-negative:#dc2626;--status-green-bg-light:#10b9811a;--status-red-bg-light:#ef44441a;--collection-block-bg:#fffbf5;--collection-block-border:#fed7aa;--background-alt:#f0f2f5;--item-field-bg:#f0fdf4;--item-field-border:#bbf7d0;--item-field-color:#15803d;--fk-field-bg:#fdf4ff;--fk-field-border:#e9d5ff;--fk-field-color:#7c3aed}[data-theme=dark]{--app-background:#0e1019;--background-primary:#0e1019;--background-body:#0e1019;--background-color:#0e1019;--content-background:#161a26;--card-background-color:#161a26;--background-card:#161a26;--sidebar-background:#161a26;--skeleton-base:#1e2235;--skeleton-shine:#252a42;--background-secondary:#1c2033;--background-tertiary:#232840;--background-hover:#1e2338;--background-alt:#13162000;--text-color:#dde3f0;--text-primary:#dde3f0;--text-secondary:#8892ab;--text-tertiary:#4f5a72;--text-white:#dde3f0;--sidebar-text:#7a839c;--sidebar-text-header:#3a4155;--sidebar-link-active:#4a69ff;--sidebar-link-active-background:#1e2448;--border-color:#252a3a;--border-color-light:#1c2030;--border-color-grey:#252a3a;--border-color-strong:#2e3450;--primary:#4a69ff;--primary-color:#4a69ff;--primary-hover:#627fff;--primary-light:#1e2448;--primary-rgb:74,105,255;--status-green:#34d399;--status-green-bg:#0f2a1e;--status-red:#f87171;--status-red-bg:#2a1016;--status-yellow:#fbbf24;--status-yellow-bg:#2a1e0a;--status-blue:#60a5fa;--status-blue-bg:#0f1e38;--status-gray:#64748b;--info-bg:#141e2e;--info-text:#93c5fd;--chart-blue:#4a69ff;--chart-purple:#a78bfa;--chart-green:#34d399;--chart-orange:#fbbf24;--chart-red:#f87171;--chart-cyan:#22d3ee;--chart-pink:#f472b6;--chart-indigo:#818cf8;--net-positive:#34d399;--net-negative:#f87171;--status-green-bg-light:#34d3991f;--status-red-bg-light:#f871711f;--collection-block-bg:#1e1a0f;--collection-block-border:#3a2e18;--item-field-bg:#0f1f14;--item-field-border:#1e3a24;--item-field-color:#4ade80;--fk-field-bg:#1a0f22;--fk-field-border:#3a1f4a;--fk-field-color:#c084fc;--shadow-subtle:0 4px 20px #0006;--shadow-card:0px 2px 8px #0000004d;--radius:12px}.app-layout{height:100vh;display:flex}.main-content-area{background-color:var(--app-background);flex-grow:1;height:100vh;padding:24px;overflow-y:auto}.main-content{background:var(--content-background);box-shadow:var(--shadow-subtle);border-radius:24px;padding:32px}.app-loading{background-color:var(--app-background);justify-content:center;align-items:center;height:100vh;display:flex}.spinner{border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.spin{animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{background-color:var(--sidebar-background,var(--content-background));border-radius:0 40px 40px 0;flex-direction:column;flex-shrink:0;justify-content:space-between;width:280px;height:100vh;padding:24px;transition:width .25s,padding .25s,border-radius .25s;display:flex;position:relative;overflow:visible}.sidebar--collapsed{border-radius:0 56px 56px 0;width:72px;padding:40px 10px 24px}.sidebar-inner{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.sidebar-header{align-items:center;gap:12px;margin-bottom:24px;padding:8px;display:flex;position:relative}.sidebar--collapsed .sidebar-header{flex-direction:column-reverse;justify-content:flex-start;align-items:center;gap:0;padding:4px 0}.sidebar--collapsed .logo-icon{margin-top:28px}.sidebar-toggle-btn{z-index:10;background-color:var(--sidebar-background,var(--content-background));border:1.5px solid var(--border-color-strong);cursor:pointer;width:26px;height:26px;color:var(--text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:border-color .15s,background-color .15s,color .15s,box-shadow .15s;display:flex;position:absolute;top:50%;right:-13px;transform:translateY(-50%)}.sidebar-toggle-btn:hover{border-color:var(--primary);background-color:var(--primary-light);color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.logo-icon{color:var(--primary)}.logo-text{color:var(--text-primary);font-size:1.5rem;font-weight:700}.nav-group{margin-bottom:24px}.nav-group-title{color:var(--sidebar-text-header,var(--text-tertiary));text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;padding:0 16px;font-size:.72rem;font-weight:600}.sidebar-nav ul{margin:0;padding:0;list-style:none}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-text{white-space:nowrap;overflow:hidden}.nav-item{border-radius:var(--radius);color:var(--sidebar-text,var(--text-secondary));white-space:nowrap;align-items:center;gap:16px;margin-bottom:2px;padding:10px 14px;font-size:.9rem;font-weight:500;text-decoration:none;transition:background-color .15s,color .15s;display:flex}.nav-item:hover{background-color:var(--sidebar-link-active-background);color:var(--text-primary)}.nav-item.active{background-color:var(--sidebar-link-active-background);color:var(--sidebar-link-active);font-weight:600}.sidebar--collapsed .nav-item{border-radius:12px;justify-content:center;gap:0;width:44px;height:44px;margin-left:auto;margin-right:auto;padding:10px}.sidebar--collapsed .nav-item:hover:not(.active){background-color:var(--sidebar-link-active-background);color:var(--text-primary)}.sidebar--collapsed .nav-group{flex-direction:column;align-items:center;margin-bottom:8px;display:flex}.sidebar--collapsed .sidebar-inner .sidebar-header{margin-bottom:8px}.sidebar--collapsed .nav-item{margin-bottom:2px}.sidebar--collapsed .sidebar-nav ul{flex-direction:column;align-items:center;width:100%;display:flex}.sidebar--collapsed .sidebar-footer .nav-item{border-radius:12px;justify-content:center;gap:0;width:44px;height:44px;margin:0 auto;padding:10px}.sidebar-footer{flex-shrink:0}.sidebar-footer .nav-item{color:var(--text-secondary);margin-top:auto}.sidebar-footer .nav-item:hover{background-color:var(--status-red-bg);color:var(--status-red)}.logout-button{cursor:pointer;background:0 0;border:none;width:100%;font-family:inherit;font-size:.9rem}.nav-dropdown{list-style:none}.nav-item-row{border-radius:var(--radius);align-items:center;margin-bottom:2px;display:flex;overflow:hidden}.nav-item-row.active{background-color:var(--sidebar-link-active-background)}.nav-item-row.active .nav-item--trigger{color:var(--sidebar-link-active);font-weight:600}.nav-item-row.active .nav-chevron-btn{color:var(--sidebar-link-active)}.nav-item--trigger{border-radius:0;flex:1;margin-bottom:0;background:0 0!important}.nav-item--trigger.active{color:var(--sidebar-link-active);background:0 0!important}.nav-chevron-btn{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;align-self:stretch;align-items:center;padding:0 12px;transition:color .15s;display:flex}.nav-chevron-btn:hover{color:var(--text-primary)}.nav-chevron{flex-shrink:0;transition:transform .2s}.nav-chevron--open{transform:rotate(180deg)}.nav-dropdown-list{margin:0 0 2px;padding:0;list-style:none}.nav-item--sub{color:var(--text-secondary);margin-bottom:1px;padding-left:36px;font-size:.84rem;font-weight:500}.app-header{background-color:var(--content-background);box-shadow:var(--shadow-subtle);border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px 24px;display:flex}.header-left-content{flex-direction:column;display:flex}.header-greeting{color:var(--text-primary);margin:0;font-size:1.75rem;font-weight:700}.header-date{color:var(--text-secondary);font-size:.9rem}.header-right-content{align-items:center;gap:16px;display:flex}.header-dept-tabs{background:var(--app-background);border:1px solid var(--border-color-strong);border-radius:12px;gap:4px;padding:4px;display:flex}.header-dept-tab{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:9px;align-items:center;gap:6px;padding:7px 16px;font-family:inherit;font-size:.82rem;font-weight:600;transition:background-color .15s,color .15s,box-shadow .15s;display:flex}.header-dept-tab.active{background:var(--content-background);color:var(--primary);box-shadow:0 1px 4px #0000001f}.header-dept-tab:hover:not(.active){color:var(--text-primary);background:#0000000d}.search-bar{background-color:var(--app-background);border-radius:var(--radius);border:1px solid var(--border-color-strong);align-items:center;gap:8px;width:280px;padding:8px 12px;display:flex}.search-bar input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-family:inherit;font-size:.9rem}.search-bar input::placeholder{color:var(--text-secondary)}.action-icons{align-items:center;gap:8px;display:flex}.icon-button{border:1px solid var(--border-color-strong);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:relative}.icon-button:hover{background-color:var(--border-color-light);color:var(--text-primary)}.theme-switcher .lucide{transition:transform .3s ease-in-out}.theme-switcher:hover .lucide{transform:rotate(45deg)}.dept-container{position:relative}.dept-switcher-btn.dept-fleet{color:var(--primary);border-color:var(--primary);background:var(--primary-light,hsla(var(--primary-hsl),.08))}.dept-switcher-btn.dept-recruitment{color:#059669;background:#05966914;border-color:#059669}.dept-dropdown{background-color:var(--content-background);border-radius:var(--radius);min-width:180px;box-shadow:var(--shadow-md);border:1px solid var(--border-color-strong);z-index:100;padding:4px;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.dept-dropdown-item{border-radius:calc(var(--radius) - 2px);cursor:pointer;color:var(--text-secondary);align-items:center;gap:10px;padding:10px 12px;font-size:.9rem;font-weight:500;transition:background-color .15s,color .15s;display:flex}.dept-dropdown-item:hover{background-color:var(--border-color-light);color:var(--text-primary)}.dept-dropdown-item.active{color:var(--primary);font-weight:600}.dept-dropdown-item .dept-check{color:var(--primary);margin-left:auto;font-size:.85rem}.dept-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dept-dot.dept-dot-fleet{background:var(--primary)}.dept-dot.dept-dot-recruitment{background:#059669}.dept-dot.dept-dot-digital-marketing{background:#f59e0b}.language-container{position:relative}.language-dropdown{background-color:var(--content-background);border-radius:var(--radius);width:180px;box-shadow:var(--shadow-md);border:1px solid var(--border-color-strong);z-index:100;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.language-dropdown ul{margin:0;padding:0;list-style:none}.language-dropdown li{cursor:pointer;color:var(--text-secondary);justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-weight:500;transition:background-color .2s,color .2s;display:flex}.language-dropdown li:hover{background-color:var(--border-color-light);color:var(--text-primary)}.language-dropdown li.active{background-color:var(--sidebar-link-active-background);color:var(--sidebar-link-active);font-weight:600}.language-dropdown li span{align-items:center;gap:6px;display:flex}.profile-container{position:relative}.profile-wrapper{background-color:var(--app-background);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:background-color .2s;display:flex}.profile-wrapper:hover{background-color:var(--border-color-light)}.profile-dropdown{background-color:var(--content-background);border-radius:var(--radius);width:200px;box-shadow:var(--shadow-md);border:1px solid var(--border-color-strong);z-index:100;position:absolute;top:calc(100% + 10px);right:0;overflow:hidden}.profile-dropdown ul{margin:0;padding:0;list-style:none}.profile-dropdown li{cursor:pointer;color:var(--text-secondary);align-items:center;gap:12px;padding:10px 12px;font-weight:500;transition:background-color .2s,color .2s;display:flex}.profile-dropdown li:hover{background-color:var(--border-color-light);color:var(--text-primary)}.profile-dropdown li:last-child{color:var(--status-red)}.profile-dropdown li:last-child:hover{background-color:var(--status-red-bg);color:var(--status-red)}.status-badge{border-radius:9999px;align-items:center;gap:6px;padding:5px 10px;font-size:.75rem;font-weight:600;line-height:1;display:inline-flex}.status-badge:before{content:"";border-radius:50%;width:7px;height:7px}.status-badge.green{color:var(--status-green);background-color:var(--status-green-bg)}.status-badge.green:before{background-color:var(--status-green)}.status-badge.blue{color:var(--chart-blue);background-color:var(--info-bg)}.status-badge.blue:before{background-color:var(--chart-blue)}.status-badge.orange{color:var(--status-yellow);background-color:var(--status-yellow-bg)}.status-badge.orange:before{background-color:var(--status-yellow)}.status-badge.red{color:var(--status-red);background-color:var(--status-red-bg)}.status-badge.red:before{background-color:var(--status-red)}.status-badge.gray{color:var(--status-gray);background-color:var(--border-color)}.status-badge.gray:before{background-color:var(--status-gray)}.chart-container{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:20px;flex-direction:column;padding:24px;transition:box-shadow .2s,border-color .2s;display:flex}.chart-container:hover{border-color:var(--border-color-strong);box-shadow:0 8px 24px #0000000f}.chart-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.chart-container h4{color:var(--text-primary);margin:0;font-size:1rem;font-weight:600}.chart-subtitle{color:var(--text-secondary);margin:4px 0 0;font-size:.8rem}.chart-content{flex:1;justify-content:center;align-items:center;width:100%;height:280px;min-height:280px;display:flex}.chart-container.chart-compact .chart-content{height:220px;min-height:220px}.chart-container.chart-tall .chart-content{height:320px;min-height:320px}.chart-action{align-items:center;gap:8px;display:flex}.chart-action button{border:1px solid var(--border-color-light);background:var(--content-background);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:.8rem;transition:all .15s}.chart-action button:hover{background:var(--sidebar-link-active-background);border-color:var(--border-color-strong);color:var(--text-primary)}@media (max-width:768px){.chart-container{padding:16px}.chart-header{margin-bottom:16px}.chart-content{height:240px;min-height:240px}.chart-container.chart-compact .chart-content{height:200px;min-height:200px}.chart-container.chart-tall .chart-content{height:280px;min-height:280px}.chart-subtitle{display:none}}:root{--chart-blue:var(--chart-blue);--chart-purple:var(--chart-purple);--chart-green:var(--chart-green);--chart-orange:var(--chart-orange);--chart-red:var(--chart-red);--chart-cyan:var(--chart-cyan);--chart-pink:var(--chart-pink);--chart-indigo:var(--chart-indigo)}.recharts-legend-wrapper{padding-top:12px!important}.recharts-legend-item{margin-right:20px!important}.recharts-legend-item-text{vertical-align:middle;font-size:.8rem;font-weight:500;color:var(--text-color)!important}.recharts-tooltip-wrapper{z-index:1000}.recharts-tooltip-label{margin-bottom:6px;font-size:.85rem;font-weight:600;color:var(--text-color)!important}.recharts-default-tooltip{background:var(--card-background-color)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;padding:12px 14px!important;box-shadow:0 4px 16px #0000001f!important}.recharts-tooltip-item{color:var(--text-color)!important;padding:2px 0!important;font-size:.8rem!important}.recharts-tooltip-item-name{font-weight:500}.recharts-tooltip-item-value{font-weight:600;margin-left:8px!important}.recharts-cartesian-axis-tick-value{fill:var(--text-color);font-size:.75rem;font-weight:500}.recharts-cartesian-axis-line{stroke:var(--border-color)}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-color);stroke-opacity:.7}.pie-center-label{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.pie-center-value{color:var(--text-color);font-size:1.5rem;font-weight:700;line-height:1.2}.pie-center-text{color:var(--text-color);font-size:.75rem;font-weight:500}.recharts-bar-rectangle{transition:opacity .2s}.recharts-bar-rectangle:hover{opacity:.85}@media (max-width:768px){.recharts-legend-wrapper{padding-top:8px!important}.recharts-legend-item{margin-right:12px!important}.recharts-legend-item-text{font-size:.75rem}.recharts-cartesian-axis-tick-value{font-size:.7rem}}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.tab-navigation{border-bottom:2px solid var(--border-color);gap:0;margin-bottom:24px;display:flex}.tab-button{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;position:relative;bottom:-2px}.tab-button:hover{color:var(--text-color)}.header-actions{align-items:center;gap:12px;display:flex}.page-title{color:var(--text-color);font-size:1.75rem;font-weight:700}.add-button{background-color:var(--primary-color);color:var(--card-background-color);border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;height:40px;padding:10px 16px;font-size:.9rem;font-weight:600;transition:background-color .2s;display:flex}.add-button:hover{background-color:var(--primary-hover)}.table-container{width:100%}table{border-collapse:separate;border-spacing:0 4px;width:100%}th,td{text-align:left;vertical-align:middle;border-bottom:1px solid var(--border-color);padding:16px 20px}thead tr{border-bottom:2px solid var(--border-color)}th{color:var(--text-color);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:600}tbody tr{background-color:var(--card-background-color);transition:background-color .2s}tbody tr:hover{background-color:var(--background-color)}tbody tr.clickable-row{cursor:pointer}td:first-child{border-top-left-radius:var(--radius);border-bottom-left-radius:var(--radius)}td:last-child{border-top-right-radius:var(--radius);border-bottom-right-radius:var(--radius)}.action-buttons{gap:6px;display:flex}.action-button{cursor:pointer;border-radius:var(--radius);border:none;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:inline-flex}.action-button.view{background-color:var(--info-bg);color:var(--info-text)}.action-button.view:hover{background-color:var(--info-bg)}.action-button.edit{background-color:var(--status-yellow-bg);color:var(--status-yellow)}.action-button.edit:hover{background-color:var(--status-yellow-bg)}.action-button.delete{background-color:var(--status-red-bg);color:var(--status-red)}.action-button.delete:hover{background-color:var(--status-red-bg)}.action-button.approve{background-color:var(--status-green-bg);color:var(--status-green)}.action-button.approve:hover{background-color:var(--status-green-bg)}.action-button.reject{background-color:var(--status-red-bg);color:var(--status-red)}.action-button.reject:hover{background-color:var(--status-red-bg)}.status-text{color:var(--text-color);margin-left:8px;font-size:.9rem}.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.inventory-card{background-color:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);flex-direction:column;transition:all .2s;display:flex}.inventory-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-start;padding:16px;display:flex}.card-title{color:var(--text-color);margin:0;font-size:1.1rem;font-weight:600;line-height:1.4}.card-body{flex-grow:1;padding:16px}.card-body p{color:var(--text-color);margin:0 0 10px;font-size:.9rem}.card-body p strong{color:var(--text-color);font-weight:500}.card-footer{background-color:var(--background-color);border-top:1px solid var(--border-color);border-bottom-left-radius:var(--radius);border-bottom-right-radius:var(--radius);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.card-footer .status-text{margin-left:0}.card-footer .card-actions{align-items:center;gap:8px;display:flex}.card-footer .action-button{border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;color:var(--text-color);background-color:#0000;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:inline-flex}.card-footer .action-button.purchase{background-color:var(--info-bg);color:var(--info-text);border-color:var(--info-text)}.card-footer .action-button.purchase:hover{background-color:var(--info-bg)}.filters-row{flex-wrap:wrap;gap:15px;margin-bottom:20px;display:flex}.search-box{flex-grow:1;align-items:center;max-width:300px;display:flex;position:relative}.search-box svg{color:var(--text-color);position:absolute;left:12px}.search-box input{border:1px solid var(--border-color);border-radius:var(--radius);width:100%;color:var(--text-color);padding:10px 10px 10px 40px;font-size:.9rem;transition:all .2s}.search-box input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb,74,105,255),.1);outline:none}.filter-select{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);color:var(--text-color);cursor:pointer;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding:10px 40px 10px 12px;font-size:.9rem}.filter-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb,74,105,255),.1);outline:none}.purchase-history{width:100%}.purchase-history-table{overflow-x:auto}.purchase-history-table tbody tr.status-confirmed{border-left:3px solid var(--status-green)}.purchase-history-table tbody tr.status-draft{border-left:3px solid var(--status-yellow)}.purchase-history-table tbody tr.status-cancelled{border-left:3px solid var(--status-red)}.status-cell{align-items:center;gap:8px;font-size:.9rem;display:flex}.status-cell .status-icon.confirmed{color:var(--status-green)}.status-cell .status-icon.draft{color:var(--status-yellow)}.status-cell .status-icon.cancelled{color:var(--status-red)}.numeric{text-align:right;font-variant-numeric:tabular-nums}.font-bold{font-weight:600}.loading-state,.empty-state{text-align:center;color:var(--text-color);padding:24px;font-size:.9rem}.purchases-list-container{width:100%}.table-container{background-color:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);overflow:hidden}.empty-message{text-align:center;color:var(--text-color);padding:48px 24px;font-size:.95rem}.error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);border-left:4px solid var(--status-red);margin-bottom:16px;padding:12px 16px}.loading-container{color:var(--text-color);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;display:flex}.loading-container .spinner{animation:1s linear infinite spin}.inline-search{align-items:center;height:40px;display:flex;position:relative}.inline-search .inline-search-icon{color:var(--text-color);pointer-events:none;position:absolute;left:10px}.inline-search input{border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-background-color);color:var(--text-color);width:220px;height:40px;padding:9px 12px 9px 34px;font-family:inherit;font-size:.875rem}.inline-search input::placeholder{color:var(--text-color)}.inline-search input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb,74,105,255),.1);outline:none}.sort-select{border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-background-color);color:var(--text-color);cursor:pointer;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 6px center;background-repeat:no-repeat;background-size:16px;height:40px;padding:9px 32px 9px 12px;font-family:inherit;font-size:.875rem;font-weight:500}.sort-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-rgb,74,105,255),.1);outline:none}.add-button.secondary{background:var(--card-background-color);color:var(--text-color);border:1px solid var(--border-color)}.add-button.secondary:hover{background:var(--background-color);color:var(--text-color)}.actions-cell{justify-content:flex-end;align-items:center;gap:6px;display:flex}.action-button.confirm{background-color:var(--status-green-bg);color:var(--status-green)}.action-button.confirm:hover:not(:disabled){background-color:var(--status-green-bg)}.action-button.confirm:disabled{opacity:.6;cursor:not-allowed}.action-button.cancel{background-color:var(--status-red-bg);color:var(--status-red)}.action-button.cancel:hover:not(:disabled){background-color:var(--status-red-bg)}.action-button.cancel:disabled{opacity:.6;cursor:not-allowed}.purchase-detail{max-width:1000px;margin:0 auto}.purchase-detail-header{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.back-button{color:var(--primary-color);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:fit-content;padding:8px 0;font-size:.95rem;font-weight:500;transition:color .2s;display:inline-flex}.back-button:hover{color:var(--primary-hover)}.purchase-detail-content{flex-direction:column;gap:20px;display:flex}.detail-card{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.detail-card .card-header{background-color:var(--background-color);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.detail-card .card-header h2{color:var(--text-color);margin:0;font-size:1rem;font-weight:600}.items-count{color:var(--text-color);background-color:var(--card-background-color);border-radius:4px;padding:4px 8px;font-size:.85rem}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;display:grid}.detail-row{flex-direction:column;gap:6px;display:flex}.detail-row label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-color);font-size:.8rem;font-weight:600}.detail-row .value{color:var(--text-color);word-break:break-word;font-size:.95rem}.totals-summary{border-top:2px solid var(--border-color);padding:20px}.total-row{justify-content:flex-end;align-items:center;gap:24px;font-size:1.1rem;font-weight:600;display:flex}.total-row .amount{color:var(--primary-color);font-size:1.3rem}.actions-section{background-color:var(--background-color);border-radius:var(--radius);border:1px solid var(--border-color);gap:12px;padding:20px;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.95rem;font-weight:500;transition:all .2s;display:inline-flex}.btn.btn-confirm{background-color:var(--status-green);color:#fff}.btn.btn-confirm:hover:not(:disabled){background-color:#15803d}.btn.btn-cancel{background-color:var(--status-red);color:#fff}.btn.btn-cancel:hover:not(:disabled){background-color:#b91c1c}.loading-state{color:var(--text-color);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 24px;display:flex}.loading-state svg{width:32px;height:32px;animation:1s linear infinite spin}.gifts-dashboard{padding:0}.gifts-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px;display:grid}@media (max-width:900px){.gifts-stats-grid{grid-template-columns:repeat(2,1fr)}}.gifts-stat-card{background:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);align-items:center;gap:16px;padding:20px;display:flex}.gifts-stat-card .stat-icon{border-radius:12px;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.gifts-stat-card .stat-icon.blue{color:#2563eb;background:#dbeafe}.gifts-stat-card .stat-icon.orange{color:#ea580c;background:#ffedd5}.gifts-stat-card .stat-icon.green{color:#16a34a;background:#dcfce7}.gifts-stat-card .stat-icon.purple{color:#9333ea;background:#f3e8ff}.gifts-stat-card .stat-info{flex-direction:column;display:flex}.gifts-stat-card .stat-info .stat-value{color:var(--text-color);font-size:1.75rem;font-weight:700;line-height:1}.gifts-stat-card .stat-info .stat-label{color:var(--text-color);margin-top:4px;font-size:.85rem}.dashboard-charts-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px;display:grid}@media (max-width:768px){.dashboard-charts-grid{grid-template-columns:1fr}}.dashboard-charts-grid-3{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px;display:grid}@media (max-width:1024px){.dashboard-charts-grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.dashboard-charts-grid-3{grid-template-columns:1fr}}.dashboard-chart-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);padding:20px 24px}.dashboard-chart-card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dashboard-chart-card-title{color:var(--text-color);margin:0;font-size:.95rem;font-weight:600}.dashboard-chart-empty{height:180px;color:var(--text-color);border:1.5px dashed var(--border-color);border-radius:10px;justify-content:center;align-items:center;font-size:.82rem;display:flex}.dashboard-period-toggle{gap:4px;display:flex}.dashboard-period-btn{border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;background:0 0;border-radius:6px;padding:4px 12px;font-size:.8rem;font-weight:500;transition:all .15s}.dashboard-period-btn:hover{background:var(--hover-background,#0000000a);color:var(--text-color)}.dashboard-period-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.dashboard-timeline-section{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);margin-bottom:32px;padding:20px 24px}.fleet-mini-vehicle-list{flex-direction:column;gap:8px;display:flex}.fleet-mini-vehicle-list--grid{grid-template-columns:repeat(2,1fr);gap:8px;display:grid}@media (max-width:640px){.fleet-mini-vehicle-list--grid{grid-template-columns:1fr}}.fleet-mini-vehicle-item{background:var(--hover-background,#00000006);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;transition:background .15s;display:flex}.fleet-mini-vehicle-item:hover{background:var(--hover-background,#0000000f)}.fleet-mini-vehicle-info{flex-direction:column;gap:2px;display:flex}.fleet-mini-vehicle-name{color:var(--text-color);font-size:.875rem;font-weight:600}.fleet-mini-vehicle-plate{color:var(--text-color);letter-spacing:.04em;font-family:monospace;font-size:.775rem}.gifts-recent-section{background:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);padding:24px}.gifts-recent-section h2{color:var(--text-color);margin-bottom:16px;font-size:1.1rem;font-weight:600}.modal-backdrop{-webkit-backdrop-filter:blur(8px);z-index:1000;opacity:0;background-color:#64748b66;justify-content:center;align-items:center;width:100%;height:100%;animation:.3s forwards fadeIn;display:flex;position:fixed;top:0;left:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--card-background-color);border-radius:var(--radius);scrollbar-width:none;-ms-overflow-style:none;width:80vw;min-width:520px;max-width:800px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);opacity:0;padding:24px;animation:.3s .1s forwards scaleIn;overflow-y:auto;transform:scale(.95)}.modal-content::-webkit-scrollbar{display:none}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);color:var(--text-color);padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group select{appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.button-primary{background-color:var(--primary-color);color:#fff;box-shadow:var(--shadow-sm)}.button-primary:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.button-secondary{background-color:var(--background-color);color:var(--text-color);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.button-secondary:hover{background-color:var(--background-color);border-color:var(--text-color);color:var(--text-color)}.purchase-items{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.purchase-item-card{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);flex-direction:column;gap:8px;padding:12px;display:flex}.purchase-item-card .item-top{align-items:center;gap:8px;display:flex}.purchase-item-card .item-top .item-select{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--background-color);color:var(--text-color);flex:1;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.purchase-item-card .item-top .item-select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #3f76ff33}.purchase-item-card .item-bottom{grid-template-columns:1fr 120px 1fr;gap:8px;display:grid}.purchase-item-card .item-field{flex-direction:column;gap:4px;display:flex}.purchase-item-card .item-field .item-field-label{color:var(--text-color);font-size:.75rem;font-weight:500}.purchase-item-card .item-field input{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);width:100%;color:var(--text-color);padding:8px 12px;font-family:inherit;font-size:.875rem;transition:border-color .2s}.purchase-item-card .item-field input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #3f76ff33}.purchase-item-card .item-field input[type=number]{text-align:right}.purchase-item-card .item-field .item-unit{background-color:var(--background-color);color:var(--text-color);cursor:default;text-align:center;font-weight:500}.remove-item-btn{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);cursor:pointer;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.remove-item-btn:hover:not(:disabled){background-color:var(--status-red);border-color:var(--status-red);color:#fff}.remove-item-btn:disabled{opacity:.5;cursor:not-allowed}.add-item-btn{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);cursor:pointer;align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.add-item-btn:hover{background-color:var(--primary-color);border-color:var(--primary-color);color:#fff}.secondary-btn{background-color:var(--background-color)!important;border:1px solid var(--border-color)!important;color:var(--text-color)!important}.secondary-btn:hover{background-color:var(--background-color)!important}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:24px;padding:8px 0;display:flex}.pagination-btn{border:1px solid var(--border-color);background:var(--card-background-color);min-width:36px;height:36px;color:var(--text-color);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0 8px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.pagination-btn:hover:not(:disabled){background:var(--hover-background,#0000000a);color:var(--text-color);border-color:var(--border-color)}.pagination-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-ellipsis{min-width:36px;height:36px;color:var(--text-color);justify-content:center;align-items:center;font-size:.875rem;display:flex}@keyframes skeleton-loading{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--skeleton-base)0%,var(--skeleton-shine)40%,var(--skeleton-base)80%);border-radius:var(--radius);background-size:200% 100%;animation:1.5s ease-in-out infinite skeleton-loading;display:inline-block}.skeleton-text-line{margin-bottom:.5rem}.skeleton-text-line:last-child{margin-bottom:0}.skeleton-card{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.5rem}.skeleton-card__header{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.skeleton-card__title{flex-direction:column;flex:1;gap:.5rem;display:flex}.skeleton-card__content{margin-top:1rem}.skeleton-table{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);overflow:hidden}.skeleton-table__header{background-color:var(--border-color);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;padding:1px;display:grid}.skeleton-table__body{background-color:var(--border-color);flex-direction:column;gap:1px;padding:1px;display:flex}.skeleton-table__row{background-color:var(--card-background-color);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;display:grid}.summary-card-skeleton{background-color:var(--card-background-color);align-items:center;gap:1rem;padding:1rem;display:flex}.summary-card-skeleton .skeleton-icon{width:40px;height:40px}.summary-card-skeleton .skeleton-content{flex-direction:column;flex:1;gap:.5rem;display:flex}.role-card-skeleton{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.5rem}.role-card-skeleton .skeleton-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.role-card-skeleton .skeleton-actions{gap:.5rem;display:flex}.role-card-skeleton .skeleton-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-top:1rem;padding-top:1rem;display:flex}.chart-skeleton{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);flex-direction:column;gap:1rem;min-height:300px;padding:1.5rem;display:flex}.chart-skeleton .skeleton-chart-header{justify-content:space-between;align-items:center;display:flex}.chart-skeleton .skeleton-chart-body{flex:1;align-items:flex-end;gap:.5rem;padding:1rem 0;display:flex}.chart-skeleton .skeleton-bar{border-radius:4px;flex:1}.document-status-dots{align-items:center;gap:.375rem;display:flex}.document-status-dots .status-dot{cursor:help;border:1px solid #0000001a;border-radius:50%;width:10px;height:10px;display:inline-block}.document-status-dots .status-dot.green{background-color:var(--status-green);box-shadow:0 0 4px #22c55e66}.document-status-dots .status-dot.yellow{background-color:var(--status-yellow);box-shadow:0 0 4px #eab30866}.document-status-dots .status-dot.red{background-color:var(--status-red);box-shadow:0 0 4px #ef444466}.document-status-dots .status-dot.gray{background-color:var(--status-gray)}:root{--mf-background:var(--card-background-color);--mf-border-color:var(--border-color);--mf-header-background:var(--background-color);--mf-radius:var(--radius);--mf-text-primary:var(--text-color);--mf-text-secondary:var(--text-color);--mf-primary-color:var(--primary-color);--mf-primary-rgb:var(--primary-rgb,74,105,255)}.mf-view{background:var(--mf-background);border:1px solid var(--mf-border-color);border-radius:var(--mf-radius);margin-bottom:24px}.mf-header{cursor:pointer;background:var(--mf-header-background);border-radius:var(--mf-radius)var(--mf-radius)0 0;justify-content:space-between;align-items:center;padding:12px 16px;transition:background .2s;display:flex}.mf-header:hover{background:var(--mf-border-color)}.mf-header-left,.mf-header-right{align-items:center;gap:12px;display:flex}.mf-header-icon{color:var(--mf-text-secondary)}.mf-title{color:var(--mf-text-primary);margin:0;font-size:.95rem;font-weight:600}.mf-active-count{background-color:var(--mf-primary-color);color:#fff;border-radius:12px;padding:2px 8px;font-size:.8rem;font-weight:600;line-height:1}.mf-reset-btn{border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);cursor:pointer;background:0 0;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .15s;display:inline-flex}.mf-reset-btn:hover{background:var(--status-red-bg);color:var(--status-red);border-color:var(--status-red)}.mf-chevron{color:var(--mf-text-secondary);transition:transform .2s ease-in-out}.mf-chevron-open{transform:rotate(180deg)}.mf-body{border-top:1px solid var(--mf-border-color);padding:20px}.mf-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;display:grid}.mf-item{flex-direction:column;gap:8px;display:flex}.mf-label{color:var(--mf-text-secondary);font-size:.8rem;font-weight:500}.mf-control-wrap{align-items:center;display:flex;position:relative}.mf-control{border:1px solid var(--border-color);border-radius:var(--mf-radius);background:var(--card-background-color);width:100%;color:var(--text-color);padding:9px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.mf-control:focus{border-color:var(--mf-primary-color);box-shadow:0 0 0 3px rgba(var(--mf-primary-rgb),.15);outline:none}.mf-control[type=number]{-moz-appearance:textfield}.mf-control[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.mf-control[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.mf-clear-btn{width:24px;height:24px;color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex;position:absolute;right:8px}.mf-clear-btn:hover{background:var(--background-color);color:var(--text-color)}select.mf-control{padding-right:30px}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--background-color);border-radius:12px;width:80vw;min-width:520px;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content .modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-content .modal-header h2{color:var(--text-color);margin:0;font-size:1.25rem;font-weight:600}.modal-content .modal-header .close-button{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.25rem;transition:all .2s}.modal-content .modal-header .close-button:hover{background:var(--background-color);color:var(--text-color)}.modal-content .error-banner{background:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin:1rem 1.5rem;padding:.75rem 1rem;font-size:.875rem}.modal-content form{padding:1.5rem}.modal-content form .form-group{margin-bottom:1.25rem}.modal-content form .form-group label{color:var(--text-color);margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.modal-content form .form-group input,.modal-content form .form-group textarea,.modal-content form .form-group select{border:1px solid var(--border-color);width:100%;color:var(--text-color);background:var(--background-color);border-radius:6px;padding:.625rem .875rem;font-size:.875rem;transition:all .2s}.modal-content form .form-group input:focus,.modal-content form .form-group textarea:focus,.modal-content form .form-group select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff1a}.modal-content form .form-group input::placeholder,.modal-content form .form-group textarea::placeholder,.modal-content form .form-group select::placeholder{color:var(--text-color)}.modal-content form .form-group textarea{resize:vertical;font-family:inherit}.modal-content form .form-group .help-text{color:var(--text-color);margin-top:.375rem;font-size:.75rem;display:block}.modal-content form .form-row{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media (max-width:640px){.modal-content form .form-row{grid-template-columns:1fr}}.modal-content form .form-actions{border-top:1px solid var(--border-color);justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.modal-content form .form-actions .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.modal-content form .form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.modal-content form .form-actions .btn.btn-primary{background:var(--primary-color);color:#fff}.modal-content form .form-actions .btn.btn-primary:hover:not(:disabled){opacity:.9}.modal-content form .form-actions .btn.btn-secondary{background:var(--background-color);color:var(--text-color);border:1px solid var(--border-color)}.modal-content form .form-actions .btn.btn-secondary:hover:not(:disabled){background:var(--background-color)}.vehicle-poa-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-poa-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-poa-section .section-header .header-left svg{color:var(--primary-color)}.vehicle-poa-section .section-header .header-left h2{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:600}.vehicle-poa-section .filters{margin-bottom:1rem}.vehicle-poa-section .filters .filter-select{border:1px solid var(--border-color);background:var(--background-color);color:var(--text-color);border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.vehicle-poa-section .filters .filter-select:focus{border-color:var(--primary-color);outline:none}.vehicle-poa-section .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vehicle-poa-section .loading-state{text-align:center;color:var(--text-color);padding:3rem}.vehicle-poa-section .empty-state{text-align:center;background:var(--background-color);border:2px dashed var(--border-color);border-radius:8px;padding:3rem}.vehicle-poa-section .empty-state .empty-icon{color:var(--text-color);margin-bottom:1rem}.vehicle-poa-section .empty-state h3{color:var(--text-color);margin:0 0 .5rem}.vehicle-poa-section .empty-state p{color:var(--text-color);margin-bottom:1.5rem}.vehicle-poa-section .table-container{background:var(--background-color);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.vehicle-poa-section .table-container table{border-collapse:collapse;width:100%}.vehicle-poa-section .table-container table thead{background:var(--background-color)}.vehicle-poa-section .table-container table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.vehicle-poa-section .table-container table tbody tr{border-bottom:1px solid var(--border-color)}.vehicle-poa-section .table-container table tbody tr:last-child{border-bottom:none}.vehicle-poa-section .table-container table tbody tr:hover{background:var(--background-color)}.vehicle-poa-section .table-container table tbody tr td{color:var(--text-color);padding:1rem;font-size:.875rem}.vehicle-poa-section .table-container table tbody tr td.actions{gap:.5rem;display:flex}.vehicle-poa-section .badge{white-space:nowrap;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.vehicle-poa-section .badge.badge-success{background:var(--status-green-bg);color:var(--status-green)}.vehicle-poa-section .badge.badge-danger{background:var(--status-red-bg);color:var(--status-red)}.vehicle-poa-section .badge.badge-warning{background:var(--status-yellow-bg);color:var(--status-yellow)}.vehicle-poa-section .badge.badge-secondary{background:var(--background-color);color:var(--text-color)}.vehicle-poa-section .btn-icon{cursor:pointer;color:var(--text-color);background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s}.vehicle-poa-section .btn-icon:hover{background:var(--background-color);color:var(--primary-color)}.vehicle-poa-section .btn-icon.btn-danger:hover{background:var(--status-red-bg);color:var(--status-red)}.vehicle-poa-section .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.vehicle-poa-section .btn.btn-primary{background:var(--primary-color);color:#fff}.vehicle-poa-section .btn.btn-primary:hover{opacity:.9}.vehicle-poa-section .font-semibold{font-weight:600}.vehicle-insurance-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-insurance-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-insurance-section .section-header .header-left svg{color:var(--primary-color)}.vehicle-insurance-section .section-header .header-left h2{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:600}.vehicle-insurance-section .filters{margin-bottom:1rem}.vehicle-insurance-section .filters .filter-select{border:1px solid var(--border-color);background:var(--background-color);color:var(--text-color);border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.vehicle-insurance-section .filters .filter-select:focus{border-color:var(--primary-color);outline:none}.vehicle-insurance-section .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vehicle-insurance-section .loading-state{text-align:center;color:var(--text-color);padding:3rem}.vehicle-insurance-section .empty-state{text-align:center;background:var(--background-color);border:2px dashed var(--border-color);border-radius:8px;padding:3rem}.vehicle-insurance-section .empty-state .empty-icon{color:var(--text-color);margin-bottom:1rem}.vehicle-insurance-section .empty-state h3{color:var(--text-color);margin:0 0 .5rem}.vehicle-insurance-section .empty-state p{color:var(--text-color);margin-bottom:1.5rem}.vehicle-insurance-section .table-container{background:var(--background-color);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.vehicle-insurance-section .table-container table{border-collapse:collapse;width:100%}.vehicle-insurance-section .table-container table thead{background:var(--background-color)}.vehicle-insurance-section .table-container table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.vehicle-insurance-section .table-container table tbody tr{border-bottom:1px solid var(--border-color)}.vehicle-insurance-section .table-container table tbody tr:last-child{border-bottom:none}.vehicle-insurance-section .table-container table tbody tr:hover{background:var(--background-color)}.vehicle-insurance-section .table-container table tbody tr td{color:var(--text-color);padding:1rem;font-size:.875rem}.vehicle-insurance-section .table-container table tbody tr td.actions{gap:.5rem;display:flex}.vehicle-insurance-section .badge{white-space:nowrap;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.vehicle-insurance-section .badge.badge-success{background:var(--status-green-bg);color:var(--status-green)}.vehicle-insurance-section .badge.badge-danger{background:var(--status-red-bg);color:var(--status-red)}.vehicle-insurance-section .badge.badge-warning{background:var(--status-yellow-bg);color:var(--status-yellow)}.vehicle-insurance-section .badge.badge-secondary{background:var(--background-color);color:var(--text-color)}.vehicle-insurance-section .btn-icon{cursor:pointer;color:var(--text-color);background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s}.vehicle-insurance-section .btn-icon:hover{background:var(--background-color);color:var(--primary-color)}.vehicle-insurance-section .btn-icon.btn-danger:hover{background:var(--status-red-bg);color:var(--status-red)}.vehicle-insurance-section .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.vehicle-insurance-section .btn.btn-primary{background:var(--primary-color);color:#fff}.vehicle-insurance-section .btn.btn-primary:hover{opacity:.9}.vehicle-oil-change-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-oil-change-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-oil-change-section .section-header .header-left svg{color:var(--primary-color)}.vehicle-oil-change-section .section-header .header-left h2{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:600}.vehicle-oil-change-section .filters{margin-bottom:1rem}.vehicle-oil-change-section .filters .filter-select{border:1px solid var(--border-color);background:var(--background-color);color:var(--text-color);border-radius:6px;padding:.5rem 1rem;font-size:.875rem}.vehicle-oil-change-section .filters .filter-select:focus{border-color:var(--primary-color);outline:none}.vehicle-oil-change-section .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:6px;margin-bottom:1rem;padding:.75rem 1rem}.vehicle-oil-change-section .loading-state{text-align:center;color:var(--text-color);padding:3rem}.vehicle-oil-change-section .empty-state{text-align:center;background:var(--background-color);border:2px dashed var(--border-color);border-radius:8px;padding:3rem}.vehicle-oil-change-section .empty-state .empty-icon{color:var(--text-color);margin-bottom:1rem}.vehicle-oil-change-section .empty-state h3{color:var(--text-color);margin:0 0 .5rem}.vehicle-oil-change-section .empty-state p{color:var(--text-color);margin-bottom:1.5rem}.vehicle-oil-change-section .table-container{background:var(--background-color);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.vehicle-oil-change-section .table-container table{border-collapse:collapse;width:100%}.vehicle-oil-change-section .table-container table thead{background:var(--background-color)}.vehicle-oil-change-section .table-container table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);border-bottom:1px solid var(--border-color);padding:.75rem 1rem;font-size:.75rem;font-weight:600}.vehicle-oil-change-section .table-container table tbody tr{border-bottom:1px solid var(--border-color)}.vehicle-oil-change-section .table-container table tbody tr:last-child{border-bottom:none}.vehicle-oil-change-section .table-container table tbody tr:hover{background:var(--background-color)}.vehicle-oil-change-section .table-container table tbody tr td{color:var(--text-color);padding:1rem;font-size:.875rem}.vehicle-oil-change-section .table-container table tbody tr td.actions{gap:.5rem;display:flex}.vehicle-oil-change-section .badge{white-space:nowrap;border-radius:12px;align-items:center;gap:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.vehicle-oil-change-section .badge.badge-success{background:var(--status-green-bg);color:var(--status-green)}.vehicle-oil-change-section .badge.badge-danger{background:var(--status-red-bg);color:var(--status-red)}.vehicle-oil-change-section .badge.badge-warning{background:var(--status-yellow-bg);color:var(--status-yellow)}.vehicle-oil-change-section .badge.badge-secondary{background:var(--background-color);color:var(--text-color)}.vehicle-oil-change-section .btn-icon{cursor:pointer;color:var(--text-color);background:0 0;border:none;border-radius:6px;padding:.5rem;transition:all .2s}.vehicle-oil-change-section .btn-icon:hover{background:var(--background-color);color:var(--primary-color)}.vehicle-oil-change-section .btn-icon.btn-danger:hover{background:var(--status-red-bg);color:var(--status-red)}.vehicle-oil-change-section .btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .2s;display:inline-flex}.vehicle-oil-change-section .btn.btn-primary{background:var(--primary-color);color:#fff}.vehicle-oil-change-section .btn.btn-primary:hover{opacity:.9}.vehicle-oil-change-section .latest-oil-change-card{background:linear-gradient(135deg,var(--primary-color)0%,var(--primary-color)100%);color:#fff;border-radius:12px;margin-bottom:2rem;padding:1.5rem;box-shadow:0 4px 6px #0000001a}.vehicle-oil-change-section .latest-oil-change-card h3{margin:0 0 1rem;font-size:1.125rem;font-weight:600}.vehicle-oil-change-section .latest-oil-change-card .summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;display:grid}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item.full-width{grid-column:1/-1}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item .label{opacity:.9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem;display:block}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item .value{font-size:1.125rem;font-weight:600;display:block}.vehicle-oil-change-section .latest-oil-change-card .summary-grid .summary-item .status-row{align-items:center;gap:1rem;margin-top:.5rem;display:flex}.vehicle-oil-change-section .progress-bar-container{flex:1;align-items:center;gap:.75rem;display:flex}.vehicle-oil-change-section .progress-bar-container .progress-bar{background:#fff3;border-radius:4px;flex:1;height:8px;overflow:hidden}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill{border-radius:4px;height:100%;transition:width .3s}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill.success{background:var(--status-green)}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill.warning{background:var(--status-yellow)}.vehicle-oil-change-section .progress-bar-container .progress-bar .progress-bar-fill.danger{background:var(--status-red)}.vehicle-oil-change-section .progress-bar-container .progress-text{text-align:right;min-width:45px;font-size:.875rem;font-weight:600}.vehicle-oil-change-section .history-title{color:var(--text-color);margin:2rem 0 1rem;font-size:1.125rem;font-weight:600}.vehicle-oil-change-section .latest-row{background:var(--background-color);font-weight:500}.vehicle-oil-change-section .text-sm{font-size:.8125rem}.vehicle-oil-change-section .text-gray{color:var(--text-color)}.vehicle-expenses-section .section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.vehicle-expenses-section .section-header .header-left{align-items:center;gap:.75rem;display:flex}.vehicle-expenses-section .section-header .header-left h2{margin:0;font-size:1.25rem;font-weight:600}.vehicle-expenses-section .empty-state{text-align:center;color:var(--text-color,#6b7280);padding:3rem}.vehicle-expenses-section .empty-state .empty-icon{opacity:.3;margin-bottom:1rem}.vehicle-expenses-section .empty-state h3{margin-bottom:.5rem;font-size:1rem;font-weight:600}.vehicle-expenses-section .empty-state p{font-size:.875rem}.vehicle-expenses-section .error-message{color:var(--status-red,#ef4444);margin-bottom:1rem}.vehicle-expenses-section .amount-income{color:var(--status-green,#22c55e);font-weight:500}.vehicle-expenses-section .amount-expense{color:var(--status-red,#ef4444);font-weight:500}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}}.driver-assignment select{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);text-overflow:ellipsis;flex:1;min-width:0;padding:.625rem .875rem;font-size:.875rem}.driver-assignment select .driver-option{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.section-separator{border:none;border-top:1px solid var(--border-color);margin:2rem 0}.filter-bar{align-items:center;gap:16px;margin-bottom:20px;display:flex}.filter-bar .filter-item{flex-direction:column;display:flex}.filter-bar label{color:var(--text-color);margin-bottom:4px;font-size:.8rem;font-weight:500}.filter-bar select,.filter-bar input{border-radius:var(--radius);border:1px solid var(--border-color);background-color:var(--card-background-color);color:var(--text-color);min-width:180px;padding:8px 12px;font-size:.9rem}.filter-bar input{width:280px}.filter-bar select:focus,.filter-bar input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px var(--primary-color);outline:none}.filter-search-wrap{align-items:center;display:flex;position:relative}.filter-search-icon{color:var(--text-color);pointer-events:none;position:absolute;left:10px}.filter-search-input{padding-left:32px!important}.filter-date-input{min-width:160px}.filter-number-input{min-width:140px}.base-select{appearance:none;border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);color:var(--text-color);cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding:10px 40px 10px 12px;font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.base-select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff26}.base-select:disabled{opacity:.6;cursor:not-allowed}.currency-display{font-weight:500}.currency-display__converted{color:var(--text-color,#6b7280);margin-left:.25rem;font-size:.9em;font-weight:400}.exchange-rate-info{background-color:var(--info-bg);color:var(--info-text);border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.875rem;display:inline-flex}.exchange-rate-info__icon{flex-shrink:0}.exchange-rate-info__text{font-weight:500}.exchange-rate-info__date{opacity:.8;font-weight:400}.exchange-rate-preview{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;padding:1rem}.exchange-rate-preview .preview-header{border-bottom:1px solid var(--border-color);align-items:center;gap:.5rem;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.exchange-rate-preview .preview-header svg{color:var(--primary-color)}.exchange-rate-preview .preview-header .preview-title{color:var(--text-color);font-size:.875rem;font-weight:600}.exchange-rate-preview .preview-loading,.exchange-rate-preview .preview-error{color:var(--text-color);align-items:center;gap:.5rem;padding:.5rem 0;font-size:.8125rem;display:flex}.exchange-rate-preview .preview-loading svg,.exchange-rate-preview .preview-error svg{flex-shrink:0}.exchange-rate-preview .preview-error,.exchange-rate-preview .preview-error svg{color:var(--status-red)}.exchange-rate-preview .preview-content{flex-direction:column;gap:.5rem;display:flex}.exchange-rate-preview .preview-content .preview-row{justify-content:space-between;align-items:center;font-size:.875rem;display:flex}.exchange-rate-preview .preview-content .preview-row .preview-label{color:var(--text-color);font-weight:500}.exchange-rate-preview .preview-content .preview-row .preview-value{color:var(--text-color);font-weight:600}.exchange-rate-preview .preview-content .preview-row .preview-value.highlight{color:var(--primary-color);font-size:1rem}.animate-spin{animation:1s linear infinite spin}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}}.driver-info{border-bottom:1px solid var(--border-color);grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1rem;padding-bottom:1rem;display:grid}.no-driver{color:var(--text-color);margin-bottom:1rem;font-style:italic}.driver-assignment{gap:.75rem;margin-top:1rem;display:flex}.driver-assignment select{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);flex:1;padding:.625rem .875rem;font-size:.875rem}.assign-button{background-color:var(--primary-color);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:.625rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s}.assign-button:hover:not(:disabled){background-color:var(--primary-hover)}.assign-button:disabled{opacity:.6;cursor:not-allowed}.documents-section{margin-top:0}.upload-button{background-color:var(--primary-color);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:background-color .2s;display:flex}.upload-button:hover{background-color:var(--primary-hover)}.no-documents{text-align:center;color:var(--text-color);padding:2rem;font-style:italic}.doc-link{color:var(--primary-color);font-weight:500;text-decoration:none}.doc-link:hover{text-decoration:underline}.form-error{color:#dc2626;border-radius:var(--radius);background-color:#fee2e2;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.form-group{flex-direction:column;display:flex}.form-group.full-width{grid-column:1/-1}.form-group label{color:var(--text-color);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);padding:.625rem .875rem;font-family:inherit;font-size:.9375rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #3f76ff33}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input[type=file]{padding:.5rem}.button-primary,.button-secondary{border-radius:var(--radius);cursor:pointer;padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;transition:all .2s}.button-primary{background-color:var(--primary-color);color:#fff;border:none}.modal-content{background-color:var(--card-background-color);border-radius:var(--radius);width:80vw;min-width:520px;max-width:800px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:1.5rem;overflow-y:auto}.close-button{cursor:pointer;color:var(--text-color);background:0 0;border:none;padding:0;font-size:1.5rem;line-height:1}.card-header-with-action{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-header-with-action .card-title{margin-bottom:0}.card-header-with-action .add-button{cursor:pointer;border-radius:var(--radius);align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.card-header-with-action .add-button.secondary{background-color:var(--background-color);border:1px solid var(--border-color);color:var(--text-color)}.card-header-with-action .add-button.secondary:hover{background-color:var(--background-color);color:var(--text-color)}.add-button.secondary{background-color:var(--background-color);border:1px solid var(--border-color);color:var(--text-color);align-items:center;gap:8px;padding:10px 16px;display:flex}.add-button.secondary:hover{background-color:var(--background-color);color:var(--text-color)}.financials-page{flex-direction:column;gap:24px;display:flex}.financials-page .page-header{justify-content:space-between;align-items:center;display:flex}.financials-page .summary-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;display:grid}.financials-page .stat-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:12px;flex-direction:column;gap:8px;padding:20px;display:flex}.financials-page .stat-card .stat-label{color:var(--text-color);font-size:.95em;font-weight:500}.financials-page .stat-card .stat-value{font-size:1.8em;font-weight:700;line-height:1.2}.financials-page .stat-card .stat-detail{color:var(--text-color);font-size:.9em}.financials-page .top-filters{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:20px;margin-bottom:20px;padding:20px;display:flex}.financials-page .top-filters .filters-header{align-self:center;margin-bottom:0;margin-right:20px;font-size:1.1em;font-weight:600}.financials-page .top-filters .filter-group{flex-direction:column;gap:8px;min-width:150px;display:flex}.financials-page .top-filters .filter-group label{color:var(--text-color);font-size:.9em;font-weight:500}.financials-page .top-filters .filter-group select{border:1px solid var(--border-color);background:var(--background-color);width:100%;color:var(--text-color);appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;border-radius:8px;padding:10px 40px 10px 12px;font-size:.95em}.financials-page .top-filters .filter-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px hsla(var(--primary-hsl),.1);outline:none}.financials-page .content-wrapper{gap:20px;display:flex}.financials-page .main-content{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:12px;flex:1;overflow:hidden}.financials-page .table-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.financials-page .table-header .table-title{font-size:1.1em;font-weight:600}.financials-page .view-toggle{background:var(--background-color);border:1px solid var(--border-color);border-radius:var(--radius);gap:2px;padding:3px;display:flex}.financials-page .view-toggle-btn{border-radius:calc(var(--radius) - 2px);width:32px;height:32px;color:var(--text-color);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.financials-page .view-toggle-btn:hover:not(.active){background:var(--card-background-color);color:var(--text-color)}.financials-page .view-toggle-btn.active{background:var(--card-background-color);color:var(--primary-color);box-shadow:var(--shadow-sm)}.financials-page .year-group-row td{border-bottom:none!important;padding:0!important}.financials-page .year-group-row{background:var(--background-color)!important}.financials-page .year-group-row:hover{background:var(--background-color)!important;cursor:default!important}.financials-page .year-group-content{border-top:2px solid var(--border-color);border-bottom:1px solid var(--border-color);align-items:center;gap:16px;padding:8px 16px;display:flex}.financials-page .year-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-color);min-width:36px;font-size:.75rem;font-weight:800}.financials-page .year-group-stats{font-variant-numeric:tabular-nums;align-items:center;gap:6px;font-size:.78rem;display:flex}.financials-page .year-stat{font-weight:600}.financials-page .year-stat.income{color:var(--status-green)}.financials-page .year-stat.expense{color:var(--status-red)}.financials-page .year-stat.positive{color:var(--status-green)}.financials-page .year-stat.negative{color:var(--status-red)}.financials-page .year-stat-sep{color:var(--border-color)}.financials-page .year-stat-count{color:var(--text-color);margin-left:4px;font-weight:500}.financials-page .transaction-type-badge{border-radius:12px;align-items:center;gap:6px;padding:4px 8px;font-size:.85em;font-weight:600;display:inline-flex}.financials-page .transaction-type-badge.income{background-color:var(--status-green-bg);color:var(--status-green)}.financials-page .transaction-type-badge.expense{background-color:var(--status-red-bg);color:var(--status-red)}.form-section .section-title{border-bottom:1px solid var(--border-color);margin-bottom:16px;padding-bottom:8px;font-size:1.1em;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);background:var(--background-color);width:100%;color:var(--text-color);border-radius:8px;padding:12px;font-size:.95em;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px hsla(var(--primary-hsl),.1);outline:none}.form-group select{appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 7px center;background-repeat:no-repeat;background-size:16px;padding-right:40px}.form-group textarea{resize:vertical;min-height:80px}.bc-root{flex-direction:column;gap:16px;display:flex}.bc-empty{color:var(--text-color);background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);flex-direction:column;align-items:center;gap:12px;padding:64px 24px;display:flex}.bc-empty p{font-size:.9375rem}.bc-strip{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);display:flex;overflow:hidden}.bc-strip-item{flex-direction:column;flex:1;gap:4px;padding:16px 20px;display:flex}.bc-strip-divider{background:var(--border-color);align-self:stretch;width:1px}.bc-strip-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);font-size:.72rem;font-weight:600}.bc-strip-value{font-variant-numeric:tabular-nums;font-size:1.3rem;font-weight:700}.bc-strip-value.income{color:var(--status-green)}.bc-strip-value.expense{color:var(--status-red)}.bc-strip-value.positive{color:var(--status-green)}.bc-strip-value.negative{color:var(--status-red)}.bc-strip-value.neutral{color:var(--text-color)}.bc-years{flex-direction:column;gap:10px;display:flex}.bc-year-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);transition:box-shadow .15s;overflow:hidden}.bc-year-card:hover{box-shadow:var(--shadow-sm)}.bc-year-card.current{border-color:hsla(var(--primary-hsl),.35);box-shadow:0 0 0 3px hsla(var(--primary-hsl),.06)}.bc-year-header{cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:16px;width:100%;padding:16px 20px;transition:background-color .12s;display:flex}.bc-year-header:hover{background:var(--background-color)}.bc-year-left{align-items:center;gap:10px;min-width:120px;display:flex}.bc-year-num{color:var(--text-color);font-size:1.4rem;font-weight:800;line-height:1}.bc-current-badge{text-transform:uppercase;letter-spacing:.04em;background:hsla(var(--primary-hsl),.12);color:var(--primary-color);border-radius:999px;padding:2px 7px;font-size:.68rem;font-weight:700}.bc-tx-count{color:var(--text-color);margin-left:auto;font-size:.78rem;font-weight:500}.bc-year-stats{flex:1;justify-content:flex-end;align-items:center;gap:20px;display:flex}.bc-year-stat{font-variant-numeric:tabular-nums;align-items:center;gap:5px;font-size:.875rem;font-weight:600;display:flex}.bc-year-stat.income{color:var(--status-green)}.bc-year-stat.expense{color:var(--status-red)}.bc-year-balance{font-variant-numeric:tabular-nums;text-align:right;min-width:110px;font-size:.9375rem;font-weight:700}.bc-year-balance.positive{color:var(--status-green)}.bc-year-balance.negative{color:var(--status-red)}.bc-year-toggle{color:var(--text-color);flex-shrink:0}.bc-bars{flex-direction:column;gap:6px;padding:0 20px 16px;display:flex}.bc-bar-row{align-items:center;gap:10px;display:flex}.bc-bar-label{color:var(--text-color);flex-shrink:0;width:64px;font-size:.75rem;font-weight:500}.bc-bar-track{background:var(--border-color);border-radius:3px;flex:1;height:6px;overflow:hidden}.bc-bar-fill{border-radius:3px;height:100%;transition:width .4s}.bc-bar-fill.income{background:var(--status-green)}.bc-bar-fill.expense{background:var(--status-red)}.bc-bar-value{font-variant-numeric:tabular-nums;text-align:right;min-width:100px;font-size:.8rem;font-weight:600}.bc-bar-value.income{color:var(--status-green)}.bc-bar-value.expense{color:var(--status-red)}.bc-months{border-top:1px solid var(--border-color);background:var(--background-color)}.bc-months-head{text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);border-bottom:1px solid var(--border-color);grid-template-columns:1fr 1fr 1fr 1fr;padding:8px 20px;font-size:.7rem;font-weight:700;display:grid}.bc-month-row{border-bottom:1px solid var(--border-color);grid-template-columns:1fr 1fr 1fr 1fr;padding:9px 20px;transition:background-color .1s;display:grid}.bc-month-row:last-child{border-bottom:none}.bc-month-row:hover:not(.totals){background:var(--card-background-color)}.bc-month-row.current-month{background:hsla(var(--primary-hsl),.04)}.bc-month-row.current-month:hover{background:hsla(var(--primary-hsl),.08)}.bc-month-row.totals{background:var(--card-background-color);border-top:2px solid var(--border-color);border-bottom:none}.bc-month-name{color:var(--text-color);align-items:center;gap:6px;font-size:.875rem;font-weight:500;display:flex}.bc-cur-dot{background:var(--primary-color);border-radius:50%;flex-shrink:0;width:6px;height:6px}.bc-month-val{font-variant-numeric:tabular-nums;text-align:right;font-size:.875rem}.bc-month-val.income{color:var(--status-green)}.bc-month-val.expense{color:var(--status-red)}.bc-month-val.positive{color:var(--status-green)}.bc-month-val.negative{color:var(--status-red)}.bc-month-val.bold{font-weight:700}.bc-month-val.zero{color:var(--text-color)}.bc-no-months{color:var(--text-color);border-top:1px solid var(--border-color);padding:16px 20px;font-size:.875rem}.vehicle-detail{padding:0}.vehicle-title{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:600}.error-state{color:#dc2626}.error-banner{color:#dc2626;border-radius:var(--radius);background-color:#fee2e2;margin-bottom:1rem;padding:.75rem 1rem}.detail-grid{grid-template-columns:2fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}@media (max-width:1024px){.detail-grid{grid-template-columns:1fr}}.detail-card{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.5rem}.card-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.card-title{color:var(--text-color);align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.125rem;font-weight:600;display:flex}.card-header .card-title{margin-bottom:0}.form-section{margin-bottom:1.5rem}.section-title{color:var(--text-color);border-bottom:1px solid var(--border-color);margin-bottom:1rem;padding-bottom:.5rem;font-size:1.1rem;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.dynamic-list{flex-direction:column;gap:.75rem;display:flex}.dynamic-list-item{grid-template-columns:3fr 1fr 1fr auto;align-items:center;gap:.75rem;display:grid}.dynamic-list-item select,.dynamic-list-item input{border:1px solid var(--border-color);background-color:var(--card-background-color);width:100%;color:var(--text-color);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.dynamic-list-item select:focus,.dynamic-list-item input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff26}.dynamic-list-item select::placeholder,.dynamic-list-item input::placeholder{color:var(--text-color)}.dynamic-list-item input[type=number]{text-align:right}.parts-item-card{border:1px solid var(--border-color);background-color:var(--card-background-color);border-radius:8px;flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.parts-item-card .parts-item-top{align-items:center;gap:.5rem;display:flex}.parts-item-card .parts-item-top select{border:1px solid var(--border-color);background-color:var(--card-background-color);color:var(--text-color);appearance:none;cursor:pointer;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20width%3D%2220%22%20height%3D%2220%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5%208l5%205%205-5z%22%20fill%3D%22%239CA3AF%22/%3E%3C/svg%3E);background-position:right 8px center;background-repeat:no-repeat;background-size:16px;border-radius:8px;flex:1;padding:10px 36px 10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.parts-item-card .parts-item-top select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff26}.parts-item-card .parts-item-bottom{grid-template-columns:1fr 120px 1fr;gap:.5rem;display:grid}.parts-item-card .parts-field{flex-direction:column;gap:4px;display:flex}.parts-item-card .parts-field .parts-field-label{color:var(--text-color);font-size:.75rem;font-weight:500}.parts-item-card .parts-field input{border:1px solid var(--border-color);background-color:var(--card-background-color);width:100%;color:var(--text-color);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.parts-item-card .parts-field input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff26}.parts-item-card .parts-field input[type=number]{text-align:right}.parts-item-card .parts-field .unit-readonly{background-color:var(--background-color);color:var(--text-color);cursor:default;text-align:center;font-weight:500}.item-type-toggle{flex-shrink:0;gap:4px;display:flex}.item-type-btn{border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:6px 12px;font-size:.78rem;font-weight:500;transition:all .15s}.item-type-btn:hover{background:var(--hover-background,#0000000a);color:var(--text-color)}.item-type-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.add-button{background-color:var(--primary-light);color:var(--primary-color);border:1px solid var(--primary-color);border-radius:var(--radius);cursor:pointer;align-self:flex-start;align-items:center;gap:.5rem;padding:.5rem 1rem;font-weight:500;transition:all .2s;display:flex}.add-button:hover{background-color:var(--primary-color);color:#fff}.remove-button{width:36px;height:36px;color:var(--status-red);border:1px solid var(--status-red);border-radius:var(--radius);cursor:pointer;background-color:#0000;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .2s;display:flex}.remove-button:hover{background-color:var(--status-red);color:#fff}.loading-modal{text-align:center;color:var(--text-color);padding:40px}.form-error{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.9rem}.export-modal{width:100%;max-width:480px}.export-modal .export-modal-body{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem;display:flex}.export-modal .form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.export-modal .loading-inline{color:var(--text-color,#6b7280);padding:.5rem 0;font-size:.875rem}.export-modal .form-actions{border-top:1px solid var(--border-color,#e5e7eb);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.export-modal .form-actions .button-primary{align-items:center;gap:.4rem;display:flex}.tabs{border-bottom:1px solid var(--border-color);gap:12px;margin-bottom:24px;display:flex}.tab-button{cursor:pointer;color:var(--text-color);background-color:#0000;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 20px;font-size:.95rem;font-weight:600;transition:all .2s ease-in-out}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.tab-button:hover:not(.active){color:var(--text-color);background-color:var(--background-hover);border-radius:var(--radius)var(--radius)0 0}.placeholder{background-color:var(--card-background-color);border-radius:var(--radius);border:1px dashed var(--border-color);color:var(--text-color);justify-content:center;align-items:center;padding:60px;font-size:1rem;font-weight:500;display:flex}.request-detail{padding:0}.detail-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.back-button{border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;color:var(--text-color);background:0 0;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:flex}.back-button:hover{background-color:var(--background-color);color:var(--text-color)}.export-button{background-color:var(--primary-color);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;height:40px;padding:10px 16px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.export-button:hover{opacity:.9}.export-button:active{transform:scale(.98)}.page-title{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:600}.loading-state,.error-state{text-align:center;color:var(--text-color);padding:3rem}.error-state{color:var(--status-red);background-color:var(--status-red-bg);border-radius:var(--radius)}.error-banner{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem}.detail-card{background-color:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);margin-bottom:1.5rem;padding:1.5rem}.card-title{color:var(--text-color);border-bottom:1px solid var(--border-color);align-items:center;gap:.5rem;margin:0 0 1rem;padding-bottom:.75rem;font-size:1.125rem;font-weight:600;display:flex}.section-title{color:var(--text-color);margin:1.5rem 0 1rem;font-size:1rem;font-weight:600}.info-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}@media (max-width:768px){.info-grid{grid-template-columns:1fr}}.info-item{flex-direction:column;gap:.25rem;display:flex}.info-item.full-width{grid-column:1/-1}.info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-color);font-size:.75rem;font-weight:500}.info-value{color:var(--text-color);font-size:.9375rem}.info-value.rejection-text{color:var(--status-red)}.price-input{border:1px solid var(--border-color);text-align:right;background-color:var(--card-background-color);border-radius:6px;width:120px;padding:6px 10px;font-size:.875rem}.price-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #4a69ff26}.date-input{border:1px solid var(--border-color);background-color:var(--card-background-color);width:100%;max-width:300px;color:var(--text-color);border-radius:6px;padding:10px 12px;font-family:inherit;font-size:.9375rem}.date-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 2px #4a69ff26}.info-help{color:var(--text-color);margin-top:.25rem;font-size:.8125rem}.approved-value{color:var(--status-green);font-weight:600}.total-card{background-color:var(--background-color)}.total-row{justify-content:space-between;align-items:center;display:flex}.total-label{color:var(--text-color);font-size:1rem;font-weight:600}.total-value{color:var(--primary-color);font-size:1.5rem;font-weight:700}.action-bar{border-top:1px solid var(--border-color);gap:1rem;margin-top:1.5rem;padding-top:1.5rem;display:flex}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.5rem;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-success{background-color:var(--status-green);color:#fff}.btn-success:hover:not(:disabled){background-color:#2da44e}.btn-danger{background-color:var(--status-red);color:#fff}.btn-danger:hover:not(:disabled){background-color:#e53935}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background-color:#64748b66;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background-color:var(--card-background-color);border-radius:var(--radius);width:80vw;min-width:520px;max-width:800px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:32px}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.modal-header h2{color:var(--text-color);margin:0;font-size:1.25rem;font-weight:600}.close-button{cursor:pointer;color:var(--text-color);background:0 0;border:none;padding:4px;font-size:1.5rem;transition:color .2s}.close-button:hover{color:var(--text-color)}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-color);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.form-group textarea{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--card-background-color);resize:vertical;width:100%;padding:12px 16px;font-family:inherit;font-size:1rem}.form-group textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff26}.form-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.button-primary,.button-secondary{border-radius:var(--radius);cursor:pointer;border:none;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.button-primary:disabled,.button-secondary:disabled{opacity:.6;cursor:not-allowed}.button-primary{background-color:var(--primary-color);color:#fff}.button-primary:hover:not(:disabled){background-color:var(--primary-hover)}.button-primary.btn-danger{background-color:var(--status-red)}.button-primary.btn-danger:hover:not(:disabled){background-color:#e53935}.button-secondary{background-color:var(--background-color);color:var(--text-color);border:1px solid var(--border-color)}.button-secondary:hover:not(:disabled){background-color:var(--background-color);color:var(--text-color)}.auth-container{background-color:var(--background-color);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth-card{border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color);padding:40px}.auth-title{text-align:center;color:var(--text-color);margin:0 0 8px;font-size:1.75rem;font-weight:700}.auth-subtitle{text-align:center;color:var(--text-color);margin:0 0 32px;font-size:1rem}.auth-form-group{margin-bottom:20px}.auth-form-group label{color:var(--text-color);margin-bottom:8px;font-size:.875rem;font-weight:600;display:block}.auth-form-group input{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--background-color);width:100%;padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-form-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #3f76ff33}.auth-button{border-radius:var(--radius);cursor:pointer;background-color:var(--primary-color);width:100%;color:var(--text-color);box-shadow:var(--shadow-sm);border:none;margin-top:8px;padding:14px 24px;font-size:1rem;font-weight:600;transition:all .2s}.auth-button:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.auth-footer{text-align:center;color:var(--text-color);margin:24px 0 0;font-size:.9rem}.auth-footer a{color:var(--primary-color);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-error{background-color:var(--status-red-bg);border:1px solid var(--status-red);color:var(--status-red);border-radius:var(--radius);text-align:center;margin-bottom:20px;padding:12px 16px;font-size:.875rem}.auth-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-form-group input:disabled{opacity:.7;cursor:not-allowed}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{width:100%;padding-right:40px}.password-input-wrapper .eye-button{cursor:pointer;color:var(--text-color);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:10px}.password-input-wrapper .eye-button:hover{color:var(--text-color)}.landing{--lp:72px;--lp-v:140px;color:#e2e8f0;min-height:100vh;font-family:var(--font-family-sans);background:#0a0c14;overflow-x:hidden}.landing-nav{z-index:100;padding:18px var(--lp);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0a0c14b3;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.landing-nav__logo{color:#fff;align-items:center;gap:10px;font-size:1.2rem;font-weight:700;display:flex}.landing-nav__img{object-fit:contain;width:32px;height:32px}.landing-nav__links{gap:32px;display:flex}.landing-nav__links a{color:#8892ab;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s}.landing-nav__links a:hover{color:#fff}.landing-nav__right{align-items:center;gap:16px;display:flex}.landing-lang-switcher{background:#ffffff0d;border:1px solid #ffffff14;border-radius:10px;gap:4px;padding:3px;display:flex}.landing-lang-btn{color:#5a6480;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:5px 10px;font-family:inherit;font-size:.75rem;font-weight:600;transition:all .2s}.landing-lang-btn:hover{color:#c4cde0;background:#ffffff0f}.landing-lang-btn.active{color:#7b94ff;background:#4a69ff33}.landing-nav__login{color:#7b94ff;cursor:pointer;background:#4a69ff26;border:1px solid #4a69ff66;border-radius:10px;align-items:center;gap:6px;padding:8px 18px;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s;display:flex}.landing-nav__login:hover{color:#fff;background:#4a69ff40;border-color:#4a69ff}.landing-section-label{letter-spacing:.1em;text-transform:uppercase;color:#4a69ff;background:#4a69ff1a;border:1px solid #4a69ff33;border-radius:100px;margin-bottom:16px;padding:4px 12px;font-size:.72rem;font-weight:700;display:inline-block}.landing-hero{--mx:0px;--my:0px;min-height:100vh;padding:120px var(--lp)80px;justify-content:space-between;align-items:center;gap:60px;display:flex;position:relative;overflow:hidden}.landing-blob{filter:blur(80px);opacity:.18;pointer-events:none;border-radius:50%;animation:8s ease-in-out infinite blobFloat;position:absolute}.landing-blob--1{background:radial-gradient(circle,#4a69ff,#6b21a8);width:500px;height:500px;animation-delay:0s;top:-100px;left:-80px}.landing-blob--2{background:radial-gradient(circle,#10b981,#0891b2);width:400px;height:400px;animation-delay:3s;bottom:-80px;right:100px}.landing-blob--3{opacity:.08;background:radial-gradient(circle,#f59e0b,#ef4444);width:300px;height:300px;animation-delay:5s;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes blobFloat{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-30px)scale(1.05)}}.landing-blob--2{animation-name:blobFloat2}@keyframes blobFloat2{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(24px)scale(1.03)}}.landing-hero__content{z-index:1;flex:1;max-width:580px;animation:.8s both fadeUp}.landing-badge{color:#7b94ff;letter-spacing:.04em;text-transform:uppercase;background:#4a69ff1f;border:1px solid #4a69ff4d;border-radius:100px;align-items:center;gap:8px;margin-bottom:28px;padding:6px 14px;font-size:.78rem;font-weight:600;display:inline-flex}.landing-badge:before{content:"";background:#4a69ff;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 8px #4a69ff}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.landing-hero__title{letter-spacing:-.02em;margin:0 0 24px;font-size:clamp(2.4rem,5vw,3.8rem);font-weight:800;line-height:1.1}.landing-hero__title-line{color:#f0f4ff;display:block}.landing-hero__title-line--accent{background:linear-gradient(135deg,#4a69ff 0%,#a78bfa 50%,#34d399 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-hero__sub{color:#8892ab;max-width:460px;margin:0 0 40px;font-size:1.05rem;line-height:1.7}.landing-hero__actions{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.landing-btn{cursor:pointer;border:none;border-radius:12px;align-items:center;gap:8px;padding:13px 28px;font-family:inherit;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.landing-btn--primary{color:#fff;background:linear-gradient(135deg,#4a69ff,#6b84ff);box-shadow:0 8px 24px #4a69ff59}.landing-btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #4a69ff80}.landing-btn--primary:active{transform:translateY(0)}.landing-btn--primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.landing-btn--ghost{color:#c4cde0;background:#ffffff0f;border:1px solid #ffffff1f}.landing-btn--ghost:hover{color:#fff;background:#ffffff1a;border-color:#ffffff38}.landing-btn--lg{padding:15px 34px;font-size:1rem}.landing-btn--full{justify-content:center;width:100%}.landing-hero__card{z-index:1;transform:translate(var(--mx),var(--my));flex:none;transition:transform .1s ease-out;animation:.8s .2s both fadeUp}.landing-screenshot{border:1px solid #ffffff14;border-radius:16px;width:720px;overflow:hidden;box-shadow:0 32px 80px #0009,0 0 0 1px #4a69ff26,0 0 60px #4a69ff14}.landing-screenshot__img{width:100%;height:auto;display:block}.landing-stats{background:#ffffff0d;border-top:1px solid #ffffff0d;border-bottom:1px solid #ffffff0d;grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.landing-stats__item{padding:40px var(--lp);text-align:center;background:#0a0c14}.landing-stats__val{color:#f0f4ff;letter-spacing:-.02em;background:linear-gradient(135deg,#4a69ff,#a78bfa);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:2.2rem;font-weight:800}.landing-stats__lbl{color:#4f5a72;font-size:.85rem;font-weight:500}.landing-features{padding:var(--lp-v)var(--lp);text-align:center;position:relative}.landing-features:before{content:"";background:linear-gradient(90deg,#0000,#ffffff14,#0000);height:1px;position:absolute;top:0;left:0;right:0}.landing-features__title{color:#f0f4ff;letter-spacing:-.02em;margin:0 0 56px;font-size:2rem;font-weight:700}.landing-features__grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.landing-feature-card{text-align:left;background:#161a2699;border:1px solid #ffffff0f;border-radius:18px;padding:28px 24px;transition:border-color .2s,transform .2s,box-shadow .2s}.landing-feature-card:hover{border-color:#4a69ff4d;transform:translateY(-4px);box-shadow:0 12px 32px #4a69ff1f}.landing-feature-card h3{color:#e2e8f0;margin:14px 0 8px;font-size:1rem;font-weight:700}.landing-feature-card p{color:#5a6480;margin:0;font-size:.85rem;line-height:1.6}.landing-feature-card__icon{color:#7b94ff;background:#4a69ff1f;border:1px solid #4a69ff33;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.landing-modules{padding:var(--lp-v)var(--lp);position:relative}.landing-modules:before{content:"";top:0;left:var(--lp);right:var(--lp);background:linear-gradient(90deg,#0000,#ffffff0f,#0000);height:1px;position:absolute}.landing-modules__title{color:#f0f4ff;letter-spacing:-.02em;max-width:560px;margin:0 0 72px;font-size:2rem;font-weight:700}.landing-module{grid-template-columns:1fr 1fr;align-items:center;gap:80px;margin-bottom:100px;display:grid}.landing-module--reverse{direction:rtl}.landing-module--reverse>*{direction:ltr}.landing-module:last-child{margin-bottom:0}.landing-module__tag{letter-spacing:.08em;text-transform:uppercase;border:1px solid;border-radius:100px;margin-bottom:20px;padding:4px 12px;font-size:.72rem;font-weight:700;display:inline-block}.landing-module__title{color:#f0f4ff;letter-spacing:-.02em;margin:0 0 16px;font-size:1.7rem;font-weight:700;line-height:1.25}.landing-module__desc{color:#8892ab;margin:0 0 28px;font-size:.95rem;line-height:1.7}.landing-module__bullets{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.landing-module__bullets li{color:#c4cde0;align-items:center;gap:10px;font-size:.9rem;display:flex}.landing-module__img-wrap{aspect-ratio:16/10;background:#13162099;border:1px solid #ffffff12;border-radius:16px;position:relative;overflow:hidden;box-shadow:0 24px 60px #00000080}.landing-module__img{object-fit:cover;z-index:1;width:100%;height:100%;display:block;position:relative}.landing-module__img-placeholder{background:radial-gradient(circle at 50% 50%,var(--accent,#4a69ff)18,transparent 70%);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.landing-module__img-placeholder span{color:var(--accent,#4a69ff);opacity:.3;letter-spacing:.1em;text-transform:uppercase;font-size:1.1rem;font-weight:700}.landing-how{padding:var(--lp-v)var(--lp);text-align:center;position:relative}.landing-how:before{content:"";background:linear-gradient(90deg,#0000,#ffffff0f,#0000);height:1px;position:absolute;top:0;left:0;right:0}.landing-how__title{color:#f0f4ff;letter-spacing:-.02em;margin:0 0 64px;font-size:2rem;font-weight:700}.landing-how__steps{grid-template-columns:repeat(3,1fr);gap:40px;display:grid;position:relative}.landing-step{text-align:left;position:relative}.landing-step__num{color:#0000;-webkit-text-stroke:1px #4a69ff40;letter-spacing:-.04em;margin-bottom:16px;font-size:3rem;font-weight:800;line-height:1}.landing-step__line{display:none}.landing-step__title{color:#e2e8f0;margin:0 0 10px;font-size:1.05rem;font-weight:700}.landing-step__desc{color:#5a6480;margin:0;font-size:.875rem;line-height:1.7}.landing-why{padding:var(--lp-v)var(--lp);background:#ffffff04;border-top:1px solid #ffffff0a;border-bottom:1px solid #ffffff0a}.landing-why__grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.landing-why__card{background:#161a2666;border:1px solid #ffffff0d;border-radius:16px;padding:28px;transition:border-color .2s}.landing-why__card:hover{border-color:#4a69ff33}.landing-why__card h4{color:#e2e8f0;margin:12px 0 6px;font-size:.95rem;font-weight:700}.landing-why__card p{color:#5a6480;margin:0;font-size:.83rem;line-height:1.6}.landing-why__icon{color:#7b94ff;background:#4a69ff1a;border:1px solid #4a69ff26;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.landing-faq{padding:var(--lp-v)var(--lp)}.landing-faq__title{color:#f0f4ff;letter-spacing:-.02em;margin:0 0 48px;font-size:2rem;font-weight:700}.landing-faq__list{flex-direction:column;gap:12px;display:flex}.landing-faq__item{background:#161a2666;border:1px solid #ffffff12;border-radius:14px;transition:border-color .2s;overflow:hidden}.landing-faq__item.open{border-color:#4a69ff40}.landing-faq__item.open .landing-faq__chevron{transform:rotate(180deg)}.landing-faq__item.open .landing-faq__a{opacity:1;max-height:200px;padding:0 24px 20px}.landing-faq__q{color:#e2e8f0;cursor:pointer;text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;gap:16px;width:100%;padding:20px 24px;font-family:inherit;font-size:.95rem;font-weight:600;display:flex}.landing-faq__chevron{color:#4f5a72;flex-shrink:0;transition:transform .25s}.landing-faq__a{color:#8892ab;opacity:0;max-height:0;padding:0 24px;font-size:.875rem;line-height:1.7;transition:max-height .3s,padding .3s,opacity .3s;overflow:hidden}.landing-demo{padding:var(--lp-v)var(--lp);position:relative}.landing-demo:before{content:"";background:linear-gradient(90deg,#0000,#4a69ff66,#0000);width:600px;height:1px;position:absolute;top:0;left:50%;transform:translate(-50%)}.landing-demo__inner{grid-template-columns:1fr 1fr;align-items:start;gap:80px;display:grid}.landing-demo__title{color:#f0f4ff;letter-spacing:-.02em;margin:0 0 16px;font-size:2.2rem;font-weight:800}.landing-demo__sub{color:#8892ab;margin:0 0 32px;font-size:.95rem;line-height:1.7}.landing-demo__perks{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.landing-demo__perks li{color:#c4cde0;align-items:center;gap:10px;font-size:.9rem;display:flex}.landing-demo__perks li svg{color:#34d399;flex-shrink:0}.landing-demo__form-wrap{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#161a26cc;border:1px solid #ffffff12;border-radius:20px;padding:40px}.landing-demo__form{flex-direction:column;gap:20px;display:flex}.landing-demo__success{text-align:center;color:#34d399;flex-direction:column;align-items:center;gap:16px;padding:40px 20px;display:flex}.landing-demo__success h3{color:#f0f4ff;margin:0;font-size:1.4rem;font-weight:700}.landing-demo__success p{color:#8892ab;margin:0;font-size:.9rem;line-height:1.6}.landing-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.landing-form-field{flex-direction:column;gap:8px;display:flex}.landing-form-field label{color:#8892ab;text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;font-size:.8rem;font-weight:600;display:flex}.landing-form-field input,.landing-form-field textarea{color:#e2e8f0;resize:vertical;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:10px;padding:12px 16px;font-family:inherit;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.landing-form-field input::placeholder,.landing-form-field textarea::placeholder{color:#3a4155}.landing-form-field input:focus,.landing-form-field textarea:focus{border-color:#4a69ff80;outline:none;box-shadow:0 0 0 3px #4a69ff1a}.landing-footer{padding:40px var(--lp);border-top:1px solid #ffffff0a}.landing-footer__inner{justify-content:space-between;align-items:center;gap:32px;display:flex}.landing-footer__brand{color:#fff;align-items:center;gap:10px;font-size:1rem;font-weight:700;display:flex}.landing-footer__links{gap:28px;display:flex}.landing-footer__links a{color:#4f5a72;font-size:.85rem;text-decoration:none;transition:color .2s}.landing-footer__links a:hover{color:#8892ab}.landing-footer__copy{color:#2e3448;font-size:.8rem}@keyframes fadeUp{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes slideLeft{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(32px)}.reveal.in-view{opacity:1;transform:translateY(0)}.reveal .landing-stats__item,.reveal .landing-feature-card,.reveal .landing-why__card,.reveal .landing-step{opacity:0;transition:opacity .5s,transform .5s;transform:translateY(20px)}.reveal.in-view .landing-stats__item,.reveal.in-view .landing-feature-card,.reveal.in-view .landing-why__card,.reveal.in-view .landing-step{opacity:1;transform:translateY(0)}.reveal.in-view .landing-stats__item:first-child,.reveal.in-view .landing-feature-card:first-child,.reveal.in-view .landing-why__card:first-child,.reveal.in-view .landing-step:first-child{transition-delay:0s}.reveal.in-view .landing-stats__item:nth-child(2),.reveal.in-view .landing-feature-card:nth-child(2),.reveal.in-view .landing-why__card:nth-child(2),.reveal.in-view .landing-step:nth-child(2){transition-delay:80ms}.reveal.in-view .landing-stats__item:nth-child(3),.reveal.in-view .landing-feature-card:nth-child(3),.reveal.in-view .landing-why__card:nth-child(3),.reveal.in-view .landing-step:nth-child(3){transition-delay:.16s}.reveal.in-view .landing-stats__item:nth-child(4),.reveal.in-view .landing-feature-card:nth-child(4),.reveal.in-view .landing-why__card:nth-child(4),.reveal.in-view .landing-step:nth-child(4){transition-delay:.24s}.reveal.in-view .landing-stats__item:nth-child(5),.reveal.in-view .landing-feature-card:nth-child(5),.reveal.in-view .landing-why__card:nth-child(5),.reveal.in-view .landing-step:nth-child(5){transition-delay:.32s}.reveal.in-view .landing-stats__item:nth-child(6),.reveal.in-view .landing-feature-card:nth-child(6),.reveal.in-view .landing-why__card:nth-child(6),.reveal.in-view .landing-step:nth-child(6){transition-delay:.4s}.reveal.in-view .landing-stats__item:nth-child(7),.reveal.in-view .landing-feature-card:nth-child(7),.reveal.in-view .landing-why__card:nth-child(7),.reveal.in-view .landing-step:nth-child(7){transition-delay:.48s}.reveal.in-view .landing-stats__item:nth-child(8),.reveal.in-view .landing-feature-card:nth-child(8),.reveal.in-view .landing-why__card:nth-child(8),.reveal.in-view .landing-step:nth-child(8){transition-delay:.56s}.reveal.in-view .landing-module:nth-child(odd) .landing-module__text{animation:.7s both slideRight}.reveal.in-view .landing-module:nth-child(odd) .landing-module__img-wrap,.reveal.in-view .landing-module:nth-child(2n) .landing-module__text{animation:.7s both slideLeft}.reveal.in-view .landing-module:nth-child(2n) .landing-module__img-wrap{animation:.7s both slideRight}.landing-screenshot{transition:box-shadow .3s,transform .3s}.landing-screenshot:hover{transform:translateY(-6px)scale(1.01);box-shadow:0 40px 100px #000000b3,0 0 0 1px #4a69ff33,0 0 80px #4a69ff1f}@media (max-width:1200px){.landing-module{gap:48px}.landing-screenshot{width:580px}}@media (max-width:1024px){.landing{--lp:32px;--lp-v:80px}.landing-hero{text-align:center;flex-direction:column;padding-top:100px;padding-bottom:60px}.landing-hero__content,.landing-hero__sub{max-width:100%}.landing-hero__actions{justify-content:center}.landing-hero__card{display:none}.landing-features__grid{grid-template-columns:repeat(2,1fr)}.landing-nav__links{display:none}.landing-stats{grid-template-columns:repeat(2,1fr)}.landing-module{grid-template-columns:1fr;gap:32px}.landing-module--reverse{direction:ltr}.landing-how__steps{grid-template-columns:1fr}.landing-why__grid{grid-template-columns:repeat(2,1fr)}.landing-demo__inner{grid-template-columns:1fr;gap:48px}.landing-footer__inner{text-align:center;flex-direction:column}}@media (max-width:600px){.landing{--lp:20px;--lp-v:60px}.landing-features__grid{grid-template-columns:1fr}.landing-stats{grid-template-columns:repeat(2,1fr)}.landing-why__grid,.landing-form-row{grid-template-columns:1fr}.landing-demo__form-wrap{padding:24px}}.users-page .page-header{margin-bottom:2rem}.user-detail-page .detail-header{margin-bottom:1.5rem}.user-detail-page .back-button{border:1px solid var(--border-color);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;transition:all .2s;display:inline-flex}.user-detail-page .back-button:hover{background-color:var(--background-secondary);color:var(--text-primary)}.user-detail-page .loading-state,.user-detail-page .error-state{text-align:center;color:var(--text-secondary);padding:3rem}.user-detail-page .error-state{color:var(--status-red);background-color:var(--status-red-bg);border-radius:var(--radius)}.user-detail-page .profile-header{background-color:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color-light);align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding:1.5rem;display:flex}.user-detail-page .profile-avatar{background:linear-gradient(135deg,var(--primary)0%,var(--primary-hover)100%);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:1.5rem;font-weight:600;display:flex}.user-detail-page .profile-info{flex:1}.user-detail-page .profile-name{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.user-detail-page .profile-meta{align-items:center;gap:.75rem;display:flex}.user-detail-page .role-badge{background-color:var(--primary-light);color:var(--primary);border-radius:20px;align-items:center;padding:4px 12px;font-size:.85rem;font-weight:500;display:inline-flex}.user-detail-page .edit-button{background-color:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.user-detail-page .edit-button:hover{background-color:var(--primary-hover)}.user-detail-page .detail-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;margin-bottom:1.5rem;display:grid}.user-detail-page .detail-card{background-color:var(--content-background);border-radius:var(--radius);border:1px solid var(--border-color-light);padding:1.5rem}.user-detail-page .detail-card.driver-card{margin-top:0}.user-detail-page .card-title{color:var(--text-primary);border-bottom:1px solid var(--border-color-light);align-items:center;gap:.5rem;margin:0 0 1.25rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:600;display:flex}.user-detail-page .card-title svg{color:var(--primary)}.user-detail-page .info-list{flex-direction:column;gap:1rem;display:flex}.user-detail-page .info-row{align-items:flex-start;gap:1rem;display:flex}.user-detail-page .info-icon{background-color:var(--background-secondary);width:36px;height:36px;color:var(--primary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.user-detail-page .info-content{flex-direction:column;gap:2px;display:flex}.user-detail-page .info-label{color:var(--text-tertiary);font-size:.8rem;font-weight:500}.user-detail-page .info-value{color:var(--text-primary);font-size:.95rem;font-weight:500}.user-detail-page .license-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;display:grid}.user-detail-page .license-item.full-width{grid-column:1/-1}.user-detail-page .license-label{color:var(--text-tertiary);margin-bottom:4px;font-size:.8rem;font-weight:500;display:block}.user-detail-page .license-value{color:var(--text-primary);font-size:.95rem;font-weight:500;display:block}.user-detail-page .license-value.highlight{color:var(--primary)}.user-detail-page .card-title-row{border-bottom:1px solid var(--border-color-light);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;display:flex}.user-detail-page .card-title-row .card-title{border:none;margin:0;padding:0}.user-detail-page .card-actions{flex-shrink:0;gap:.5rem;display:flex}.user-detail-page .ud-btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.3rem;padding:5px 12px;font-size:.82rem;font-weight:500;transition:all .15s;display:inline-flex}.user-detail-page .ud-btn:active{transform:scale(.97)}.user-detail-page .ud-btn-edit{background:var(--primary-light);color:var(--primary)}.user-detail-page .ud-btn-edit:hover,.user-detail-page .ud-btn-save{background:var(--primary);color:#fff}.user-detail-page .ud-btn-save:hover{background:var(--primary-hover)}.user-detail-page .ud-btn-cancel{background:var(--background-secondary);color:var(--text-secondary)}.user-detail-page .ud-btn-cancel:hover{background:var(--border-color)}.user-detail-page .ud-field-input{border:1px solid var(--border-color);border-radius:var(--radius);width:100%;color:var(--text-primary);background:var(--background-secondary);box-sizing:border-box;outline:none;padding:5px 8px;font-size:.88rem;transition:border-color .15s}.user-detail-page .ud-field-input:focus{border-color:var(--primary);background:var(--content-background)}.user-detail-page .ud-empty{color:var(--text-tertiary);margin:0;padding:.5rem 0;font-size:.9rem}.user-detail-page .ud-delete-btn{background:var(--status-red-bg);color:var(--status-red);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:6px;transition:background .15s;display:flex}.user-detail-page .ud-delete-btn:hover{background:#d92d202e}.user-detail-page .ud-add-card-form{border-top:1px dashed var(--border-color);flex-direction:column;gap:.5rem;margin-top:.5rem;padding:.75rem 0 .25rem;display:flex}.user-detail-page .ud-add-card-actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.user-detail-page .ud-add-card-btn{background:var(--primary-light);color:var(--primary);border:1.5px dashed var(--primary);border-radius:var(--radius);cursor:pointer;align-items:center;gap:.4rem;margin-top:.75rem;padding:7px 14px;font-size:.88rem;font-weight:500;transition:background .15s;display:inline-flex}.user-detail-page .ud-add-card-btn:hover{background:var(--primary);color:#fff}.user-detail-page .no-license{text-align:center;color:var(--text-tertiary);flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex}.user-detail-page .no-license svg{color:var(--text-tertiary);margin-bottom:.75rem}.user-detail-page .no-license p{margin:0 0 1rem;font-size:.95rem}.user-detail-page .add-license-button{background-color:var(--primary-light);color:var(--primary);border:1px solid var(--primary);border-radius:var(--radius);cursor:pointer;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:500;transition:all .2s;display:inline-flex}.user-detail-page .add-license-button:hover{background-color:var(--primary);color:#fff}.user-form-container{background-color:var(--content-background);border-radius:var(--radius);max-width:600px;box-shadow:var(--shadow-card);border:1px solid var(--border-color-light);margin:0 auto;padding:2rem}.user-form-container h2{text-align:center;color:var(--text-primary);margin-bottom:2rem}.user-form-container .user-form{flex-direction:column;gap:1.25rem;display:flex}.user-form-container .dept-memberships-section{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);padding:1.25rem}.user-form-container .dept-memberships-section h3{color:var(--text-primary);margin:0 0 .375rem;font-size:1rem;font-weight:600}.user-form-container .dept-memberships-section .dept-hint{color:var(--text-secondary);margin:0 0 1rem;font-size:.8125rem}.user-form-container .dept-row{border-bottom:1px solid var(--border-color-light);align-items:center;gap:1rem;padding:.5rem 0;display:flex}.user-form-container .dept-row:last-child{border-bottom:none}.user-form-container .dept-check-label{cursor:pointer;min-width:160px;color:var(--text-primary);align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.user-form-container .dept-check-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.user-form-container .dept-role-select{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-primary);flex:1;padding:6px 10px;font-size:.875rem}.user-form-container .dept-role-select:focus{border-color:var(--primary);outline:none}.user-form-container .driver-profile-toggle{margin:1rem 0}.user-form-container .driver-profile-toggle .toggle-button{background-color:var(--background-secondary);border:1px dashed var(--border-color-strong);border-radius:var(--radius);width:100%;color:var(--text-primary);cursor:pointer;text-align:left;padding:12px 16px;font-size:.9rem;font-weight:500;transition:all .2s}.user-form-container .driver-profile-toggle .toggle-button:hover{background-color:var(--background-tertiary);border-color:var(--primary);color:var(--primary)}.user-form-container .driver-profile-toggle .toggle-button:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.user-form-container .driver-profile-section{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);margin-top:1.5rem;padding:1.5rem}.user-form-container .driver-profile-section h3{color:var(--text-primary);border-bottom:2px solid var(--primary);margin-top:0;margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.125rem}.user-form-container .driver-profile-section .form-group{margin-bottom:1rem}.user-form-container .driver-profile-section .full-width{grid-column:1/-1}.user-form-container .form-group{flex-direction:column;display:flex}.user-form-container .form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500}.user-form-container .form-group input,.user-form-container .form-group select,.user-form-container .form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);color:var(--text-primary);padding:12px 16px;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.user-form-container .form-group input:focus,.user-form-container .form-group select:focus,.user-form-container .form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.user-form-container .form-group input:disabled,.user-form-container .form-group select:disabled,.user-form-container .form-group textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--background-secondary)}.user-form-container .form-group textarea{resize:vertical;min-height:80px}.user-form-container .form-group .error{color:var(--status-red);margin-top:.25rem;font-size:.875rem}.user-form-container .form-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;display:grid}.user-form-container .form-section{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);padding:1.25rem 1.5rem}.user-form-container .form-section-title{color:var(--text-primary);border-bottom:2px solid var(--primary);margin:0 0 1rem;padding-bottom:.5rem;font-size:1rem;font-weight:600}.user-form-container .uf-card-item{border-bottom:1px solid var(--border-color-light);align-items:center;gap:.75rem;padding:.6rem 0;display:flex}.user-form-container .uf-card-item:last-of-type{border-bottom:none}.user-form-container .uf-card-info{flex-direction:column;flex:1;gap:2px;display:flex}.user-form-container .uf-card-label{color:var(--text-primary);font-size:.88rem;font-weight:600}.user-form-container .uf-card-number{color:var(--text-secondary);font-family:monospace;font-size:.82rem}.user-form-container .uf-card-delete{background:var(--status-red-bg);color:var(--status-red);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:background .15s;display:flex}.user-form-container .uf-card-delete:hover{background:#d92d202e}.user-form-container .uf-add-card-form{border-top:1px dashed var(--border-color);flex-direction:column;gap:.75rem;margin-top:.5rem;padding:.75rem 0 .25rem;display:flex}.user-form-container .uf-add-card-actions{align-items:center;gap:.5rem;display:flex}.user-form-container .uf-add-card-actions .btn-sm{align-items:center;gap:.3rem;padding:6px 14px;font-size:.85rem;display:inline-flex}.user-form-container .uf-add-card-btn{background:var(--primary-light);color:var(--primary);border:1.5px dashed var(--primary);border-radius:var(--radius);cursor:pointer;align-items:center;gap:.4rem;margin-top:.75rem;padding:8px 14px;font-size:.88rem;font-weight:500;transition:background .15s;display:inline-flex}.user-form-container .uf-add-card-btn:hover{background:var(--primary);color:#fff}.user-form-container .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.user-form-container .form-actions{justify-content:flex-end;gap:1rem;margin-top:1.5rem;display:flex}.user-form-container .form-actions .btn{border-radius:var(--radius);cursor:pointer;border:none;padding:12px 24px;font-size:1rem;font-weight:600;transition:all .2s}.user-form-container .form-actions .btn:disabled{opacity:.6;cursor:not-allowed}.user-form-container .form-actions .btn-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.user-form-container .form-actions .btn-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.user-form-container .form-actions .btn-secondary{background-color:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.user-form-container .form-actions .btn-secondary:hover:not(:disabled){background-color:var(--background-tertiary);color:var(--text-primary)}.role-form-modal{max-width:800px;max-height:90vh;overflow-y:auto}.role-form-modal .modal-header{border-bottom:2px solid var(--border-color-light);justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.role-form-modal .modal-header h2{color:var(--text-primary);margin:0;font-size:1.5rem}.role-form-modal .modal-header .close-button{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:2rem;line-height:1;transition:all .2s;display:flex}.role-form-modal .modal-header .close-button:hover{background-color:var(--background-secondary);color:var(--text-primary)}.role-form-modal .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.875rem}.role-form-modal .form-section{margin-bottom:2rem}.role-form-modal .form-section h3{color:var(--text-primary);margin:0 0 1rem;font-size:1.125rem;font-weight:600}.role-form-modal .form-section .form-group{margin-bottom:1.25rem}.role-form-modal .form-section .form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.role-form-modal .form-section .form-group input,.role-form-modal .form-section .form-group textarea{border:1px solid var(--border-color-strong);border-radius:var(--radius);background-color:var(--content-background);width:100%;color:var(--text-primary);padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.role-form-modal .form-section .form-group input:focus,.role-form-modal .form-section .form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #4a69ff26}.role-form-modal .form-section .form-group input:disabled,.role-form-modal .form-section .form-group textarea:disabled{opacity:.6;cursor:not-allowed;background-color:var(--background-secondary)}.role-form-modal .form-section .form-group textarea{resize:vertical;min-height:80px}.role-form-modal .form-section .form-group .error{color:var(--status-red);margin-top:.25rem;font-size:.875rem}.role-form-modal .combine-departments-section{margin-bottom:1.25rem}.role-form-modal .combine-departments-toggle{border:1px solid var(--border-color-light);border-radius:var(--radius);background-color:var(--background-secondary);cursor:pointer;align-items:flex-start;gap:.875rem;padding:1rem;transition:border-color .2s,background-color .2s;display:flex}.role-form-modal .combine-departments-toggle:hover{border-color:var(--border-color-strong);background-color:var(--content-background)}.role-form-modal .combine-departments-toggle:has(input:checked){background-color:#4a69ff0d;border-color:#4a69ff66}.role-form-modal .combine-departments-toggle input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;margin-top:3px}.role-form-modal .combine-departments-info{flex-direction:column;gap:3px;display:flex}.role-form-modal .combine-departments-label{color:var(--text-primary);font-size:.9375rem;font-weight:600}.role-form-modal .combine-departments-desc{color:var(--text-secondary);margin:0;font-size:.8125rem;line-height:1.4}.role-form-modal .scope-accordion{flex-direction:column;gap:.5rem;display:flex}.role-form-modal .scope-group{border:1px solid var(--border-color-light);border-radius:var(--radius);overflow:hidden}.role-form-modal .scope-group.expanded{border-color:var(--border-color-strong)}.role-form-modal .scope-group-header{background-color:var(--background-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:background-color .15s;display:flex}.role-form-modal .scope-group-header:hover{background-color:var(--content-background)}.role-form-modal .scope-group-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;display:flex}.role-form-modal .scope-chevron{color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.role-form-modal .scope-chevron.open{transform:rotate(180deg)}.role-form-modal .scope-perm-badge{background-color:var(--primary);color:#fff;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 6px;font-size:.7rem;font-weight:700;line-height:1;display:inline-flex}.role-form-modal .scope-group-body{border-top:1px solid var(--border-color-light);background-color:var(--content-background);padding:.75rem}.role-form-modal .permissions-grid{gap:.625rem;display:grid}.role-form-modal .permission-module{background-color:var(--background-secondary);border:1px solid var(--border-color-light);border-radius:var(--radius);transition:border-color .2s,box-shadow .2s;overflow:hidden}.role-form-modal .permission-module:hover{border-color:var(--border-color-strong)}.role-form-modal .permission-module.has-perms{border-color:#4a69ff59}.role-form-modal .permission-module.has-perms:hover{border-color:#4a69ff8c}.role-form-modal .permission-module.has-perms .module-header{background-color:#4a69ff0a}.role-form-modal .module-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:.75rem;padding:.875rem 1rem;transition:background-color .15s;display:flex}.role-form-modal .module-header:hover{background-color:var(--content-background)}.role-form-modal .module-header-left{flex:1;align-items:flex-start;gap:.75rem;min-width:0;display:flex}.role-form-modal .module-header-left input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;margin-top:3px}.role-form-modal .module-info{flex-direction:column;gap:2px;min-width:0;display:flex}.role-form-modal .module-name{color:var(--text-primary);font-size:.9375rem;font-weight:600}.role-form-modal .module-description{color:var(--text-secondary);margin:0;font-size:.8125rem;line-height:1.4}.role-form-modal .module-chevron{color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.role-form-modal .module-chevron.open{transform:rotate(180deg)}.role-form-modal .module-content{border-top:1px solid var(--border-color-light);background-color:var(--content-background);flex-direction:column;gap:.75rem;padding:.875rem 1rem 1rem;display:flex}.role-form-modal .simple-actions{flex-wrap:wrap;gap:.5rem;display:flex}.role-form-modal .action-checkbox{cursor:pointer;border-radius:var(--radius);border:1px solid var(--border-color-light);background-color:var(--background-secondary);white-space:nowrap;align-items:center;gap:.5rem;padding:.375rem .625rem;transition:all .15s;display:flex}.role-form-modal .action-checkbox:hover{border-color:var(--border-color-strong);background-color:var(--content-background)}.role-form-modal .action-checkbox input[type=checkbox]{cursor:pointer;width:14px;height:14px;accent-color:var(--primary)}.role-form-modal .action-checkbox span{color:var(--text-secondary);font-size:.8125rem}.role-form-modal .action-checkbox:has(input:checked){background-color:#4a69ff0f;border-color:#4a69ff66}.role-form-modal .action-checkbox:has(input:checked) span{color:var(--primary);font-weight:500}.role-form-modal .granular-actions{flex-direction:column;gap:.75rem;display:flex}.role-form-modal .permission-group{background-color:var(--background-secondary);border-radius:var(--radius);border:1px solid var(--border-color-light);flex-direction:column;gap:.375rem;padding:.625rem .75rem;display:flex}.role-form-modal .permission-group .group-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em;font-size:.8rem;font-weight:600}.role-form-modal .radio-options{flex-direction:column;gap:.25rem;display:flex}.role-form-modal .radio-options.horizontal{flex-flow:wrap;gap:.5rem}.role-form-modal .radio-option{cursor:pointer;border-radius:calc(var(--radius) - 2px);align-items:center;gap:.5rem;padding:.3rem .5rem;transition:background-color .15s;display:flex}.role-form-modal .radio-option:hover{background-color:var(--content-background)}.role-form-modal .radio-option input[type=radio]{cursor:pointer;width:14px;height:14px;accent-color:var(--primary)}.role-form-modal .radio-option span{color:var(--text-secondary);font-size:.8125rem}.role-form-modal .radio-option:has(input:checked) span{color:var(--primary);font-weight:500}.role-form-modal .form-actions{border-top:1px solid var(--border-color-light);justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.role-form-modal .form-actions button{border-radius:var(--radius);cursor:pointer;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.role-form-modal .form-actions button:disabled{opacity:.6;cursor:not-allowed}.role-form-modal .form-actions .button-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.role-form-modal .form-actions .button-primary:hover:not(:disabled){background-color:var(--primary-hover);box-shadow:var(--shadow-md)}.role-form-modal .form-actions .button-secondary{background-color:var(--background-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.role-form-modal .form-actions .button-secondary:hover:not(:disabled){background-color:var(--background-tertiary);color:var(--text-primary)}.roles-page .page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.roles-page .page-header .page-title{color:var(--text-primary);align-items:center;gap:.75rem;margin:0;font-size:1.75rem;font-weight:700;display:flex}.roles-page .page-header .add-button{background-color:var(--primary);color:#fff;border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-sm);border:none;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:all .2s;display:flex}.roles-page .page-header .add-button:hover{background-color:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.roles-page .page-header .add-button:active{transform:translateY(0)}.roles-page .error-message{background-color:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:1rem}.roles-page .empty-state{text-align:center;color:var(--text-secondary);grid-column:1/-1;padding:4rem 2rem}.roles-page .empty-state svg{opacity:.5;margin-bottom:1rem}.roles-page .empty-state p{font-size:1.125rem}.roles-page .roles-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;display:grid}.roles-page .role-card{background-color:var(--content-background);border:1px solid var(--border-color-light);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:1.5rem;transition:all .2s}.roles-page .role-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-color-strong)}.roles-page .role-card .role-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:1rem;display:flex}.roles-page .role-card .role-card-header .role-info{flex:1}.roles-page .role-card .role-card-header .role-info .role-name{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.roles-page .role-card .role-card-header .role-info .system-badge{background-color:var(--primary-light);color:var(--primary);text-transform:uppercase;letter-spacing:.5px;border-radius:12px;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.roles-page .role-card .role-card-header .role-info .combined-badge{color:#059669;text-transform:uppercase;letter-spacing:.5px;background-color:#10b9811f;border-radius:12px;margin-left:.375rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-block}.roles-page .role-card .role-card-header .role-actions{gap:.5rem;display:flex}.roles-page .role-card .role-card-header .role-actions .icon-button{border-radius:var(--radius);cursor:pointer;background-color:var(--background-secondary);width:32px;height:32px;color:var(--text-secondary);border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.roles-page .role-card .role-card-header .role-actions .icon-button:hover{transform:scale(1.1)}.roles-page .role-card .role-card-header .role-actions .icon-button.view:hover{background-color:var(--background-tertiary);color:var(--text-primary)}.roles-page .role-card .role-card-header .role-actions .icon-button.edit:hover{background-color:var(--primary-light);color:var(--primary)}.roles-page .role-card .role-card-header .role-actions .icon-button.delete:hover{background-color:var(--status-red-bg);color:var(--status-red)}.roles-page .role-card .role-description{color:var(--text-secondary);min-height:3rem;margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.roles-page .role-card .role-footer{border-top:1px solid var(--border-color-light);justify-content:space-between;align-items:center;padding-top:1rem;display:flex}.roles-page .role-card .role-footer .role-stat{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.roles-page .role-card .role-footer .role-stat svg{color:var(--primary)}.roles-page .role-card .role-footer .role-date{color:var(--text-tertiary);font-size:.75rem}.organization-settings{max-width:1200px;margin:0 auto;padding:2rem}.organization-settings .settings-header{margin-bottom:2rem}.organization-settings .settings-header .back-button{border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;background:0 0;border-radius:.5rem;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s;display:inline-flex}.organization-settings .settings-header .back-button:hover{background:var(--hover-bg);border-color:var(--border-color);color:var(--text-color)}.organization-settings .settings-header .settings-title{color:var(--text-color);margin:0;font-size:1.75rem;font-weight:700}.organization-settings .settings-tabs{border-bottom:2px solid var(--border-color);gap:.5rem;margin-bottom:2rem;display:flex}.organization-settings .settings-tabs .tab-button{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-bottom:3px solid #0000;margin-bottom:-2px;padding:.875rem 1.5rem;font-size:.9375rem;font-weight:500;transition:all .2s}.organization-settings .settings-tabs .tab-button:hover{color:var(--text-color);background:var(--hover-bg)}.organization-settings .settings-tabs .tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.organization-settings .alert{border-radius:.5rem;margin-bottom:1.5rem;padding:1rem;font-size:.875rem}.organization-settings .alert.alert-error{background:var(--status-red-bg);color:var(--status-red);border:1px solid var(--status-red)}.organization-settings .alert.alert-success{background:var(--status-green-bg);color:var(--status-green);border:1px solid var(--status-green)}.organization-settings .settings-content{flex-direction:column;gap:1.5rem;display:flex}.organization-settings .settings-content .settings-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:.75rem;padding:2rem}.organization-settings .settings-content .settings-card .card-title{color:var(--text-color);margin:0 0 .5rem;font-size:1.25rem;font-weight:600}.organization-settings .settings-content .settings-card .card-description{color:var(--text-color);margin:0 0 2rem;font-size:.875rem;line-height:1.5}.organization-settings .settings-content .settings-card .form-group{margin-bottom:1.5rem}.organization-settings .settings-content .settings-card .form-group .form-label{color:var(--text-color);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.organization-settings .settings-content .settings-card .form-group .form-input{border:1px solid var(--border-color);background:var(--input-background);width:100%;max-width:400px;color:var(--text-color);border-radius:.5rem;padding:.75rem;font-family:inherit;font-size:.875rem;transition:all .2s}.organization-settings .settings-content .settings-card .form-group .form-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-20);outline:none}.organization-settings .settings-content .settings-card .form-group select{border:1px solid var(--border-color);background:var(--input-background);width:100%;max-width:300px;color:var(--text-color);border-radius:.5rem;padding:.75rem;font-size:.875rem;transition:all .2s}.organization-settings .settings-content .settings-card .form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-color-alpha-20);outline:none}.organization-settings .dept-toggle-list{flex-direction:column;gap:0;display:flex}.organization-settings .dept-toggle-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:1.5rem;padding:1rem 0;display:flex}.organization-settings .dept-toggle-row:last-child{border-bottom:none}.organization-settings .dept-toggle-info{flex-direction:column;gap:.25rem;display:flex}.organization-settings .dept-toggle-label{color:var(--text-color);font-size:.9rem;font-weight:600}.organization-settings .dept-toggle-desc{color:var(--text-color);font-size:.8rem;line-height:1.4}.organization-settings .toggle-switch{background:var(--border-color);cursor:pointer;border:none;border-radius:12px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .2s;position:relative}.organization-settings .toggle-switch.on{background:var(--primary-color)}.organization-settings .toggle-switch .toggle-thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.organization-settings .toggle-switch.on .toggle-thumb{transform:translate(20px)}.organization-settings .form-actions{gap:1rem;display:flex}.organization-settings .form-actions .btn{cursor:pointer;border:none;border-radius:.5rem;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.875rem;font-weight:500;transition:all .2s;display:inline-flex}.organization-settings .form-actions .btn.btn-primary{background:var(--primary-color);color:#fff}.organization-settings .form-actions .btn.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.organization-settings .form-actions .btn.btn-primary:disabled{opacity:.6;cursor:not-allowed}.organization-settings .form-actions .btn .spinner{animation:1s linear infinite spin}.profile-page{max-width:760px;margin:0 auto;padding-bottom:2rem}.profile-page .pp-hero{background:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);text-align:center;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:1.5rem;padding:2rem 1.5rem 1.5rem;display:flex}.profile-page .pp-avatar-wrap{background:linear-gradient(135deg,var(--primary-color)0%,var(--primary-hover)100%);cursor:pointer;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:88px;height:88px;margin-bottom:.5rem;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000001f}.profile-page .pp-avatar-wrap:hover .pp-avatar-overlay{opacity:1}.profile-page .pp-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.profile-page .pp-avatar-initials{color:#fff;-webkit-user-select:none;user-select:none;font-size:2rem;font-weight:700}.profile-page .pp-avatar-overlay{color:#fff;opacity:0;background:#0006;border-radius:50%;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.profile-page .pp-avatar-spinner{border:3px solid #fff6;border-left-color:#fff;border-radius:50%;width:22px;height:22px;animation:.8s linear infinite pp-spin}@keyframes pp-spin{to{transform:rotate(360deg)}}.profile-page .pp-hero-name{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:700}.profile-page .pp-hero-email{color:var(--text-color);margin:0;font-size:.9rem}.profile-page .pp-hero-role{background:var(--background-color);color:var(--primary-color);border-radius:20px;margin-top:.25rem;padding:3px 12px;font-size:.82rem;font-weight:500;display:inline-block}.profile-page .pp-content{flex-direction:column;gap:1.25rem;display:flex}.profile-page .pp-card{background:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);padding:1.25rem 1.5rem}.profile-page .pp-card-title{color:var(--primary-color);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);align-items:center;gap:.5rem;margin-bottom:1rem;padding-bottom:.75rem;font-size:.85rem;font-weight:700;display:flex}.profile-page .pp-section-actions{justify-content:flex-end;gap:.5rem;margin-bottom:.75rem;display:flex}.profile-page .pp-btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:.3rem;padding:6px 14px;font-size:.85rem;font-weight:500;transition:all .15s;display:inline-flex}.profile-page .pp-btn:active{transform:scale(.97)}.profile-page .pp-btn-edit{background:var(--background-color);color:var(--primary-color)}.profile-page .pp-btn-edit:hover,.profile-page .pp-btn-save{background:var(--primary-color);color:#fff}.profile-page .pp-btn-save:hover{background:var(--primary-hover)}.profile-page .pp-btn-save:disabled{opacity:.6;cursor:not-allowed}.profile-page .pp-btn-cancel{background:var(--background-color);color:var(--text-color)}.profile-page .pp-btn-cancel:hover{background:var(--border-color)}.profile-page .pp-error{color:var(--status-red);background:var(--status-red-bg);border-radius:var(--radius);margin-bottom:.5rem;padding:.5rem .75rem;font-size:.85rem}.profile-page .pp-field{border-bottom:1px solid var(--border-color);align-items:center;gap:1rem;padding:.65rem 0;display:flex}.profile-page .pp-field:last-child{border-bottom:none}.profile-page .pp-field-label{color:var(--text-color);align-items:center;min-width:120px;font-size:.82rem;font-weight:600;display:flex}.profile-page .pp-field-value{color:var(--text-color);flex:1;font-size:.95rem;font-weight:500}.profile-page .pp-field-input{border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);background:var(--background-color);outline:none;flex:1;padding:6px 10px;font-size:.9rem;transition:border-color .15s}.profile-page .pp-field-input:focus{border-color:var(--primary-color);background:var(--card-background-color)}.profile-page .pp-card-item{border-bottom:1px solid var(--border-color);align-items:center;gap:.875rem;padding:.75rem 0;display:flex}.profile-page .pp-card-item:last-of-type{border-bottom:none}.profile-page .pp-card-icon{background:linear-gradient(135deg,var(--primary-color)0%,var(--primary-hover)100%);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.profile-page .pp-card-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.profile-page .pp-card-label{color:var(--text-color);font-size:.9rem;font-weight:600}.profile-page .pp-card-number{color:var(--text-color);letter-spacing:.5px;font-family:monospace;font-size:.82rem}.profile-page .pp-card-holder{color:var(--text-color);text-transform:uppercase;letter-spacing:.3px;font-size:.78rem}.profile-page .pp-card-delete{background:var(--status-red-bg);color:var(--status-red);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:6px;transition:background .15s;display:flex}.profile-page .pp-card-delete:hover{background:#d92d202e}.profile-page .pp-add-card-form{border-top:1px dashed var(--border-color);flex-direction:column;gap:.5rem;margin-top:.5rem;padding:.75rem 0 .25rem;display:flex}.profile-page .pp-add-card-actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.profile-page .pp-add-card-btn{background:var(--background-color);color:var(--primary-color);border:1.5px dashed var(--primary-color);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;gap:.4rem;width:100%;margin-top:.75rem;padding:8px 16px;font-size:.88rem;font-weight:500;transition:background .15s;display:inline-flex}.profile-page .pp-add-card-btn:hover{background:var(--primary-color);color:#fff}.profile-page .pp-logout-btn{border-radius:var(--radius);cursor:pointer;background:var(--status-red-bg);width:100%;color:var(--status-red);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.profile-page .pp-logout-btn:hover{background:var(--status-red);color:#fff}.page-header-left{align-items:center;gap:.75rem;display:flex}.filter-select{border:1px solid var(--color-border,#e5e7eb);background:var(--color-surface,#fff);cursor:pointer;border-radius:6px;height:36px;padding:0 .75rem;font-size:.875rem}.badge{background:var(--color-surface-alt,#f3f4f6);color:var(--color-text-secondary,#6b7280);border-radius:9999px;padding:.15rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.badge.badge-success{color:#065f46;background:#d1fae5}.action-buttons{align-items:center;gap:.5rem;display:flex}.loading-state,.empty-state{text-align:center;color:var(--color-text-secondary,#6b7280);padding:3rem}.export-template-page{max-width:1200px;margin:0 auto;padding:0 0 80px}.etp-spinner{text-align:center;color:var(--text-color);padding:60px}.etp-header{border-bottom:1px solid var(--border-color);background:var(--background-color);z-index:20;align-items:center;gap:14px;margin-bottom:24px;padding:20px 0 22px;display:flex;position:sticky;top:0}.etp-back{cursor:pointer;color:var(--text-color);white-space:nowrap;background:0 0;border:none;border-radius:7px;align-items:center;gap:5px;padding:6px 10px;font-size:.85rem;display:flex}.etp-back:hover{background:var(--background-color)}.etp-title{flex:1;margin:0;font-size:1.2rem;font-weight:700}.etp-header-actions{gap:8px;display:flex}.etp-error{background:var(--status-red-bg);color:var(--status-red);border:1px solid var(--status-red);border-radius:8px;margin-bottom:16px;padding:10px 16px;font-size:.875rem}.etp-body{flex-direction:column;gap:16px;display:flex}.etp-section{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:12px;padding:20px 24px}.etp-section-title{color:var(--text-color);margin:0 0 4px;font-size:.9rem;font-weight:700}.etp-hint{color:var(--text-color);margin:0 0 14px;font-size:.78rem}.etp-hint code{background:var(--background-color);color:var(--text-color);border-radius:4px;padding:1px 5px;font-family:monospace;font-size:.75rem}.etp-note{color:var(--text-color);background:var(--background-color);border:1px solid var(--border-color);border-radius:6px;margin:8px 0 0;padding:8px 12px;font-size:.78rem}.etp-note code{background:var(--border-color);border-radius:3px;padding:1px 4px;font-family:monospace;font-size:.73rem}.etp-note strong{color:var(--text-color)}.etp-basic-row{grid-template-columns:2fr 2fr 1fr;align-items:start;gap:16px;display:grid}.form-group{flex-direction:column;gap:5px;display:flex}.form-group label{color:var(--text-color);font-size:.78rem;font-weight:600}.form-group input[type=text],.form-group select{border:1px solid var(--border-color);background:var(--card-background-color);border-radius:7px;padding:8px 11px;font-size:.875rem}.form-group input[type=text]:focus,.form-group select:focus{border-color:var(--primary-color);outline:none}.etp-checkbox-group label{cursor:pointer;align-items:center;gap:8px;padding-top:24px;display:flex;font-weight:400!important}.etp-checkbox-group label input{cursor:pointer;width:15px;height:15px}.field-hint{color:var(--text-color);margin-top:3px;font-size:.72rem}.etp-vars-section .etp-section-title{margin-bottom:2px}.etp-vars-header{align-items:baseline;gap:12px;margin-bottom:12px;display:flex}.etp-vars-hint{color:var(--text-color);font-size:.75rem}.etp-vars-hint code{background:var(--background-color);color:var(--text-color);border-radius:3px;padding:1px 4px;font-family:monospace;font-size:.73rem}.etp-vars-row{align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.etp-vars-row:last-child{margin-bottom:0}.etp-vars-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-color);min-width:48px;padding-top:5px;font-size:.68rem;font-weight:700}.etp-chips-wrap{flex-wrap:wrap;flex:1;gap:6px;display:flex}.etp-vars-empty{color:var(--text-color);padding:4px 0;font-size:.8rem}.etp-chip{cursor:pointer;border:none;border-radius:6px;align-items:center;font-family:monospace;transition:background .12s;display:inline-flex}.etp-chip--context{background:var(--info-bg);color:var(--info-text);border:1px solid var(--info-bg);padding:4px 10px}.etp-chip--context:hover{background:var(--info-bg)}.etp-chip--field{background:var(--item-field-bg);border:1px solid var(--item-field-border);flex-direction:column;align-items:flex-start;gap:1px;padding:5px 10px;font-size:.72rem}.etp-chip--field:hover{background:var(--item-field-bg)}.etp-chip-var{color:var(--item-field-color);font-family:monospace;font-size:.72rem;font-weight:600}.etp-chip-label{color:var(--text-color);font-family:sans-serif;font-size:.67rem;font-weight:400}.etp-chip--item{background:var(--status-yellow-bg);border:1px solid var(--status-yellow);cursor:pointer;border-radius:6px;flex-direction:column;align-items:flex-start;gap:1px;padding:5px 10px;font-size:.72rem;transition:background .12s;display:inline-flex}.etp-chip--item:hover{background:var(--status-yellow-bg)}.etp-chip--item .etp-chip-var{color:var(--status-yellow);font-family:monospace;font-size:.72rem;font-weight:600}.etp-chip--item .etp-chip-label{color:var(--text-color);font-family:sans-serif;font-size:.67rem;font-weight:400}.etp-vars-row--collections{flex-direction:column;align-items:flex-start;gap:8px}.etp-vars-row--collections .etp-vars-group-label{align-items:center;gap:4px;padding-top:0;display:flex}.etp-collections-wrap{flex-direction:column;gap:12px;width:100%;display:flex}.etp-collection-block{background:var(--collection-block-bg);border:1px solid var(--collection-block-border);border-radius:8px;padding:10px 14px}.etp-collection-name{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:8px;display:flex}.etp-collection-name strong{color:var(--text-color);font-size:.82rem}.etp-collection-badge{background:var(--status-yellow);color:var(--status-yellow);text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.etp-collection-key{color:var(--text-color);background:var(--background-color);border-radius:3px;padding:1px 5px;font-family:monospace;font-size:.72rem}.etp-collection-hint{color:var(--text-color);background:var(--background-color);border:1px solid var(--border-color);border-radius:6px;margin:4px 0 0;padding:8px 12px;font-size:.75rem}.etp-collection-hint code{background:var(--border-color);border-radius:3px;padding:1px 4px;font-family:monospace;font-size:.73rem}.etp-collection-hint strong{color:var(--text-color)}.etp-chip--fk{cursor:pointer;background:#fdf4ff;border:1px solid #e9d5ff;border-radius:6px;flex-direction:column;align-items:flex-start;gap:1px;padding:5px 10px;font-size:.72rem;transition:background .12s;display:inline-flex}.etp-chip--fk:hover{background:#f3e8ff}.etp-chip--fk .etp-chip-var{color:#7c3aed;font-family:monospace;font-size:.72rem;font-weight:600}.etp-chip--fk .etp-chip-label{color:#6b7280;font-family:sans-serif;font-size:.67rem;font-weight:400}.excel-grid{background:#fff;border:1px solid #bfc8d4;border-radius:8px;overflow:clip;box-shadow:0 1px 4px #0000000f}.excel-toolbar{background:#f0f2f5;border-bottom:1px solid #d0d6de;flex-wrap:wrap;align-items:center;gap:6px;padding:5px 10px;display:flex}.excel-section-label{letter-spacing:.08em;color:#6b7280;text-transform:uppercase;background:#e5e7eb;border-radius:4px;padding:2px 6px;font-size:.62rem;font-weight:800}.excel-toolbar-sep{background:#d1d5db;width:1px;height:16px;margin:0 2px}.excel-tool-btn{cursor:pointer;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:4px;align-items:center;padding:4px 8px;font-size:.8rem;font-weight:700;transition:background .1s;display:flex}.excel-tool-btn:hover:not(:disabled){background:#e5e7eb}.excel-tool-btn--on{color:#fff;background:#1e3a8a;border-color:#1e3a8a}.excel-tool-btn--on:hover{background:#1e40af}.excel-tool-btn:disabled{opacity:.35;cursor:default}.excel-tool-group{align-items:center;gap:3px;display:flex}.excel-tool-group .excel-tool-btn:not(:first-child){border-left-width:0;border-radius:0}.excel-tool-group .excel-tool-btn:first-child{border-radius:4px 0 0 4px}.excel-tool-group .excel-tool-btn:last-child{border-left-width:1px;border-radius:0 4px 4px 0}.excel-tool-group .excel-tool-btn:only-child{border-left-width:1px;border-radius:4px}.excel-tool-label{color:#9ca3af;white-space:nowrap;padding:0 3px;font-size:.68rem;font-weight:600}.excel-fsize-input{text-align:center;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:4px;width:42px;padding:3px 5px;font-size:.78rem}.excel-fsize-input:disabled{opacity:.4;background:#f9fafb}.excel-fsize-input:focus{border-color:#2563eb;outline:none}.excel-fsize-input{-moz-appearance:textfield}.excel-fsize-input::-webkit-inner-spin-button{-webkit-appearance:none}.excel-fsize-input::-webkit-outer-spin-button{-webkit-appearance:none}.excel-span-input{text-align:center;color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:4px;width:38px;padding:3px 5px;font-size:.78rem}.excel-span-input:disabled{opacity:.4;background:#f9fafb}.excel-span-input:focus{border-color:#2563eb;outline:none}.excel-span-input{-moz-appearance:textfield}.excel-span-input::-webkit-inner-spin-button{-webkit-appearance:none}.excel-span-input::-webkit-outer-spin-button{-webkit-appearance:none}.excel-repeat-hdr{color:#c2410c;z-index:4;background:#fff7ed;border-right:1px solid #fed7aa;flex-shrink:0;justify-content:center;align-items:center;width:90px;min-width:90px;font-size:.65rem;font-weight:700;display:flex;position:sticky;left:40px}.excel-repeat-cell{z-index:3;background:#fffbf5;border-right:1px solid #fed7aa;flex-shrink:0;align-items:center;width:90px;min-width:90px;padding:0 4px;display:flex;position:sticky;left:40px}.excel-repeat-select{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:4px;width:100%;padding:3px 4px;font-size:.7rem}.excel-repeat-select:focus{border-color:#f97316;outline:none}.excel-repeat-select--on{color:#c2410c;background:#fff7ed;border-color:#f97316;font-weight:600}.excel-data-row--repeat{border-left:3px solid #f97316;background:#fffbf5!important}.excel-data-row--repeat .excel-row-num{color:#c2410c;background:#fed7aa}.excel-data-row--repeat .excel-cell{border-right-color:#fed7aa}.excel-cell--merged{background:#faf5ff;border-right:2px solid #7c3aed!important}.excel-merge-badge{color:#7c3aed;pointer-events:none;z-index:2;background:#f3e8ff;border:1px solid #e9d5ff;border-radius:3px;padding:0 3px;font-size:.6rem;font-weight:700;line-height:1.4;position:absolute;top:2px;right:4px}.excel-fbar{background:#fff;border-bottom:1px solid #d0d6de;align-items:center;min-height:30px;display:flex}.excel-fbar-ref{color:#374151;text-align:center;background:#f9fafb;border-right:1px solid #d0d6de;justify-content:center;align-items:center;min-width:64px;height:100%;padding:4px 10px;font-family:monospace;font-size:.78rem;font-weight:600;display:flex}.excel-fbar-fx{color:#2563eb;background:#eff6ff;border-right:1px solid #e5e7eb;align-items:center;height:100%;padding:4px 8px;font-size:.78rem;font-style:italic;font-weight:700;display:flex}.excel-fbar-input{color:#111827;resize:none;background:0 0;border:none;outline:none;flex:1;min-height:30px;padding:4px 10px;font-family:monospace;font-size:.85rem;line-height:1.45;overflow:hidden}.excel-fbar-input:disabled{color:#9ca3af;background:0 0}.excel-fbar-input:focus{background:#fafeff}.excel-sheet{overflow-x:auto}.excel-col-row{-webkit-user-select:none;user-select:none;background:#f0f2f5;border-bottom:1px solid #c8d0da;display:flex}.excel-corner{z-index:4;background:#f0f2f5;border-right:1px solid #c8d0da;flex-shrink:0;width:40px;min-width:40px;position:sticky;left:0}.excel-col-hdr{color:#4b5563;border-right:1px solid #c8d0da;flex:0 0 160px;justify-content:center;align-items:center;width:160px;padding:4px 6px;font-size:.72rem;font-weight:700;display:flex;position:relative}.excel-col-hdr span{text-align:center;flex:1}.excel-col-hdr .excel-col-x{cursor:pointer;color:#c9cdd3;background:0 0;border:none;padding:0 2px;font-size:.85rem;line-height:1;position:absolute;top:50%;right:3px;transform:translateY(-50%)}.excel-col-hdr .excel-col-x:hover{color:#ef4444}.excel-col-add-slot{border-left:1px solid #c8d0da;flex-shrink:0;justify-content:center;align-items:center;width:36px;min-width:36px;display:flex}.excel-col-add-btn{cursor:pointer;color:#9ca3af;background:0 0;border:1px dashed #9ca3af;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;transition:all .12s;display:flex}.excel-col-add-btn:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.excel-data-row{background:#fff;border-bottom:1px solid #e5e9ee;transition:background 80ms;display:flex}.excel-data-row:hover{background:#f8fafc}.excel-data-row:hover .excel-row-num{color:#1d4ed8;background:#dbeafe}.excel-row-num{z-index:3;color:#6b7280;-webkit-user-select:none;user-select:none;background:#f0f2f5;border-right:1px solid #c8d0da;flex-shrink:0;justify-content:center;align-items:center;width:40px;min-width:40px;font-size:.68rem;font-weight:700;transition:background .1s,color .1s;display:flex;position:sticky;left:0}.excel-row-num--active{color:#1d4ed8;background:#bfdbfe}.excel-cell{border-right:1px solid #e5e9ee;flex:0 0 160px;width:160px;position:relative}.excel-cell--active{outline-offset:-2px;z-index:1;background:#fff;outline:2px solid #1a73e8}.excel-cell--bold .xcell-input{font-weight:700}.excel-row-del{flex-shrink:0;justify-content:center;align-items:center;width:32px;min-width:32px;display:flex}.excel-row-del-btn{cursor:pointer;color:#d1d5db;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:color .1s,background .1s;display:flex}.excel-row-del-btn:hover{color:#ef4444;background:#fef2f2}.excel-add-row{background:#f9fafb;border-top:1px dashed #d1d5db;padding:6px 10px}.excel-add-row-btn{cursor:pointer;color:#6b7280;background:0 0;border:1px dashed #c8d0da;border-radius:5px;align-items:center;gap:4px;padding:5px 10px;font-size:.78rem;transition:border-color .12s,color .12s;display:inline-flex}.excel-add-row-btn:hover{color:#2563eb;border-color:#2563eb}.xcell-wrap{width:100%;height:100%;position:relative}.xcell-input{box-sizing:border-box;color:#111827;resize:none;background:0 0;border:none;outline:none;width:100%;min-height:34px;padding:7px 9px;font-family:inherit;font-size:.85rem;line-height:1.45;display:block;overflow:hidden}.xcell-input--active{background:#fff}.xcell-input.xcell-bold{font-weight:700}.xcell-input.xcell-italic{font-style:italic}.xcell-input::placeholder{color:#c4c9d4;font-style:italic}.excel-color-btn{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;gap:1px;min-width:28px;padding:4px 7px;transition:background .1s;display:flex;position:relative}.excel-color-btn:hover:not(.excel-color-btn--disabled){background:#e5e7eb}.excel-color-btn--disabled{opacity:.35;cursor:default}.excel-color-btn .excel-color-A{color:#111827;font-size:.82rem;font-weight:700;line-height:1}.excel-color-btn .excel-color-bar{background:#000;border-radius:1px;width:16px;height:3px}.excel-color-btn .excel-color-input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;inset:0}.excel-color-btn .excel-color-input:disabled{cursor:default}.xcell-dropdown{z-index:200;background:#fff;border:1px solid #d1d5db;border-radius:8px;min-width:260px;max-height:220px;padding:4px;position:absolute;top:calc(100% + 2px);left:0;overflow-y:auto;box-shadow:0 6px 20px #00000024}.xcell-dd-item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:5px;align-items:center;gap:10px;width:100%;padding:7px 10px;transition:background 80ms;display:flex}.xcell-dd-item:hover,.xcell-dd-item--hl{background:#eff6ff}.xcell-dd-var{color:#1d4ed8;white-space:nowrap;flex-shrink:0;font-family:monospace;font-size:.78rem;font-weight:700}.xcell-dd-lbl{color:#6b7280;white-space:nowrap;text-overflow:ellipsis;font-size:.73rem;overflow:hidden}.cols-table{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.cols-head{color:#6b7280;text-transform:uppercase;letter-spacing:.04em;background:#f3f4f6;grid-template-columns:36px 160px 1fr 72px 68px;padding:8px 12px;font-size:.72rem;font-weight:700;display:grid}.cols-body{flex-direction:column;display:flex}.cols-row{background:#fff;border-top:1px solid #f3f4f6;grid-template-columns:36px 160px 1fr 72px 68px;align-items:center;padding:7px 12px;transition:background .1s;display:grid}.cols-row:hover{background:#fafafa}.cols-row--off{opacity:.45}.cols-row--off .col-field-name{text-decoration:line-through}.cols-row input[type=checkbox]{cursor:pointer;width:15px;height:15px}.col-field-name{color:#374151;white-space:nowrap;text-overflow:ellipsis;padding-right:8px;font-size:.82rem;font-weight:500;overflow:hidden}.col-header-input{border:1px solid #d1d5db;border-radius:6px;width:100%;margin-right:8px;padding:5px 9px;font-size:.83rem}.col-header-input:focus{border-color:var(--accent,#2563eb);outline:none}.col-width-input{text-align:center;border:1px solid #d1d5db;border-radius:6px;width:58px;margin-right:8px;padding:5px 7px;font-size:.83rem}.col-width-input:focus{border-color:var(--accent,#2563eb);outline:none}.col-order-btns{gap:3px;display:flex}.etp-cols-empty{color:#9ca3af;padding:16px 0;font-size:.85rem}.icon-btn{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #e5e7eb;border-radius:6px;justify-content:center;align-items:center;padding:5px;display:flex}.icon-btn:hover{background:#f3f4f6}.icon-btn:disabled{opacity:.3;cursor:default}.icon-btn.danger{color:#ef4444;border-color:#fecaca}.icon-btn.danger:hover{background:#fef2f2}.icon-btn.xs{border-radius:4px;padding:3px}.btn-primary{background:var(--accent,#2563eb);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-primary:hover{opacity:.9}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{color:#374151;cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;align-items:center;gap:6px;padding:8px 18px;font-size:.875rem;font-weight:600;display:inline-flex}.btn-secondary:hover{background:#e5e7eb}.qrd-loading{color:var(--text-color);padding:40px}.qrd-page{flex-direction:column;gap:20px;display:flex}.qrd-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px;display:flex}.qrd-title{color:var(--text-color);margin:0 0 4px;font-size:1.3rem;font-weight:700}.qrd-subtitle{color:var(--text-tertiary,var(--text-color));opacity:.7;margin:0;font-size:.82rem}.qrd-stat-tiles{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.qrd-stat-tile{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:14px;align-items:center;gap:14px;padding:18px 20px;display:flex}.qrd-stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.qrd-stat-icon--blue{color:#2563eb;background:#dbeafe}.qrd-stat-icon--purple{color:#9333ea;background:#f3e8ff}.qrd-stat-icon--green{color:#16a34a;background:#dcfce7}.qrd-stat-icon--orange{color:#ea580c;background:#ffedd5}.qrd-stat-value{color:var(--text-color);font-size:1.6rem;font-weight:700;line-height:1}.qrd-stat-label{color:var(--text-color);opacity:.65;margin-top:3px;font-size:.75rem;font-weight:500}.qrd-chart-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:16px;padding:20px 24px}.qrd-chart-title{color:var(--text-color);align-items:center;gap:6px;margin:0 0 16px;font-size:.85rem;font-weight:700;display:flex}.qrd-empty{min-height:100px;color:var(--text-color);opacity:.5;border:1.5px dashed var(--border-color);border-radius:10px;justify-content:center;align-items:center;font-size:.82rem;display:flex}.qrd-two-col{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.qrd-right-col{flex-direction:column;gap:20px;display:flex}.qrd-top-list{flex-direction:column;gap:10px;display:flex}.qrd-top-row{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:4px 0;transition:opacity .15s;display:flex}.qrd-top-row:hover{opacity:.75}.qrd-top-rank{color:var(--text-color);opacity:.4;flex-shrink:0;width:22px;font-size:.72rem;font-weight:700}.qrd-top-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.85rem;font-weight:600;overflow:hidden}.qrd-top-cnt{color:var(--text-color);text-align:right;min-width:40px;font-size:.8rem;font-weight:700}.qrd-bar-wrap{background:var(--border-color);border-radius:3px;flex:2;height:6px;overflow:hidden}.qrd-bar-fill{background:var(--primary,#4a69ff);border-radius:3px;height:100%;transition:width .5s}.qrd-country-list{flex-direction:column;gap:10px;display:flex}.qrd-country-row{align-items:center;gap:10px;display:flex}.qrd-country-flag{flex-shrink:0;font-size:1.1rem;line-height:1}.qrd-country-name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:.85rem;font-weight:500;overflow:hidden}.qrd-country-pct{color:var(--text-color);opacity:.55;text-align:right;min-width:32px;font-size:.75rem}.qrd-country-cnt{color:var(--text-color);text-align:right;min-width:36px;font-size:.8rem;font-weight:700}.qrd-tod-list{flex-direction:column;gap:10px;display:flex}.qrd-tod-row{align-items:center;gap:10px;display:flex}.qrd-tod-label{color:var(--text-color);flex-shrink:0;width:120px;font-size:.78rem;font-weight:500}.qrd-tod-pct{color:var(--text-color);text-align:right;min-width:36px;font-size:.8rem;font-weight:700}@media (max-width:900px){.qrd-stat-tiles{grid-template-columns:repeat(2,1fr)}.qrd-two-col{grid-template-columns:1fr}}.qr-list-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.qr-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.qr-card{background:var(--card-background-color);border:1px solid var(--border-color);cursor:pointer;border-radius:16px;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s,border-color .2s,transform .15s;display:flex}.qr-card:hover{border-color:var(--primary-color);transform:translateY(-1px);box-shadow:0 4px 20px #4a69ff1a}.qr-card__top{align-items:flex-start;gap:14px;display:flex}.qr-card__thumb{background:var(--background-color);border:1px solid var(--border-color);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;line-height:0;display:flex;overflow:hidden}.qr-card__thumb svg{width:100%;height:100%}.qr-card__info{flex:1;min-width:0}.qr-card__name{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;font-size:1rem;font-weight:700;overflow:hidden}.qr-card__url{color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.qr-card__stats{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr;gap:8px;padding-top:12px;display:grid}.qr-stat{flex-direction:column;gap:2px;display:flex}.qr-stat__value{color:var(--text-color);font-size:1.3rem;font-weight:700}.qr-stat__label{color:var(--text-color);font-size:.72rem;font-weight:500}.qr-card__footer{justify-content:space-between;align-items:center;display:flex}.qr-card__date{color:var(--text-color);font-size:.73rem}.qr-card__actions{gap:6px;display:flex}.qr-action-btn{border:1px solid var(--border-color);width:30px;height:30px;color:var(--text-color);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.qr-action-btn:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--primary-light,#4a69ff14)}.qr-action-btn.danger:hover{border-color:var(--status-red);color:var(--status-red);background:var(--status-red-bg)}.qr-empty{text-align:center;color:var(--text-color);padding:80px 40px}.qr-empty h3{color:var(--text-color);margin:16px 0 8px;font-size:1.1rem;font-weight:600}.qr-empty p{font-size:.875rem}.qr-form-layout{grid-template-columns:1fr 340px;align-items:start;gap:24px;display:grid}.qr-form-panel{flex-direction:column;gap:0;display:flex}.qr-form-section{background:var(--card-background-color);border-radius:var(--radius-lg,16px);border:1px solid var(--border-color);margin-bottom:16px;overflow:hidden}.qr-form-section__title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-color);border-bottom:1px solid var(--border-color);background:var(--background-color);padding:14px 20px;font-size:.8rem;font-weight:700}.qr-form-section__body{flex-direction:column;gap:16px;padding:20px;display:flex}.qr-form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.qr-form-group{flex-direction:column;gap:6px;display:flex}.qr-form-group label{color:var(--text-color);font-size:.8rem;font-weight:600}.qr-form-group input[type=text],.qr-form-group input[type=url],.qr-form-group input[type=number],.qr-form-group select,.qr-form-group textarea{border:1px solid var(--border-color);background:var(--card-background-color);color:var(--text-color);border-radius:8px;padding:9px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.qr-form-group input[type=text]:focus,.qr-form-group input[type=url]:focus,.qr-form-group input[type=number]:focus,.qr-form-group select:focus,.qr-form-group textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #4a69ff1f}.qr-color-field{align-items:center;gap:8px;display:flex}.qr-color-field input[type=color]{border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:8px;flex-shrink:0;width:36px;height:36px;padding:2px}.qr-color-field input[type=text]{flex:1;font-family:Courier New,monospace;font-size:.85rem}.qr-style-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.qr-style-option{border:1.5px solid var(--border-color);cursor:pointer;color:var(--text-color);background:0 0;border-radius:10px;flex-direction:column;align-items:center;gap:5px;padding:10px 6px 8px;font-size:.72rem;font-weight:500;transition:all .15s;display:flex}.qr-style-option svg,.qr-style-option .qr-style-icon{width:28px;height:28px}.qr-style-option:hover{border-color:var(--primary-color);color:var(--primary-color);background:var(--primary-light,#4a69ff0f)}.qr-style-option.active{border-color:var(--primary-color);background:var(--primary-light,#4a69ff1a);color:var(--primary-color)}.qr-logo-upload{align-items:center;gap:12px;display:flex}.qr-logo-upload .qr-logo-preview{border:1.5px solid var(--border-color);object-fit:contain;background:var(--background-color);width:52px;height:52px;color:var(--text-color);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.qr-logo-upload .qr-logo-preview img{object-fit:contain;width:100%;height:100%}.qr-logo-upload .qr-logo-controls{flex-direction:column;flex:1;gap:6px;display:flex}.qr-logo-upload input[type=file]{display:none}.qr-logo-upload .qr-logo-btn{border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;background:0 0;border-radius:7px;padding:6px 12px;font-size:.8rem;font-weight:600;transition:all .15s}.qr-logo-upload .qr-logo-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.qr-logo-upload .qr-logo-remove{color:var(--status-red);border-color:var(--status-red)}.qr-logo-upload .qr-logo-remove:hover{background:var(--status-red);color:#fff}.qr-preview-panel{flex-direction:column;gap:16px;display:flex;position:sticky;top:24px}.qr-preview-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius-lg,16px);flex-direction:column;align-items:center;gap:16px;padding:24px;display:flex}.qr-preview-card__title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-color);align-self:flex-start;font-size:.8rem;font-weight:700}.qr-preview{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.qr-preview__canvas{border-radius:12px;line-height:0;overflow:hidden;box-shadow:0 4px 20px #00000014}.qr-preview__actions{gap:8px;display:flex}.qr-preview__dl{border:1.5px solid var(--border-color);color:var(--text-color);cursor:pointer;letter-spacing:.3px;background:0 0;border-radius:7px;padding:6px 16px;font-size:.78rem;font-weight:700;transition:all .15s}.qr-preview__dl:hover{border-color:var(--primary-color);color:var(--primary-color)}.qr-scan-url{background:var(--background-color);width:100%;color:var(--text-color);border-radius:8px;align-items:center;gap:6px;padding:8px 10px;font-size:.75rem;display:flex}.qr-scan-url span{text-overflow:ellipsis;white-space:nowrap;color:var(--primary-color);flex:1;font-family:Courier New,monospace;overflow:hidden}.qr-scan-url button{cursor:pointer;color:var(--text-color);background:0 0;border:none;align-items:center;padding:0;display:flex}.qr-scan-url button:hover{color:var(--primary-color)}.qr-form-error{background:var(--status-red-bg);color:var(--status-red);border-radius:8px;margin-bottom:8px;padding:10px 14px;font-size:.875rem}.qr-submit-row{justify-content:flex-end;gap:10px;margin-top:4px;display:flex}.qr-detail-layout{grid-template-columns:1fr 260px;align-items:start;gap:24px;display:grid}.qr-detail-main{flex-direction:column;gap:20px;display:flex}.qr-detail-sidebar{flex-direction:column;gap:16px;display:flex;position:sticky;top:24px}.qr-detail-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:4px;display:flex}.qr-detail-title{color:var(--text-color);margin:0 0 4px;font-size:1.3rem;font-weight:700}.qr-detail-url{color:var(--primary-color);font-size:.82rem;text-decoration:none}.qr-detail-url:hover{text-decoration:underline}.qr-detail-header-actions{flex-shrink:0;gap:8px;display:flex}.qr-stat-tiles{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.qr-stat-tile{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:14px;flex-direction:column;gap:4px;padding:16px 18px;display:flex}.qr-stat-tile__value{color:var(--text-color);font-size:1.8rem;font-weight:700;line-height:1}.qr-stat-tile__label{color:var(--text-color);font-size:.75rem;font-weight:500}.qr-chart-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:16px;padding:20px 24px}.qr-chart-empty{min-height:80px;color:var(--text-color);border:1.5px dashed var(--border-color);border-radius:10px;justify-content:center;align-items:center;font-size:.82rem;display:flex}.qr-chart-card__title{color:var(--text-color);margin:0 0 16px;font-size:.85rem;font-weight:700}.qr-country-table{flex-direction:column;gap:10px;display:flex}.qr-country-row{align-items:center;gap:10px;display:flex}.qr-country-flag{flex-shrink:0;font-size:1.2rem;line-height:1}.qr-country-name{color:var(--text-color);flex:1;font-size:.875rem;font-weight:500}.qr-country-bar{background:var(--border-color);border-radius:3px;flex:2;height:6px;overflow:hidden}.qr-country-fill{background:var(--primary-color);border-radius:3px;height:100%;transition:width .5s}.qr-country-cnt{color:var(--text-color);text-align:right;min-width:36px;font-size:.8rem;font-weight:700}.qr-device-list{flex-direction:column;gap:10px;display:flex}.qr-device-row{align-items:center;gap:10px;display:flex}.qr-device-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.qr-device-name{color:var(--text-color);text-transform:capitalize;flex:1;font-size:.875rem;font-weight:500}.qr-device-pct{color:var(--text-color);font-size:.8rem;font-weight:700}.qr-sidebar-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:16px;flex-direction:column;align-items:center;gap:14px;padding:20px;display:flex}.qr-sidebar-card__title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-color);align-self:flex-start;font-size:.78rem;font-weight:700}.partner-detail-page{max-width:900px}.partner-detail-page .pd-header{align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.partner-detail-page .pd-back-btn{border:1px solid var(--border-color);border-radius:var(--radius);background:var(--card-background-color);color:var(--text-color);cursor:pointer;align-items:center;gap:6px;padding:8px 14px;font-size:.9rem;transition:all .2s;display:inline-flex}.partner-detail-page .pd-back-btn:hover{background:var(--background-color);color:var(--text-color)}.partner-detail-page .pd-edit-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;margin-left:auto;padding:8px 16px;font-size:.9rem;font-weight:500;transition:background .2s;display:inline-flex}.partner-detail-page .pd-edit-btn:hover{background:var(--primary-hover)}.partner-detail-page .pd-edit-actions{gap:.5rem;margin-left:auto;display:flex}.partner-detail-page .pd-save-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:8px 18px;font-size:.9rem;font-weight:500;transition:background .2s}.partner-detail-page .pd-save-btn:hover:not(:disabled){background:var(--primary-hover)}.partner-detail-page .pd-save-btn:disabled{opacity:.6;cursor:not-allowed}.partner-detail-page .pd-cancel-btn{background:var(--background-color);color:var(--text-color);border:1px solid var(--border-color);border-radius:var(--radius);cursor:pointer;padding:8px 14px;font-size:.9rem;transition:all .2s}.partner-detail-page .pd-cancel-btn:hover{background:var(--background-color);color:var(--text-color)}.partner-detail-page .pd-save-error{background:var(--status-red-bg);color:var(--status-red);border-radius:var(--radius);margin-bottom:1rem;padding:.6rem 1rem;font-size:.88rem}.partner-detail-page .pd-loading{justify-content:center;padding:4rem;display:flex}.partner-detail-page .pd-error{color:var(--status-red);background:var(--status-red-bg);border-radius:var(--radius);padding:1rem 1.5rem}.partner-detail-page .pd-hero{background:var(--card-background-color);border-radius:var(--radius);border:1px solid var(--border-color);align-items:flex-start;gap:1.25rem;margin-bottom:1.5rem;padding:1.5rem;display:flex}.partner-detail-page .pd-hero-avatar{background:linear-gradient(135deg,var(--primary-color)0%,var(--primary-hover)100%);color:#fff;border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;font-size:2rem;font-weight:700;display:flex}.partner-detail-page .pd-hero-info{flex-direction:column;flex:1;gap:.5rem;display:flex}.partner-detail-page .pd-hero-name{color:var(--text-color);margin:0;font-size:1.6rem;font-weight:700}.partner-detail-page .pd-hero-name-input{color:var(--text-color);border:1px solid var(--border-color);border-radius:var(--radius);background:var(--background-color);outline:none;width:100%;padding:4px 10px;font-size:1.4rem;font-weight:700}.partner-detail-page .pd-hero-name-input:focus{border-color:var(--primary-color);background:var(--card-background-color)}.partner-detail-page .pd-hero-meta{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.partner-detail-page .pd-status-badge{border-radius:20px;padding:3px 12px;font-size:.82rem;font-weight:500;display:inline-block}.partner-detail-page .pd-status-badge.active{background:var(--status-green-bg);color:var(--status-green)}.partner-detail-page .pd-status-badge.inactive{background:var(--background-color);color:var(--status-gray)}.partner-detail-page .pd-hero-date{color:var(--text-color);font-size:.85rem}.partner-detail-page .pd-active-toggle{color:var(--text-color);cursor:pointer;align-items:center;gap:6px;margin-top:.25rem;font-size:.9rem;display:inline-flex}.partner-detail-page .pd-active-toggle input[type=checkbox]{accent-color:var(--primary-color);width:15px;height:15px}.partner-detail-page .pd-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem;margin-bottom:1.25rem;display:grid}.partner-detail-page .pd-card{background:var(--card-background-color);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.25rem 1.5rem}.partner-detail-page .pd-card-title{color:var(--primary-color);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-color);align-items:center;gap:.5rem;margin:0 0 1rem;padding-bottom:.75rem;font-size:.85rem;font-weight:700;display:flex}.partner-detail-page .pd-info-list{flex-direction:column;gap:.75rem;display:flex}.partner-detail-page .pd-info-row{align-items:flex-start;gap:.75rem;display:flex}.partner-detail-page .pd-info-icon{background:var(--background-color);width:32px;height:32px;color:var(--primary-color);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;display:flex}.partner-detail-page .pd-info-content{flex-direction:column;flex:1;gap:2px;display:flex}.partner-detail-page .pd-info-label{color:var(--text-color);font-size:.78rem;font-weight:500}.partner-detail-page .pd-info-value{color:var(--text-color);font-size:.95rem;font-weight:500}.partner-detail-page .pd-link{color:var(--primary-color);font-size:.95rem;font-weight:500;text-decoration:none}.partner-detail-page .pd-link:hover{text-decoration:underline}.partner-detail-page .pd-input{border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);background:var(--background-color);outline:none;width:100%;padding:5px 9px;font-size:.9rem;transition:border-color .15s}.partner-detail-page .pd-input:focus{border-color:var(--primary-color);background:var(--card-background-color)}.partner-detail-page .pd-textarea{border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);background:var(--background-color);resize:vertical;outline:none;width:100%;padding:8px 10px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.partner-detail-page .pd-textarea:focus{border-color:var(--primary-color);background:var(--card-background-color)}.partner-detail-page .pd-notes{color:var(--text-color);white-space:pre-wrap;flex:1;margin:0 0 1rem;font-size:.95rem;line-height:1.6}.partner-detail-page .pd-meta-dates{color:var(--text-color);gap:1rem;margin-top:auto;font-size:.8rem;display:flex}.partner-detail-page .pd-meta-dates span{align-items:center;gap:4px;display:flex}.partner-detail-page .pd-requests-card{margin-bottom:0}.partner-detail-page .pd-empty{color:var(--text-color);margin:0;padding:1rem 0;font-size:.9rem}.partner-detail-page .pd-requests-list{flex-direction:column;gap:0;display:flex}.partner-detail-page .pd-request-row{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 0;display:flex}.partner-detail-page .pd-request-row:last-child{border-bottom:none}.partner-detail-page .pd-request-info{flex-direction:column;gap:2px;display:flex}.partner-detail-page .pd-request-id{color:var(--text-color);font-family:monospace;font-size:.78rem}.partner-detail-page .pd-request-requester{color:var(--text-color);font-size:.92rem;font-weight:600}.partner-detail-page .pd-request-note{color:var(--text-color);text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-size:.82rem;overflow:hidden}.partner-detail-page .pd-request-meta{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.partner-detail-page .pd-status-pill{border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.78rem;font-weight:500;display:inline-flex}.partner-detail-page .pd-status-pill.status-pending{background:var(--status-yellow-bg);color:var(--status-yellow)}.partner-detail-page .pd-status-pill.status-approved{background:var(--status-green-bg);color:var(--status-green)}.partner-detail-page .pd-status-pill.status-rejected{background:var(--status-red-bg);color:var(--status-red)}.partner-detail-page .pd-status-pill.status-fulfilled{color:#7c3aed;background:#ede9fe}.partner-detail-page .pd-request-date{color:var(--text-color);font-size:.78rem}
