:root{--accent: #6366f1;--accent-2: #8b5cf6;--accent-rgb: 99, 102, 241;--sidebar-bg: #13111f;--layout-bg: #0f0e1a;--text-primary: #e2e8f0;--card-bg: #1a1827;--sidebar-text: rgba(255,255,255,.55);--sidebar-text-hover: rgba(255,255,255,.9);--sidebar-border: rgba(255,255,255,.06);--sidebar-hover-bg: rgba(255,255,255,.06);--text-muted: rgba(255,255,255,.38);--border: rgba(255,255,255,.07);--input-bg: rgba(255,255,255,.06);--input-border: rgba(255,255,255,.1);--hover-bg: rgba(255,255,255,.04);--bg: var(--layout-bg);--border-color: var(--border);--accent-bg: rgba(var(--accent-rgb), .12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit}select,select option{background-color:var(--card-bg);color:var(--text-primary)}select option:checked,select option:hover{background-color:var(--accent);color:#fff}.pd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:400;pointer-events:none;transition:background .3s ease}.pd-overlay-open{background:#0000008c;pointer-events:all;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.pd-drawer{position:fixed;top:0;right:0;width:380px;max-width:100vw;height:100vh;background:var(--card-bg);border-left:1px solid var(--border);z-index:401;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-12px 0 40px #0006}.pd-drawer-open{transform:translate(0)}.pd-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.pd-header-user{display:flex;align-items:center;gap:.85rem}.pd-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 0 0 3px rgba(var(--accent-rgb),.2)}.pd-header-name{display:block;font-size:.975rem;font-weight:700;color:var(--text-primary)}.pd-header-role{display:block;font-size:.75rem;color:var(--text-muted);text-transform:capitalize;margin-top:.1rem}.pd-close{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;padding:.4rem;border-radius:8px;transition:background .15s,color .15s}.pd-close:hover{background:var(--hover-bg);color:var(--text-primary)}.pd-tabs{display:flex;gap:0;padding:.75rem 1.25rem 0;border-bottom:1px solid var(--border);flex-shrink:0}.pd-tab{background:none;border:none;cursor:pointer;font-size:.875rem;font-weight:500;color:var(--text-muted);padding:.5rem .1rem;margin-right:1.5rem;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.pd-tab:hover{color:var(--sidebar-text-hover)}.pd-tab-active{color:var(--accent-2);border-bottom-color:var(--accent)}.pd-body{flex:1;overflow-y:auto;padding:1.25rem}.pd-loading{color:var(--text-muted);text-align:center;padding:2rem;font-size:.875rem}.pd-form{display:flex;flex-direction:column;gap:.9rem}.pd-row-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.pd-field{display:flex;flex-direction:column;gap:.3rem}.pd-field label{font-size:.75rem;font-weight:600;color:var(--text-muted)}.pd-field input,.pd-field select{background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:.875rem;padding:.55rem .75rem;outline:none;font-family:inherit;transition:border-color .2s,background .2s;width:100%;box-sizing:border-box}.pd-field input:focus,.pd-field select:focus{border-color:var(--accent);background:var(--hover-bg)}.pd-field input::placeholder{color:var(--text-muted)}.pd-pwd-wrap{position:relative}.pd-pwd-wrap input{padding-right:2.25rem}.pd-pwd-toggle{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;padding:0;transition:color .15s}.pd-pwd-toggle:hover{color:var(--sidebar-text-hover)}.pd-msg{padding:.55rem .85rem;border-radius:8px;font-size:.825rem}.pd-msg-ok{background:#22c55e1f;border:1px solid rgba(34,197,94,.25);color:#4ade80}.pd-msg-err{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#f87171}.pd-btn-save{margin-top:.5rem;padding:.7rem 1.25rem;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:10px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s;width:100%}.pd-btn-save:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 480px){.pd-drawer{width:100vw}.pd-row-2{grid-template-columns:1fr}}.pd-theme{display:flex;flex-direction:column;gap:1rem}.pd-theme-section-label{font-size:.7rem;font-weight:700;color:#ffffff4d;text-transform:uppercase;letter-spacing:.8px;margin-bottom:-.25rem}.pd-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.pd-preset{position:relative;display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.55rem .4rem .45rem;background:var(--hover-bg);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s}.pd-preset:hover{background:var(--input-bg);border-color:var(--input-border)}.pd-preset-active{border-color:var(--accent);background:rgba(var(--accent-rgb),.1)}.pd-preset-swatch{width:28px;height:28px;border-radius:50%;display:block;box-shadow:0 2px 6px #0006;flex-shrink:0}.pd-preset-dots{display:flex;gap:3px;margin-top:-2px}.pd-preset-dots span{width:8px;height:5px;border-radius:2px;display:block}.pd-preset-label{font-size:.68rem;font-weight:600;color:var(--text-muted)}.pd-preset-active .pd-preset-label{color:var(--text-primary)}.pd-preset-check{position:absolute;top:4px;right:4px;color:var(--accent);display:flex}.pd-colors{display:flex;flex-direction:column;gap:.45rem}.pd-color-row{display:flex;align-items:center;justify-content:space-between;padding:.45rem .75rem;background:var(--hover-bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:background .15s}.pd-color-row:hover{background:var(--input-bg)}.pd-color-label{font-size:.82rem;color:var(--sidebar-text);font-weight:500}.pd-color-pick{display:flex;align-items:center;gap:.5rem}.pd-color-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:32px;height:32px;padding:2px;border:1.5px solid var(--input-border);border-radius:8px;background:transparent;cursor:pointer}.pd-color-input::-webkit-color-swatch-wrapper{padding:0;border-radius:5px;overflow:hidden}.pd-color-input::-webkit-color-swatch{border:none;border-radius:5px}.pd-color-input::-moz-color-swatch{border:none;border-radius:5px}.pd-color-hex{font-size:.72rem;font-family:Courier New,monospace;color:var(--text-muted);min-width:56px;text-align:right}.pd-theme-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.25rem}.pd-btn-save{padding:.6rem 1.15rem;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:10px;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s,transform .15s}.pd-btn-save:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.pd-btn-save:disabled{opacity:.5;cursor:not-allowed}.pd-btn-reset{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1rem;background:none;border:1px solid var(--border);border-radius:10px;color:var(--text-muted);font-size:.825rem;cursor:pointer;transition:background .15s,color .15s}.pd-btn-reset:hover:not(:disabled){background:var(--hover-bg);color:var(--sidebar-text-hover)}.pd-btn-reset:disabled{opacity:.4;cursor:not-allowed}.layout{display:flex;min-height:100vh;background:var(--layout-bg);color:var(--text-primary);font-family:system-ui,-apple-system,Segoe UI,sans-serif}.sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);position:fixed;top:0;left:0;height:100vh;z-index:200;transition:transform .25s ease,width .25s ease}.sidebar-logo{display:flex;align-items:center;gap:.65rem;height:72px;padding:0 1rem 0 .75rem;border-bottom:1px solid var(--sidebar-border);box-sizing:border-box}.sidebar-toggle{background:none;border:none;cursor:pointer;color:var(--sidebar-text);display:flex;align-items:center;padding:.3rem;border-radius:8px;flex-shrink:0;transition:background .15s,color .15s}.sidebar-toggle:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-hover)}.sidebar-logo-img{width:64px;height:64px;object-fit:contain;border-radius:8px}.sidebar-logo-name{font-size:1.1rem;font-weight:700;color:var(--sidebar-text-hover);letter-spacing:-.3px}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.25rem;padding:1rem .75rem;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.65rem .9rem;border-radius:10px;color:var(--sidebar-text);font-size:.9rem;font-weight:500;transition:background .15s,color .15s;text-decoration:none}.sidebar-link:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-hover)}.sidebar-link-active{background:rgba(var(--accent-rgb),.18);color:var(--accent-2)}.sidebar-link-active:hover{background:rgba(var(--accent-rgb),.25);color:var(--accent-2)}.sidebar-link-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center}.sidebar-link-icon svg{width:18px;height:18px}.sidebar-group{display:flex;flex-direction:column}.sidebar-group-btn{width:100%;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit}.sidebar-group-label{flex:1}.sidebar-group-chevron{display:flex;align-items:center;color:var(--text-muted);transition:transform .2s ease;flex-shrink:0}.sidebar-group-chevron.open{transform:rotate(180deg)}.sidebar-sub{display:flex;flex-direction:column;gap:.1rem;padding-left:1.1rem;margin-top:.1rem}.sidebar-sub-link{display:flex;align-items:center;gap:.65rem;padding:.5rem .75rem;border-radius:8px;color:var(--sidebar-text);font-size:.85rem;font-weight:500;transition:background .15s,color .15s;text-decoration:none}.sidebar-sub-link:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-hover)}.sidebar-sub-link.sidebar-link-active{background:rgba(var(--accent-rgb),.18);color:var(--accent-2)}.sidebar-footer{padding:1rem .75rem;border-top:1px solid var(--sidebar-border);display:flex;align-items:center;gap:.5rem}.sidebar-user{flex:1;display:flex;align-items:center;gap:.65rem;min-width:0}.sidebar-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;min-width:0}.sidebar-user-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.7rem;color:var(--text-muted);text-transform:capitalize}.sidebar-logout{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;padding:.4rem;border-radius:8px;transition:background .15s,color .15s;flex-shrink:0}.sidebar-logout:hover{background:#ef44441f;color:#f87171}.layout-main{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .25s ease}.layout-topbar{display:flex;align-items:center;gap:.75rem;height:72px;padding:0 1.75rem 0 1.25rem;background:var(--sidebar-bg);border-bottom:1px solid var(--sidebar-border);position:sticky;top:0;z-index:100}.topbar-burger{background:none;border:none;cursor:pointer;color:var(--sidebar-text);display:none;align-items:center;padding:.3rem;border-radius:8px;transition:background .15s,color .15s;flex-shrink:0}.topbar-burger:hover{background:var(--sidebar-hover-bg);color:var(--sidebar-text-hover)}.topbar-spacer{flex:1}.topbar-page-tabs{display:flex;align-items:center;align-self:stretch;gap:0;margin-left:.5rem}.topbar-ptab{display:flex;align-items:center;gap:6px;padding:0 16px;align-self:stretch;background:none;border:none;border-bottom:2px solid transparent;color:var(--sidebar-text);font-size:.83rem;font-weight:500;cursor:pointer;transition:color .15s,background .15s,border-color .15s;font-family:inherit;white-space:nowrap}.topbar-ptab:hover{color:var(--sidebar-text-hover);background:var(--sidebar-hover-bg)}.topbar-ptab.active{color:var(--accent);border-bottom-color:var(--accent)}.topbar-ptab svg{flex-shrink:0}.topbar-user{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:.4rem .6rem;border-radius:10px;transition:background .15s}.topbar-user:hover{background:var(--sidebar-hover-bg)}.topbar-user-info{display:flex;flex-direction:column;align-items:flex-end;min-width:0}.topbar-user-name{font-size:.875rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.topbar-user-role{font-size:.72rem;color:var(--text-muted);text-transform:capitalize}.topbar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0}.topbar-logout{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;padding:.4rem;border-radius:8px;transition:background .15s,color .15s;flex-shrink:0}.topbar-logout:hover{background:#ef44441f;color:#f87171}.layout-collapsed .sidebar{width:64px}.layout-collapsed .layout-main{margin-left:64px}.layout-collapsed .sidebar-logo{justify-content:center;padding:1rem 0}.layout-collapsed .sidebar-logo-img{display:none}.layout-collapsed .sidebar-nav{padding:1rem .5rem;align-items:stretch}.layout-collapsed .sidebar-link{justify-content:center;padding:.7rem 0;gap:0}.layout-collapsed .sidebar-link>span:last-child{display:none}.layout-collapsed .sidebar-group-label,.layout-collapsed .sidebar-group-chevron{display:none}.layout-collapsed .sidebar-group-btn{justify-content:center;padding:.7rem 0;gap:0}.layout-collapsed .sidebar-sub{display:none}.layout-content{flex:1;padding:2rem 2.5rem;display:flex;flex-direction:column;min-height:0}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:199}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.layout-main{margin-left:0!important}.topbar-burger{display:flex}.layout-content{padding:1.5rem 1rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1e1b4b,#312e81 40%,#4c1d95);position:relative;overflow:hidden;padding:1.5rem}.login-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.bubble{position:absolute;border-radius:50%;opacity:.15;animation:float 8s ease-in-out infinite}.bubble-1{width:320px;height:320px;background:#818cf8;top:-80px;left:-80px;animation-delay:0s}.bubble-2{width:200px;height:200px;background:#a78bfa;bottom:-60px;right:-60px;animation-delay:2s}.bubble-3{width:140px;height:140px;background:#c4b5fd;top:50%;left:5%;animation-delay:4s}.bubble-4{width:100px;height:100px;background:#818cf8;top:20%;right:8%;animation-delay:1s}.bubble-5{width:60px;height:60px;background:#e0e7ff;bottom:20%;left:15%;animation-delay:3s}@keyframes float{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-24px) scale(1.04)}}.login-card{background:#ffffff12;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.15);border-radius:24px;padding:2.5rem 2.5rem 2rem;width:100%;max-width:420px;box-shadow:0 25px 50px #0006,0 0 0 1px #ffffff0d inset;position:relative;z-index:1}.login-header{text-align:center;margin-bottom:2rem}.login-logo{display:inline-flex;margin-bottom:1rem;filter:drop-shadow(0 8px 16px rgba(99,102,241,.5))}.login-logo img{width:72px;height:72px;object-fit:contain;border-radius:16px}.login-title{font-size:1.75rem;font-weight:700;color:#fff;margin:0 0 .35rem;letter-spacing:-.5px}.login-subtitle{font-size:.9rem;color:#ffffff8c;margin:0}.login-form{display:flex;flex-direction:column;gap:1.1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.8rem;font-weight:600;color:#ffffffbf;letter-spacing:.4px;text-transform:uppercase}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:.9rem;width:17px;height:17px;color:#4f46e5;pointer-events:none;flex-shrink:0}.form-input{width:100%;padding:.75rem .9rem .75rem 2.6rem;background:#ffffffeb;border:1px solid rgba(255,255,255,.6);border-radius:12px;color:#1e1b4b;font-size:.95rem;outline:none;transition:border-color .2s,background .2s,box-shadow .2s;box-sizing:border-box}.form-input::placeholder{color:#9ca3af;font-size:.85rem}.form-input:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f140}.form-input:disabled{opacity:.5;cursor:not-allowed}.input-password{padding-right:2.8rem}.toggle-password{position:absolute;right:.9rem;background:none;border:none;cursor:pointer;color:#6b7280;display:flex;align-items:center;padding:0;transition:color .2s}.toggle-password:hover{color:#4f46e5}.input-error{border-color:#f87171!important;box-shadow:0 0 0 3px #f8717133!important}.login-error{display:flex;align-items:center;gap:.5rem;background:#ef444426;border:1px solid rgba(239,68,68,.35);border-radius:10px;padding:.65rem .9rem;color:#fca5a5;font-size:.875rem;animation:shake .4s ease}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.login-btn{margin-top:.5rem;padding:.85rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 16px #6366f173;display:flex;align-items:center;justify-content:center;gap:.6rem;letter-spacing:.2px}.login-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #6366f18c}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.65;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;margin-top:1.75rem;font-size:.78rem;color:#ffffff4d}@media (max-width: 480px){.login-card{padding:2rem 1.5rem 1.5rem;border-radius:20px}.login-title{font-size:1.5rem}}.dashboard{min-height:100vh;background:var(--layout-bg);color:var(--text-primary);font-family:system-ui,sans-serif}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:64px;background:#ffffff0a;border-bottom:1px solid rgba(255,255,255,.08);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100}.topbar-brand{display:flex;align-items:center;gap:.75rem}.topbar-logo{width:32px;height:32px;object-fit:contain;border-radius:8px}.topbar-name{font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.topbar-user{display:flex;align-items:center;gap:.75rem}.user-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-fullname{font-size:.875rem;font-weight:600;color:var(--text-primary)}.user-role{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.logout-btn{display:flex;align-items:center;gap:.4rem;background:#ef44441a;border:1px solid rgba(239,68,68,.25);border-radius:8px;color:#f87171;font-size:.85rem;font-weight:500;padding:.45rem .85rem;cursor:pointer;transition:background .2s,border-color .2s;margin-left:.5rem}.logout-btn:hover{background:#ef444433;border-color:#ef444480}.dashboard-main{max-width:1100px;margin:0 auto;padding:2.5rem 2rem}.welcome-card{display:flex;align-items:center;gap:1.25rem;background:linear-gradient(135deg,rgba(var(--accent-rgb),.14),rgba(var(--accent-rgb),.07));border:1px solid rgba(var(--accent-rgb),.25);border-radius:20px;padding:1.75rem 2rem;margin-bottom:2rem}.welcome-avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 4px 14px rgba(var(--accent-rgb),.45)}.welcome-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .3rem;letter-spacing:-.4px}.welcome-sub{font-size:.9rem;color:var(--text-muted);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;border-radius:16px;border:1px solid var(--border);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.stat-purple{background:rgba(var(--accent-rgb),.1)}.stat-indigo{background:rgba(var(--accent-rgb),.07)}.stat-violet{background:rgba(var(--accent-rgb),.13)}.stat-icon{width:44px;height:44px;border-radius:12px;background:rgba(var(--accent-rgb),.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent-2)}.stat-icon svg{width:22px;height:22px}.stat-info{display:flex;flex-direction:column;gap:.2rem}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-value{font-size:1.35rem;font-weight:700;color:var(--text-primary)}.stat-value-sm{font-size:.9rem}@media (max-width: 600px){.topbar{padding:0 1rem}.user-info{display:none}.dashboard-main{padding:1.5rem 1rem}.welcome-card{padding:1.25rem}.welcome-title{font-size:1.25rem}}.emp-page{max-width:1100px}.emp-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.emp-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.emp-subtitle{font-size:.85rem;color:var(--text-muted);margin:0}.emp-search-wrap{position:relative;margin-bottom:1.25rem}.emp-search-icon{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--text-muted);pointer-events:none}.emp-search{width:100%;max-width:380px;padding:.65rem .9rem .65rem 2.5rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .2s,background .2s}.emp-search::placeholder{color:var(--text-muted)}.emp-search:focus{border-color:var(--accent);background:var(--hover-bg)}.emp-table-wrap{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;overflow:hidden;overflow-x:auto}.emp-table{width:100%;border-collapse:collapse;font-size:.875rem}.emp-table thead{background:var(--input-bg);border-bottom:1px solid var(--border)}.emp-table th{text-align:left;padding:.85rem 1.1rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.emp-table td{padding:.9rem 1.1rem;border-bottom:1px solid var(--border);vertical-align:middle}.emp-table tr:last-child td{border-bottom:none}.emp-table tbody tr:hover{background:#ffffff06}.emp-person{display:flex;align-items:center;gap:.75rem}.emp-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0}.emp-fullname{font-weight:600;color:var(--text-primary)}.emp-username{font-size:.75rem;color:var(--text-muted)}.emp-cell-muted{color:var(--sidebar-text)}.emp-empty{text-align:center;color:var(--text-muted);padding:2.5rem}.badge{display:inline-block;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:capitalize;white-space:nowrap}.badge-user{background:#ffffff14;color:#ffffff8c}.badge-active{background:#22c55e1f;color:#4ade80}.badge-inactive{background:#ef44441f;color:#f87171}.emp-actions{display:flex;gap:.4rem;justify-content:flex-end}.emp-state{text-align:center;padding:3rem;color:var(--text-muted);font-size:.9rem}.emp-error{color:#f87171}.btn-primary{display:inline-flex;align-items:center;gap:.45rem;padding:.6rem 1.1rem;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:10px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s;white-space:nowrap}.btn-secondary{padding:.6rem 1.1rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:10px;color:var(--sidebar-text);font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-danger{padding:.6rem 1.1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#f87171;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-danger:hover:not(:disabled){background:#ef444440}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.btn-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;background:var(--input-bg);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);cursor:pointer;transition:background .15s,color .15s}.btn-icon:hover{background:rgba(var(--accent-rgb),.15);color:var(--accent-2)}.btn-icon-danger:hover{background:#ef444426;color:#f87171}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;padding:1.5rem}.modal{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #00000080}.modal-sm{max-width:420px;padding:1.75rem}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.75rem 1rem;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0}.modal-close{background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;padding:.2rem;border-radius:6px;transition:color .15s}.modal-close:hover{color:var(--text-primary)}.modal-text{color:var(--sidebar-text);font-size:.9rem;margin-bottom:1.25rem;line-height:1.5}.modal-text strong{color:var(--text-primary)}.modal-form{padding:1.25rem 1.75rem 1.5rem;display:flex;flex-direction:column;gap:.9rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;margin-top:.5rem}.form-section-title{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-top:.5rem;padding-bottom:.3rem;border-bottom:1px solid var(--border)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.form-field{display:flex;flex-direction:column;gap:.3rem}.form-field-full{grid-column:1 / -1}.form-field label{font-size:.775rem;font-weight:600;color:var(--text-muted)}.form-field input,.form-field select,.form-field textarea{background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:.875rem;padding:.55rem .75rem;outline:none;transition:border-color .2s,background .2s;font-family:inherit;resize:vertical}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent);background:var(--hover-bg)}.form-field select option{background:var(--card-bg)}.form-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--sidebar-text);cursor:pointer}.form-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.form-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:.85rem;padding:.6rem .9rem}@media (max-width: 600px){.form-grid-2{grid-template-columns:1fr}.modal{border-radius:16px}.modal-form{padding:1rem}.modal-header{padding:1.1rem 1rem .75rem}}.profile-loading{color:var(--text-muted);text-align:center;padding:4rem}.profile-page{max-width:760px;display:flex;flex-direction:column;gap:1.5rem}.profile-hero{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:2rem 1.75rem;display:flex;align-items:center;gap:1.5rem}.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:#fff;flex-shrink:0;box-shadow:0 0 0 4px rgba(var(--accent-rgb),.25)}.profile-hero-name{font-size:1.35rem;font-weight:700;color:var(--text-primary);margin-bottom:.2rem}.profile-hero-meta{font-size:.85rem;color:var(--text-muted);margin-bottom:.55rem}.profile-badge{display:inline-block;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:capitalize}.badge-super{background:#f59e0b26;color:#fbbf24}.badge-manager{background:rgba(var(--accent-rgb),.15);color:var(--accent-2)}.badge-user{background:var(--input-bg);color:var(--sidebar-text)}.profile-card{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:1.75rem;display:flex;flex-direction:column;gap:.85rem}.profile-section-title{font-size:.7rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin:0 0 .1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}.profile-grid-narrow{grid-template-columns:1fr;max-width:380px}.profile-field{display:flex;flex-direction:column;gap:.3rem}.profile-field-full{grid-column:1 / -1}.profile-field label{font-size:.775rem;font-weight:600;color:var(--text-muted)}.profile-field input,.profile-field select,.profile-field textarea{background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;color:var(--text-primary);font-size:.875rem;padding:.6rem .8rem;outline:none;transition:border-color .2s,background .2s;font-family:inherit;resize:vertical}.profile-field input:focus,.profile-field select:focus,.profile-field textarea:focus{border-color:var(--accent);background:var(--hover-bg)}.profile-field select option{background:var(--card-bg)}.profile-field input::placeholder{color:var(--text-muted)}.profile-pwd-wrap{position:relative}.profile-pwd-wrap input{width:100%;padding-right:2.5rem;box-sizing:border-box}.profile-pwd-toggle{position:absolute;right:.7rem;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;padding:0;transition:color .15s}.profile-pwd-toggle:hover{color:var(--sidebar-text-hover)}.profile-msg{padding:.65rem 1rem;border-radius:8px;font-size:.875rem}.profile-msg-ok{background:#22c55e1f;border:1px solid rgba(34,197,94,.25);color:#4ade80}.profile-msg-err{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#f87171}.profile-form-footer{display:flex;justify-content:flex-end;margin-top:.25rem}.btn-primary{display:inline-flex;align-items:center;gap:.45rem;padding:.65rem 1.25rem;background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;border-radius:10px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .15s}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed}@media (max-width: 600px){.profile-hero{flex-direction:column;align-items:flex-start;gap:1rem}.profile-grid{grid-template-columns:1fr}.profile-grid-narrow{max-width:100%}.profile-card{padding:1.25rem}}.geo-select-wrap,.geo-combo-wrap{position:relative;width:100%}.geo-disabled{opacity:.5;pointer-events:none}.geo-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:.5rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;padding:.55rem .75rem;cursor:pointer;min-height:38px;transition:border-color .2s;-webkit-user-select:none;user-select:none}.geo-open .geo-select-trigger{border-color:var(--accent)}.geo-select-value{display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--text-primary)}.geo-placeholder{font-size:.875rem;color:var(--text-muted)}.geo-select-icons{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.geo-chevron{color:var(--text-muted);transition:transform .2s}.geo-open .geo-chevron{transform:rotate(180deg)}.geo-clear{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:1rem;line-height:1;padding:0 2px;border-radius:4px;transition:color .15s}.geo-clear:hover{color:var(--text-primary)}.geo-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px #0000004d;z-index:600;overflow:hidden}.geo-search-wrap{display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;border-bottom:1px solid var(--border)}.geo-search-icon{color:var(--text-muted);flex-shrink:0}.geo-search-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.875rem;font-family:inherit}.geo-search-input::placeholder{color:var(--text-muted)}.geo-list{list-style:none;margin:0;padding:.3rem 0;max-height:260px;overflow-y:auto}.geo-option{display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;cursor:pointer;font-size:.875rem;color:var(--text-primary);transition:background .12s}.geo-option:hover{background:var(--hover-bg)}.geo-option-active{background:rgba(var(--accent-rgb),.12);color:var(--accent-2)}.geo-option-name{flex:1}.geo-option-meta{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.geo-no-results{padding:.75rem;text-align:center;font-size:.85rem;color:var(--text-muted)}.geo-flag-img{width:24px;height:18px;object-fit:cover;border-radius:2px;flex-shrink:0;vertical-align:middle}.geo-eu-badge{font-size:.6rem;font-weight:700;padding:1px 5px;border-radius:4px;background:rgba(var(--accent-rgb),.15);color:var(--accent-2);flex-shrink:0}.geo-combo-input-row{display:flex;align-items:center;gap:.5rem;background:var(--input-bg);border:1px solid var(--input-border);border-radius:8px;padding:0 .75rem;min-height:38px;transition:border-color .2s}.geo-open .geo-combo-input-row{border-color:var(--accent)}.geo-search-icon-inline{color:var(--text-muted);flex-shrink:0}.geo-combo-input{flex:1;background:none;border:none;outline:none;color:var(--text-primary);font-size:.875rem;font-family:inherit;padding:.55rem 0}.geo-combo-input::placeholder{color:var(--text-muted)}.geo-dropdown-combo{padding:.3rem 0;list-style:none;margin:0;max-height:240px;overflow-y:auto}.geo-spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:geo-spin .7s linear infinite;flex-shrink:0}@keyframes geo-spin{to{transform:rotate(360deg)}}.cd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#00000073;display:flex;align-items:stretch;justify-content:flex-end}.cd-panel{width:520px;max-width:100vw;background:var(--card-bg);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;animation:cdSlideIn .22s ease}@keyframes cdSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.cd-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border-color);background:var(--card-bg);flex-shrink:0}.cd-header-info h2{margin:0;font-size:1.05rem;font-weight:600;color:var(--text-primary)}.cd-contact-name{font-size:.8rem;color:var(--text-muted)}.cd-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.cd-btn-add{padding:7px 14px;border-radius:7px;border:none;background:var(--accent);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s}.cd-btn-add:hover{opacity:.85}.cd-btn-close{width:32px;height:32px;border-radius:7px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.cd-btn-close:hover{background:var(--hover-bg)}.cd-body{flex:1;overflow-y:auto;padding:16px 20px 24px;display:flex;flex-direction:column;gap:10px}.cd-state{text-align:center;padding:32px;color:var(--text-muted);font-size:.88rem}.cd-state.cd-error{color:#e05252}.cd-empty{display:flex;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;color:var(--text-muted);font-size:.88rem;text-align:center}.cd-card{background:var(--input-bg);border:1px solid var(--border-color);border-radius:10px;padding:12px 14px;transition:border-color .15s}.cd-card:hover{border-color:var(--accent)}.cd-card.cd-card-default{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--input-bg))}.cd-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.cd-card-label{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cd-badge-default{font-size:.7rem;font-weight:700;background:var(--accent);color:#fff;border-radius:20px;padding:1px 8px;text-transform:uppercase;letter-spacing:.03em}.cd-card-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.cd-card-btns{display:flex;gap:6px;flex-shrink:0}.cd-btn-icon{width:28px;height:28px;border-radius:6px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.cd-btn-icon:hover{color:var(--accent);border-color:var(--accent);background:var(--hover-bg)}.cd-btn-del:hover{color:#e05252;border-color:#e05252}.cd-card-addr{font-size:.82rem;color:var(--text-muted);line-height:1.5}.cd-card-coords{margin-top:6px;display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-muted);font-family:monospace}.cd-maps-link{color:var(--accent);text-decoration:none;font-family:inherit;font-size:.75rem;margin-left:4px}.cd-maps-link:hover{text-decoration:underline}.cd-card-notes{margin-top:6px;font-size:.78rem;color:var(--text-muted);font-style:italic;border-top:1px solid var(--border-color);padding-top:6px}.cd-form-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-end;z-index:10}.cd-panel{position:relative}.cd-form-modal{width:100%;max-height:90%;background:var(--card-bg);border-top:1px solid var(--border-color);border-radius:14px 14px 0 0;overflow-y:auto;padding:0 0 16px;animation:cdSlideUp .2s ease}@keyframes cdSlideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.cd-form-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--card-bg);z-index:1}.cd-form-header h3{margin:0;font-size:.95rem;font-weight:600;color:var(--text-primary)}.cd-btn-close-sm{border:none;background:none;font-size:1rem;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:5px}.cd-btn-close-sm:hover{background:var(--hover-bg);color:var(--text-primary)}.cd-form{padding:14px 18px;display:flex;flex-direction:column;gap:10px}.cd-f-section{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding-top:6px;border-top:1px solid var(--border-color);margin-top:2px}.cd-f-row{display:grid;gap:10px}.cd-f-2col{grid-template-columns:1fr 1fr}.cd-f-3col{grid-template-columns:1fr 1fr 1fr}.cd-f-field{display:flex;flex-direction:column;gap:4px}.cd-f-field label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.cd-f-field input[type=text],.cd-f-field input[type=number],.cd-f-field textarea,.cd-f-field select{padding:7px 10px;border-radius:7px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s}.cd-f-field input:focus,.cd-f-field textarea:focus,.cd-f-field select:focus{border-color:var(--accent)}.cd-f-field textarea{resize:vertical;min-height:52px}.cd-f-check{justify-content:flex-end;padding-bottom:2px}.cd-f-check label{display:flex;align-items:center;gap:7px;font-size:.82rem;text-transform:none;letter-spacing:0;color:var(--text-primary);cursor:pointer}.cd-f-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.cd-coords-preview{text-align:right;font-size:.78rem;margin-top:-4px}.cd-coords-preview a{color:var(--accent);text-decoration:none}.cd-coords-preview a:hover{text-decoration:underline}.cd-form-error{padding:8px 12px;border-radius:7px;background:#e052521a;border:1px solid rgba(224,82,82,.3);color:#e05252;font-size:.82rem}.cd-form-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:6px}.cd-btn-cancel{padding:8px 18px;border-radius:7px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:background .15s}.cd-btn-cancel:hover{background:var(--hover-bg)}.cd-btn-save{padding:8px 22px;border-radius:7px;border:none;background:var(--accent);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.cd-btn-save:hover{opacity:.85}.cd-btn-save:disabled,.cd-btn-cancel:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 560px){.cd-panel{width:100vw}.cd-f-2col{grid-template-columns:1fr}.cd-f-3col{grid-template-columns:1fr 1fr}}.contacts-page{display:flex;flex-direction:column;gap:1.5rem}.contacts-header{display:flex;flex-direction:column;gap:1rem}.contacts-title-row{display:flex;align-items:baseline;gap:.75rem}.contacts-title-row h1{margin:0;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.contacts-total{font-size:.85rem;color:var(--text-muted)}.contacts-toolbar{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.contacts-search{flex:1;min-width:220px;padding:.55rem .85rem;border-radius:10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .15s}.contacts-search:focus{border-color:var(--accent)}.contacts-search::placeholder{color:var(--text-muted)}.contacts-filter-type{padding:.55rem .85rem;border-radius:10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.9rem;outline:none;cursor:pointer}.contacts-btn-new{white-space:nowrap;padding:.55rem 1.1rem;border-radius:10px;border:none;cursor:pointer;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;transition:opacity .15s}.contacts-btn-new:hover{opacity:.88}.contacts-table-wrap{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;overflow:hidden}.contacts-table{width:100%;border-collapse:collapse;font-size:.88rem}.contacts-table thead tr{background:var(--hover-bg)}.contacts-table th{padding:.75rem 1rem;text-align:left;font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border)}.contacts-table td{padding:.65rem 1rem;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.contacts-table tbody tr:last-child td{border-bottom:none}.contacts-table tbody tr:hover td{background:var(--hover-bg)}.contacts-loading,.contacts-empty{text-align:center;padding:2.5rem;color:var(--text-muted)}.contacts-error{padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;color:#f87171;font-size:.9rem}.contacts-name-wrap{display:flex;align-items:center;gap:.5rem}.contacts-entity-icon{font-size:1rem;flex-shrink:0}.contacts-name{font-weight:500}.contacts-email,.contacts-phone,.contacts-city,.contacts-nation{color:var(--text-muted);font-size:.85rem}.contacts-type-badge{display:inline-block;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.badge-cliente{background:#22c55e26;color:#22c55e}.badge-fornitore{background:#3b82f626;color:#3b82f6}.badge-prospect{background:#eab30826;color:#eab308}.badge-altro{background:#94a3b826;color:var(--text-muted)}.contacts-status{display:inline-block;padding:.15rem .55rem;border-radius:6px;font-size:.75rem;font-weight:600}.status-active{background:#22c55e26;color:#22c55e}.status-inactive{background:#ef44441f;color:#f87171}.contacts-actions{display:flex;gap:.4rem;justify-content:flex-end}.btn-icon-action{background:none;border:1px solid var(--border);cursor:pointer;color:var(--text-muted);display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;transition:background .15s,color .15s,border-color .15s}.btn-icon-action:hover{background:var(--hover-bg);color:var(--text-primary);border-color:var(--accent)}.btn-icon-danger:hover{background:#ef44441a;color:#f87171;border-color:#ef444466}.contacts-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;font-size:.9rem;color:var(--text-muted)}.contacts-pagination button{padding:.4rem .9rem;border-radius:8px;border:1px solid var(--border);background:var(--input-bg);color:var(--text-primary);cursor:pointer;font-size:.85rem;transition:background .15s}.contacts-pagination button:disabled{opacity:.4;cursor:default}.contacts-pagination button:not(:disabled):hover{background:var(--hover-bg)}.contacts-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:400;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}.contacts-modal{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;width:100%;max-width:680px;box-shadow:0 24px 64px #00000040;display:flex;flex-direction:column}.contacts-modal-sm{max-width:420px}.contacts-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.contacts-modal-header h2{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary)}.modal-close-btn{background:none;border:none;cursor:pointer;font-size:1rem;color:var(--text-muted);width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.modal-close-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.contacts-form{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.9rem}.cf-section-title{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:.35rem;margin-top:.25rem}.cf-row{display:flex;gap:.75rem;flex-wrap:wrap}.cf-2col .cf-field{flex:1;min-width:180px}.cf-3col .cf-field{flex:1;min-width:140px}.cf-row:not(.cf-2col):not(.cf-3col) .cf-field{flex:1}.cf-field{display:flex;flex-direction:column;gap:.3rem}.cf-field label{font-size:.8rem;font-weight:600;color:var(--text-muted)}.cf-field input[type=text],.cf-field input[type=email],.cf-field input[type=tel],.cf-field input[type=url],.cf-field select,.cf-field textarea{padding:.5rem .75rem;border-radius:9px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.88rem;font-family:inherit;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box}.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-color:var(--accent)}.cf-field input::placeholder,.cf-field textarea::placeholder{color:var(--text-muted)}.cf-field textarea{resize:vertical;min-height:70px}.cf-checkbox-field{justify-content:center}.cf-checkbox-field label{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text-primary);cursor:pointer;font-weight:500;margin-top:.3rem}.cf-checkbox-field input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.contacts-form-error{padding:.6rem .85rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:.85rem}.cf-maps-link{display:inline-flex;align-items:center;gap:5px;font-size:.82rem;color:var(--accent);text-decoration:none;padding:4px 8px;border:1px solid var(--border-color, var(--border));border-radius:6px;transition:background .15s}.cf-maps-link:hover{background:var(--hover-bg)}.contacts-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border)}.btn-secondary{padding:.55rem 1.1rem;border-radius:9px;border:1px solid var(--border);background:var(--input-bg);color:var(--text-primary);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary{padding:.55rem 1.1rem;border-radius:9px;border:none;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-primary:hover:not(:disabled){opacity:.85}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:default}.btn-danger{padding:.55rem 1.1rem;border-radius:9px;border:none;background:#ef4444;color:#fff;font-size:.88rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-danger:hover:not(:disabled){opacity:.85}.contacts-delete-body{padding:1.25rem 1.5rem;font-size:.95rem;color:var(--text-primary)}.contacts-delete-body p{margin:0 0 .5rem}.contacts-delete-warning{color:#f87171;font-size:.85rem}.nazioni-page{display:flex;flex-direction:column;gap:1.5rem}.nazioni-header{display:flex;flex-direction:column;gap:1rem}.nazioni-title-row{display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}.nazioni-btn-add{margin-left:auto;padding:7px 16px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s}.nazioni-btn-add:hover{opacity:.85}.nazioni-title-row h1{margin:0;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.nazioni-count{font-size:.85rem;color:var(--text-muted)}.nazioni-filters{display:flex;gap:.75rem;flex-wrap:wrap}.nazioni-search{flex:1;min-width:240px;padding:.55rem .85rem;border-radius:10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .15s}.nazioni-search:focus{border-color:var(--accent)}.nazioni-search::placeholder{color:var(--text-muted)}.nazioni-filter-eu{padding:.55rem .85rem;border-radius:10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.9rem;outline:none;cursor:pointer;transition:border-color .15s}.nazioni-filter-eu:focus{border-color:var(--accent)}.nazioni-loading,.nazioni-error,.nazioni-empty{padding:2rem;text-align:center;color:var(--text-muted);font-size:.95rem}.nazioni-error{color:#f87171}.nazioni-table-wrap{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;overflow:hidden}.nazioni-table{width:100%;border-collapse:collapse;font-size:.88rem}.nazioni-table thead tr{background:var(--hover-bg)}.nazioni-table th{padding:.75rem 1rem;text-align:left;font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border)}.nazioni-table td{padding:.65rem 1rem;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.nazioni-table tbody tr:last-child td{border-bottom:none}.nazioni-table tbody tr:hover td{background:var(--hover-bg)}.nazioni-flag{font-size:1.3rem;text-align:center!important}.nazioni-code{display:inline-block;font-family:monospace;font-size:.82rem;font-weight:700;color:var(--accent);background:rgba(var(--accent-rgb),.12);padding:.1rem .4rem;border-radius:5px;margin-right:.4rem}.nazioni-code3{font-size:.78rem;color:var(--text-muted);font-family:monospace}.nazioni-name-it{font-weight:500}.nazioni-name-en{color:var(--text-muted);font-size:.85rem}.nazioni-prefix{font-family:monospace;font-size:.85rem;color:var(--text-muted)}.nazioni-eu-badge{display:inline-block;padding:.15rem .5rem;font-size:.72rem;font-weight:700;letter-spacing:.04em;border-radius:6px;background:#3b82f626;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.nazioni-flag-cell{text-align:center;width:36px}.nazioni-flag-img{display:block;border-radius:2px;border:1px solid var(--border-color, #e2e8f0)}.nazioni-flag-placeholder{color:var(--text-muted);font-size:.8rem}.nazioni-actions{text-align:right;white-space:nowrap}.nazioni-btn-icon{width:28px;height:28px;border-radius:6px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;margin-left:4px}.nazioni-btn-icon:hover{color:var(--accent);border-color:var(--accent);background:var(--hover-bg)}.nazioni-btn-del:hover{color:#e05252;border-color:#e05252}.nazioni-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000073;display:flex;align-items:center;justify-content:center;padding:20px}.nazioni-modal{background:var(--card-bg);border-radius:14px;border:1px solid var(--border-color);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;animation:nmSlideUp .18s ease}.nazioni-modal-sm{max-width:380px}@keyframes nmSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.nazioni-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border-color)}.nazioni-modal-header h2{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.nazioni-modal-close{border:none;background:none;font-size:1rem;color:var(--text-muted);cursor:pointer;padding:4px 8px;border-radius:5px}.nazioni-modal-close:hover{background:var(--hover-bg);color:var(--text-primary)}.nazioni-form{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.nf-row{display:grid;gap:12px}.nf-2col{grid-template-columns:1fr 1fr}.nf-field{display:flex;flex-direction:column;gap:4px}.nf-field label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.nf-field input[type=text]{padding:8px 10px;border-radius:7px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-primary);font-size:.88rem;outline:none;transition:border-color .15s}.nf-field input:focus{border-color:var(--accent)}.nf-check label{display:flex;align-items:center;gap:8px;font-size:.85rem;text-transform:none;letter-spacing:0;color:var(--text-primary);cursor:pointer}.nf-check input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.nf-flag-preview{display:flex;align-items:center;gap:8px;font-size:.8rem;color:var(--text-muted);padding:6px 10px;background:var(--hover-bg);border-radius:7px}.nf-error{padding:8px 12px;border-radius:7px;background:#e052521a;border:1px solid rgba(224,82,82,.3);color:#e05252;font-size:.82rem}.nazioni-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border-color)}.nazioni-delete-body{padding:16px 20px}.nazioni-delete-body p{margin:0 0 6px;color:var(--text-primary);font-size:.9rem}.nazioni-delete-warn{font-size:.8rem!important;color:var(--text-muted)!important}.btn-primary{padding:8px 20px;border-radius:8px;border:none;background:var(--accent);color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:8px 18px;border-radius:8px;border:1px solid var(--border-color);background:var(--input-bg);color:var(--text-primary);font-size:.85rem;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--hover-bg)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{padding:8px 20px;border-radius:8px;border:none;background:#e05252;color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-danger:hover{opacity:.85}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.comuni-page{display:flex;flex-direction:column;gap:1.5rem}.comuni-header{display:flex;flex-direction:column;gap:1rem}.comuni-title-row{display:flex;align-items:baseline;gap:.75rem}.comuni-title-row h1{margin:0;font-size:1.6rem;font-weight:700;color:var(--text-primary)}.comuni-count{font-size:.85rem;color:var(--text-muted)}.comuni-filters{display:flex;gap:.75rem;flex-wrap:wrap}.comuni-search{flex:1;min-width:240px;padding:.55rem .85rem;border-radius:10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .15s}.comuni-search:focus{border-color:var(--accent)}.comuni-search::placeholder{color:var(--text-muted)}.comuni-filter-region{padding:.55rem .85rem;border-radius:10px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.9rem;outline:none;cursor:pointer;transition:border-color .15s}.comuni-filter-region:focus{border-color:var(--accent)}.comuni-hint{padding:3rem 2rem;text-align:center;color:var(--text-muted);font-size:.95rem;background:var(--card-bg);border:1px dashed var(--border);border-radius:14px}.comuni-loading,.comuni-error,.comuni-empty{padding:2rem;text-align:center;color:var(--text-muted);font-size:.95rem}.comuni-error{color:#f87171}.comuni-table-wrap{background:var(--card-bg);border:1px solid var(--border);border-radius:14px;overflow:hidden}.comuni-table{width:100%;border-collapse:collapse;font-size:.88rem}.comuni-table thead tr{background:var(--hover-bg)}.comuni-table th{padding:.75rem 1rem;text-align:left;font-size:.78rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border)}.comuni-table td{padding:.65rem 1rem;color:var(--text-primary);border-bottom:1px solid var(--border);vertical-align:middle}.comuni-table tbody tr:last-child td{border-bottom:none}.comuni-table tbody tr:hover td{background:var(--hover-bg)}.comuni-name{font-weight:500}.comuni-prov-badge{display:inline-block;font-family:monospace;font-size:.8rem;font-weight:700;color:var(--accent);background:rgba(var(--accent-rgb),.12);padding:.1rem .4rem;border-radius:5px;margin-right:.5rem}.comuni-prov-name,.comuni-region{font-size:.85rem;color:var(--text-muted)}.comuni-cap{font-family:monospace;font-size:.85rem;font-weight:600;color:var(--text-primary)}.comuni-istat{font-family:monospace;font-size:.8rem;color:var(--text-muted)}.comuni-title-row{flex-wrap:wrap}.comuni-btn-add{margin-left:auto;padding:.45rem 1rem;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .15s}.comuni-btn-add:hover{opacity:.85}.comuni-actions{white-space:nowrap}.comuni-btn-icon{background:none;border:1px solid var(--border-color);border-radius:5px;padding:4px 6px;cursor:pointer;color:var(--text-muted);transition:color .15s,border-color .15s;margin-right:4px;line-height:1}.comuni-btn-icon:hover{color:var(--accent);border-color:var(--accent)}.comuni-btn-del:hover{color:#e53e3e;border-color:#e53e3e}.comuni-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:900;display:flex;align-items:center;justify-content:center}.comuni-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;width:min(560px,95vw);max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #0006}.comuni-modal-sm{width:min(400px,95vw)}.comuni-modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border-color)}.comuni-modal-header h2{margin:0;font-size:1.1rem;color:var(--text-primary)}.comuni-modal-close{background:none;border:none;font-size:1.1rem;cursor:pointer;color:var(--text-muted);padding:2px 6px;border-radius:4px}.comuni-modal-close:hover{background:var(--hover-bg)}.comuni-form{padding:18px 20px 4px;display:flex;flex-direction:column;gap:14px}.cf-row{display:flex;gap:12px}.cf-2col>*{flex:1;min-width:0}.cf-field{display:flex;flex-direction:column;gap:5px}.cf-field label{font-size:.82rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.cf-field input,.cf-field select{padding:8px 10px;background:var(--input-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.9rem;width:100%;box-sizing:border-box}.cf-field input:focus,.cf-field select:focus{outline:none;border-color:var(--accent)}.cf-error{background:#e53e3e1f;color:#e53e3e;border:1px solid rgba(229,62,62,.3);border-radius:6px;padding:8px 12px;font-size:.85rem}.comuni-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid var(--border-color)}.comuni-delete-body{padding:20px 20px 8px;font-size:.95rem;color:var(--text-primary);line-height:1.5}.comuni-delete-body p{margin:0 0 6px}.comuni-delete-warn{font-size:.82rem;color:var(--text-muted)}.sc-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;background:var(--bg, #f5f6fa)}.sc-tabs{display:flex;gap:4px;padding:12px 20px 0;border-bottom:1px solid var(--border-color, #e0e3ea);background:var(--card-bg, #fff);flex-shrink:0}.sc-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted, #888);font-size:.9rem;font-weight:500;cursor:pointer;border-radius:6px 6px 0 0;transition:color .15s,border-color .15s,background .15s;margin-bottom:-1px}.sc-tab:hover{color:var(--text-primary, #222);background:var(--hover-bg, #f0f1f3)}.sc-tab.active{color:var(--accent, #4f46e5);border-bottom-color:var(--accent, #4f46e5);background:none}.sc-list-layout{display:flex;flex:1;min-height:0;overflow:hidden}.sc-list-pane{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0;overflow:hidden;padding:0 0 20px;gap:14px}.sc-has-detail .sc-list-pane{flex:1;min-width:0}.sc-list-header{display:flex;align-items:center;justify-content:space-between}.sc-page-title{font-size:1.6rem;font-weight:700;color:var(--text-primary, #222);margin:0}.sc-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.sc-search{flex:1;min-width:180px;max-width:280px;padding:7px 12px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);color:var(--text-primary, #222);font-size:.875rem}.sc-search:focus{outline:none;border-color:var(--accent, #4f46e5)}.sc-filter-sel{padding:7px 10px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);color:var(--text-primary, #222);font-size:.875rem;cursor:pointer}.sc-filter-sel:focus{outline:none;border-color:var(--accent, #4f46e5)}.sc-filter-chk{display:flex;align-items:center;gap:5px;font-size:.875rem;color:var(--text-muted, #888);cursor:pointer;white-space:nowrap}.sc-filter-chk input{cursor:pointer}.sc-filter-overdue{color:#e53e3e}.sc-ms-wrap{position:relative;flex-shrink:0}.sc-ms-btn{display:flex;align-items:center;gap:6px;padding:7px 10px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);color:var(--text-primary, #222);font-size:.875rem;font-family:inherit;cursor:pointer;white-space:nowrap;transition:border-color .15s;min-width:130px;max-width:220px}.sc-ms-btn:hover,.sc-ms-btn.sc-ms-open{border-color:var(--accent, #4f46e5)}.sc-ms-btn.sc-ms-active{border-color:var(--accent, #4f46e5);color:var(--accent, #4f46e5)}.sc-ms-label{flex:1;overflow:hidden;text-overflow:ellipsis;text-align:left}.sc-ms-caret{font-size:.6rem;opacity:.5;flex-shrink:0}.sc-ms-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:100%;background:var(--card-bg, #fff);border:1px solid var(--border-color, #dde1ea);border-radius:10px;box-shadow:0 8px 24px #00000024;z-index:200;padding:6px 0;display:flex;flex-direction:column}.sc-ms-opt{display:flex;align-items:center;gap:8px;padding:7px 12px;font-size:.875rem;color:var(--text-primary, #222);cursor:pointer;transition:background .1s}.sc-ms-opt:hover{background:var(--hover-bg, #f0f1f3)}.sc-ms-opt input[type=checkbox]{cursor:pointer;accent-color:var(--accent, #4f46e5)}.sc-ms-clear{margin:4px 8px 2px;padding:5px 10px;font-size:.78rem;color:var(--text-muted, #888);background:none;border:1px solid var(--border-color, #dde1ea);border-radius:6px;cursor:pointer;font-family:inherit;transition:background .15s,color .15s}.sc-ms-clear:hover{background:var(--hover-bg, #f0f1f3);color:var(--text-primary, #222)}.sc-table-wrap{overflow:auto;flex:1;border-radius:10px;border:1px solid var(--border-color, #e0e3ea);background:var(--card-bg, #fff)}.sc-table{width:100%;border-collapse:collapse;font-size:.875rem}.sc-table th{position:sticky;top:0;background:var(--card-bg, #fff);padding:10px 14px;text-align:left;font-size:.78rem;font-weight:600;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-color, #e0e3ea);z-index:1}.sc-table td{padding:10px 14px;border-bottom:1px solid var(--border-color, #f0f1f5);color:var(--text-primary, #222);vertical-align:middle}.sc-row{cursor:pointer;transition:background .1s}.sc-row:hover{background:var(--hover-bg, #f8f9fc)}.sc-row-sel{background:var(--accent-bg, #ede9fe)!important}.sc-row-ovd .sc-col-title{color:#c53030}.sc-col-title{font-weight:500;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-date-ovd{color:#e53e3e;font-weight:600}.sc-priv-icon{margin-left:4px;font-size:.75rem;opacity:.6}.sc-th-sort{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.sc-th-sort:hover{color:var(--text-primary, #333)}.sc-sort-icon{font-size:.7rem;opacity:.45;margin-left:2px}.sc-th-sort:hover .sc-sort-icon{opacity:.8}@media (max-width: 900px){.sc-th-hide{display:none}}.sc-badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.sc-s-gray{background:#e2e8f0;color:#4a5568}.sc-s-blue{background:#bee3f8;color:#2b6cb0}.sc-s-orange{background:#feebc8;color:#c05621}.sc-s-green{background:#c6f6d5;color:#276749}.sc-s-red{background:#fed7d7;color:#c53030}.sc-s-muted{background:#edf2f7;color:#718096}.sc-prio-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.sc-p-low{background:#e6fffa;color:#234e52}.sc-p-medium{background:#fefcbf;color:#744210}.sc-p-high{background:#feebc8;color:#c05621}.sc-p-urgent{background:#fed7d7;color:#9b2c2c}.sc-avatars{display:flex;gap:3px}.sc-avatar{width:26px;height:26px;border-radius:50%;background:var(--accent, #4f46e5);color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sc-avatar-more{background:var(--border-color, #c0c7d6);color:var(--text-muted, #555);font-size:.7rem}.sc-chip-list{display:flex;flex-wrap:wrap;gap:4px}.sc-chip{display:inline-block;padding:2px 7px;background:var(--input-bg, #eef0f7);border:1px solid var(--border-color, #dde0ea);border-radius:12px;font-size:.72rem;color:var(--text-muted, #555);white-space:nowrap}.sc-pagination{display:flex;align-items:center;justify-content:center;gap:14px;padding:10px 0 4px;font-size:.85rem;color:var(--text-muted, #888);flex-shrink:0}.sc-pagination button{padding:4px 12px;border:1px solid var(--border-color, #dde1ea);border-radius:6px;background:var(--card-bg, #fff);color:var(--text-primary, #222);cursor:pointer;font-size:.85rem}.sc-pagination button:disabled{opacity:.4;cursor:default}.sc-loading,.sc-empty{padding:40px 20px;text-align:center;color:var(--text-muted, #888);font-size:.9rem}.sc-empty-sub{padding:20px 0;text-align:center;color:var(--text-muted, #aaa);font-size:.85rem}.sc-detail{flex:0 0 clamp(300px,38%,480px);min-width:0;max-width:clamp(300px,38%,480px);box-sizing:border-box;border-left:1px solid var(--border-color, #e0e3ea);background:var(--card-bg, #fff);display:flex;flex-direction:column;overflow:hidden}.sc-detail-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-color, #e0e3ea);flex-shrink:0}.sc-detail-close{width:28px;height:28px;border:none;border-radius:6px;background:none;color:var(--text-muted, #888);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.sc-detail-close:hover{background:var(--hover-bg, #f0f1f3)}.sc-detail-actions{display:flex;gap:6px}.sc-act-btn{padding:5px 10px;font-size:.8rem;border-radius:6px;cursor:pointer}.sc-detail-title{padding:12px 16px 4px;font-size:1.05rem;font-weight:700;color:var(--text-primary, #222);line-height:1.35}.sc-detail-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px;padding:4px 16px 12px}.sc-detail-date{font-size:.85rem;color:var(--text-muted, #777)}.sc-detail-tabs{display:flex;border-bottom:1px solid var(--border-color, #e0e3ea);flex-shrink:0}.sc-dtab{flex:1;padding:8px 6px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted, #888);font-size:.82rem;font-weight:500;cursor:pointer;margin-bottom:-1px;transition:color .15s,border-color .15s}.sc-dtab:hover{color:var(--text-primary, #222)}.sc-dtab.active{color:var(--accent, #4f46e5);border-bottom-color:var(--accent, #4f46e5)}.sc-sup{background:var(--accent, #4f46e5);color:#fff;border-radius:10px;padding:1px 5px;font-size:.65rem;margin-left:3px}.sc-detail-body{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column}.sc-info{display:flex;flex-direction:column;gap:10px}.sc-info-row{display:flex;flex-direction:column;gap:4px;font-size:.875rem;color:var(--text-primary, #222)}.sc-info-lbl{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #aaa)}.sc-info-small{margin-top:8px}.sc-info-small span{font-size:.8rem;color:var(--text-muted, #888)}.sc-description{margin-top:8px;padding:10px 12px;background:var(--input-bg, #f8f9fc);border-radius:8px;font-size:.875rem;color:var(--text-primary, #333);line-height:1.55;white-space:pre-wrap}.sc-comments-wrap{display:flex;flex-direction:column;flex:1;min-height:0}.sc-comment-feed{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-bottom:10px}.sc-comment{display:flex;gap:8px;align-items:flex-start}.sc-comment-event{padding:4px 0}.sc-cm-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent, #4f46e5);color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}.sc-cm-body{flex:1;min-width:0}.sc-cm-meta{display:flex;align-items:center;gap:8px;font-size:.8rem;margin-bottom:3px}.sc-cm-time{font-size:.72rem;color:var(--text-muted, #aaa);flex:1}.sc-cm-del{background:none;border:none;color:var(--text-muted, #bbb);cursor:pointer;font-size:.75rem;padding:0 2px;border-radius:4px;transition:color .15s}.sc-cm-del:hover{color:#e53e3e}.sc-cm-text{background:var(--input-bg, #f8f9fc);border-radius:0 8px 8px;padding:7px 10px;font-size:.875rem;color:var(--text-primary, #333);line-height:1.45;white-space:pre-wrap;word-break:break-word}.sc-event{display:flex;align-items:flex-start;gap:8px;width:100%;padding:4px 0}.sc-event-dot{width:8px;height:8px;border-radius:50%;background:var(--border-color, #c0c7d6);flex-shrink:0;margin-left:11px;margin-top:4px}.sc-event-body{flex:1;display:flex;flex-direction:column;gap:1px}.sc-event-line{font-size:.78rem;color:var(--text-muted, #888);font-style:italic}.sc-compose{display:flex;gap:8px;align-items:flex-end;padding-bottom:10px;border-bottom:1px solid var(--border-color, #eee);flex-shrink:0}.sc-compose-input{flex:1;padding:8px 10px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);color:var(--text-primary, #222);font-size:.875rem;resize:none;font-family:inherit;line-height:1.4}.sc-compose-input:focus{outline:none;border-color:var(--accent, #4f46e5)}.sc-compose-send{padding:8px 14px;font-size:.85rem;white-space:nowrap}.sc-renewals{display:flex;flex-direction:column;gap:10px}.sc-renewal-btn{font-size:.85rem;align-self:flex-start}.sc-renewal-card{border:1px solid var(--border-color, #e0e3ea);border-radius:8px;padding:10px 12px;background:var(--input-bg, #f8f9fc);display:flex;flex-direction:column;gap:4px;font-size:.82rem;color:var(--text-primary, #333)}.sc-renewal-hdr{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.sc-renewal-row{color:var(--text-primary, #444)}.sc-renewal-newdate strong{color:var(--accent, #4f46e5)}.sc-renewal-notes{color:var(--text-muted, #777);font-style:italic;margin-top:2px}.sc-renewal-by{color:var(--text-muted, #aaa);font-size:.76rem;margin-top:4px}.sc-cat-page{display:flex;flex-direction:column;flex:1;overflow:hidden;padding:0 0 20px;gap:14px}.sc-cat-child td:first-child{padding-left:28px}.sc-indent{color:var(--text-muted, #bbb)}.sc-cat-desc{font-size:.78rem;color:var(--text-muted, #aaa);margin-top:2px}.sc-row-acts{display:flex;gap:6px}.sc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.sc-modal{background:var(--card-bg, #fff);border-radius:14px;width:100%;max-width:680px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0003}.sc-modal-sm{max-width:460px}.sc-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color, #e0e3ea);flex-shrink:0}.sc-modal-hdr h3{margin:0;font-size:1.05rem;font-weight:700;color:var(--text-primary, #222)}.sc-close{width:30px;height:30px;border:none;border-radius:6px;background:none;color:var(--text-muted, #888);font-size:1rem;cursor:pointer;transition:background .15s}.sc-close:hover{background:var(--hover-bg, #f0f1f3)}.sc-modal-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.sc-modal-ftr{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border-color, #e0e3ea);flex-shrink:0}.sc-section{display:flex;flex-direction:column;gap:12px}.sc-section-ttl{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted, #aaa);padding-bottom:4px;border-bottom:1px solid var(--border-color, #f0f1f5)}.sc-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.sc-field{display:flex;flex-direction:column;gap:5px}.sc-f-full{grid-column:1 / -1}.sc-field label{font-size:.8rem;font-weight:600;color:var(--text-muted, #777)}.sc-field input,.sc-field select,.sc-field textarea{padding:8px 10px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);color:var(--text-primary, #222);font-size:.875rem;font-family:inherit;transition:border-color .15s}.sc-field input:focus,.sc-field select:focus,.sc-field textarea:focus{outline:none;border-color:var(--accent, #4f46e5)}.sc-chklist{display:flex;flex-wrap:wrap;gap:6px 14px;max-height:140px;overflow-y:auto;border:1px solid var(--border-color, #dde1ea);border-radius:8px;padding:8px 10px;background:var(--input-bg, #fafbfd)}.sc-chk{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-primary, #333);cursor:pointer;white-space:nowrap}.sc-chk input[type=checkbox]{cursor:pointer}.sc-contact-wrap{position:relative}.sc-selected-ct{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);font-size:.875rem;color:var(--text-primary, #222)}.sc-ct-clear{background:none;border:none;color:var(--text-muted, #aaa);cursor:pointer;font-size:.8rem;padding:0 2px}.sc-ct-clear:hover{color:#e53e3e}.sc-ct-search{position:relative}.sc-ct-search input{width:100%;padding:8px 10px;border:1px solid var(--border-color, #dde1ea);border-radius:8px;background:var(--input-bg, #fff);color:var(--text-primary, #222);font-size:.875rem}.sc-ct-search input:focus{outline:none;border-color:var(--accent, #4f46e5)}.sc-ct-loading{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-muted, #aaa);font-size:.8rem}.sc-ct-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--card-bg, #fff);border:1px solid var(--border-color, #dde1ea);border-radius:8px;box-shadow:0 6px 20px #0000001f;z-index:100;max-height:200px;overflow-y:auto}.sc-ct-opt{padding:9px 12px;font-size:.875rem;cursor:pointer;color:var(--text-primary, #222);transition:background .1s}.sc-ct-opt:hover{background:var(--hover-bg, #f0f1f3)}.sc-cal-wrap{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0;overflow:hidden;padding:0 0 20px;gap:14px}.sc-has-detail .sc-cal-wrap{flex:1;min-width:0}.sc-cal-nav{display:flex;align-items:center;gap:10px;flex-shrink:0}.sc-cal-title{font-size:1.2rem;font-weight:700;color:var(--text-primary, #222);min-width:200px;text-align:center}.sc-cal-nav-btn{background:none;border:1px solid var(--border-color, #dde1ea);border-radius:7px;color:var(--text-primary, #222);cursor:pointer;padding:5px 8px;display:flex;align-items:center;transition:background .15s}.sc-cal-nav-btn:hover{background:var(--hover-bg, #f0f1f3)}.sc-cal-today-btn{background:none;border:1px solid var(--border-color, #dde1ea);border-radius:7px;color:var(--text-muted, #888);cursor:pointer;padding:5px 12px;font-size:.82rem;font-family:inherit;transition:background .15s,color .15s}.sc-cal-today-btn:hover{background:var(--hover-bg, #f0f1f3);color:var(--text-primary, #222)}.sc-cal-filters{display:flex;align-items:center;gap:8px;margin-left:6px;flex-wrap:wrap}.sc-cal-spin{color:var(--text-muted, #aaa);animation:sc-spin 1s linear infinite;display:flex;align-items:center;margin-left:auto}@keyframes sc-spin{to{transform:rotate(360deg)}}.sc-cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;background:var(--border-color, #e0e3ea);border:1px solid var(--border-color, #e0e3ea);border-radius:10px;overflow:hidden;flex:1;min-height:0;overflow-y:auto;width:100%}.sc-cal-dow{background:var(--card-bg, #fff);padding:8px 6px;text-align:center;font-size:.75rem;font-weight:600;color:var(--text-muted, #888);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0;z-index:1}.sc-cal-dow.sc-cal-weekend{color:var(--accent, #4f46e5)}.sc-cal-cell{background:var(--card-bg, #fff);padding:6px;min-height:90px;min-width:0;overflow:hidden;display:flex;flex-direction:column;gap:3px}.sc-cal-empty{background:var(--layout-bg, #f5f6fa);opacity:.5}.sc-cal-weekend-cell{background:rgba(var(--accent-rgb, 99,102,241),.03)}.sc-cal-today{background:rgba(var(--accent-rgb, 99,102,241),.08)}.sc-cal-day-num{font-size:.78rem;font-weight:600;color:var(--text-muted, #888);width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.sc-cal-today .sc-cal-day-num{background:var(--accent, #4f46e5);color:#fff}.sc-cal-items{display:flex;flex-direction:column;gap:2px}.sc-cal-item{display:flex;align-items:center;gap:4px;padding:2px 5px;border-radius:4px;border:none;cursor:pointer;text-align:left;font-size:.7rem;font-weight:500;font-family:inherit;width:100%;min-width:0;overflow:hidden;color:#fff;transition:opacity .15s;box-sizing:border-box}.sc-cal-item:hover{opacity:.82}.sc-cal-item-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.sc-cal-item-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.sc-cal-more{font-size:.68rem;color:var(--text-muted, #aaa);padding-left:4px;cursor:default}.sc-cal-s-bozza{background:#6b7280}.sc-cal-s-aperta{background:#3b82f6}.sc-cal-s-in_lavorazione{background:#f59e0b}.sc-cal-s-completata{background:#10b981}.sc-cal-s-scaduta{background:#ef4444}.sc-cal-s-annullata{background:#9ca3af}.sc-cal-ovd{outline:2px solid #ef4444;outline-offset:-1px}.sc-cal-legend{display:flex;flex-wrap:wrap;gap:12px;flex-shrink:0;padding-top:4px}.sc-cal-leg-item{display:flex;align-items:center;gap:5px;font-size:.75rem;color:var(--text-muted, #888);background:none!important}.sc-cal-leg-item .sc-cal-item-dot{width:8px;height:8px;background:#ccc}.sc-cal-leg-item.sc-cal-s-bozza .sc-cal-item-dot{background:#6b7280}.sc-cal-leg-item.sc-cal-s-aperta .sc-cal-item-dot{background:#3b82f6}.sc-cal-leg-item.sc-cal-s-in_lavorazione .sc-cal-item-dot{background:#f59e0b}.sc-cal-leg-item.sc-cal-s-completata .sc-cal-item-dot{background:#10b981}.sc-cal-leg-item.sc-cal-s-scaduta .sc-cal-item-dot{background:#ef4444}.sc-cal-leg-item.sc-cal-s-annullata .sc-cal-item-dot{background:#9ca3af}.sc-err{padding:10px 14px;background:#fed7d7;border:1px solid #fc8181;border-radius:8px;color:#c53030;font-size:.875rem}@media (max-width: 960px){.sc-has-detail .sc-list-pane,.sc-has-detail .sc-cal-wrap{display:none}.sc-detail{position:fixed;top:0;right:0;bottom:0;left:0;flex:none;width:100%!important;max-width:100%!important;z-index:200;border-left:none}}@media (max-width: 768px){.sc-2col{grid-template-columns:1fr}.sc-modal{max-height:96vh;border-radius:12px}}
