*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.relative{position:relative}.col-span-2{grid-column:span 2 / span 2}.mb-2{margin-bottom:.5rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-40{height:10rem}.w-full{width:100%}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.gap-4{gap:1rem}.rounded{border-radius:.25rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.p-0{padding:0}.p-4{padding:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-sm{font-size:.875rem;line-height:1.25rem}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}:root{--sidebar-bg: #1e2a3a;--sidebar-hover: #2d3e52;--sidebar-active: #3b82f6;--sidebar-width: 260px;--sidebar-collapsed: 64px;--topbar-height: 56px;--topbar-bg: #ffffff;--body-bg: #f0f2f5;--card-bg: #ffffff;--primary: #3b82f6;--success: #22c55e;--warning: #f59e0b;--danger: #ef4444;--purple: #8b5cf6;--text-main: #1f2937;--text-muted: #6b7280;--border: #e5e7eb;--radius: 10px;--shadow: 0 1px 4px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--body-bg);font-family:Inter,Segoe UI,sans-serif;color:var(--text-main);font-size:14px}.admin-wrapper{display:flex;min-height:100vh}.admin-sidebar{width:var(--sidebar-width);min-height:100vh;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;z-index:100;transition:width .25s ease;overflow:hidden}.admin-sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.07);color:#fff;min-height:var(--topbar-height)}.brand-logo{width:32px;height:32px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.brand-text{font-size:16px;font-weight:500;color:#e2e8f0;white-space:nowrap}.brand-text strong{color:#fff}.sidebar-user{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.07)}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}.user-info{display:flex;flex-direction:column;overflow:hidden}.user-name{font-size:13px;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:#94a3b8}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-section-label{font-size:10px;font-weight:700;color:#64748b;letter-spacing:.08em;padding:10px 18px 4px;text-transform:uppercase}.nav-section-label.mt-4{margin-top:8px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:#94a3b8;text-decoration:none;transition:background .15s,color .15s;cursor:pointer;border:none;background:transparent;width:100%;text-align:left;font-size:13.5px;border-left:3px solid transparent}.nav-item:hover{background:var(--sidebar-hover);color:#e2e8f0}.nav-item.active{background:#3b82f626;color:#60a5fa;border-left-color:var(--primary)}.nav-icon{flex-shrink:0;width:20px;display:flex;align-items:center;justify-content:center}.nav-label{flex:1;white-space:nowrap}.nav-arrow{opacity:.3;margin-left:auto}.nav-item:hover .nav-arrow,.nav-item.active .nav-arrow{opacity:.7}.admin-main{margin-left:var(--sidebar-width);flex:1;min-height:100vh;display:flex;flex-direction:column;transition:margin-left .25s ease}.admin-main.expanded{margin-left:var(--sidebar-collapsed)}.admin-topbar{height:var(--topbar-height);background:var(--topbar-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow)}.topbar-toggle{background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:6px;border-radius:6px;display:flex;align-items:center}.topbar-toggle:hover{background:#f3f4f6;color:var(--text-main)}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-icon-btn{position:relative;background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:8px;border-radius:8px;display:flex;align-items:center}.topbar-icon-btn:hover{background:#f3f4f6}.topbar-icon-btn .badge{position:absolute;top:4px;right:4px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center}.topbar-user{position:relative}.topbar-user-btn{display:flex;align-items:center;gap:8px;background:transparent;border:none;cursor:pointer;padding:6px 10px;border-radius:8px;color:var(--text-main)}.topbar-user-btn:hover{background:#f3f4f6}.topbar-avatar{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.topbar-username{font-size:13px;font-weight:500}.topbar-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);width:220px;z-index:200;overflow:hidden}.dropdown-header{display:flex;align-items:center;gap:10px;padding:14px;background:#f8fafc}.dropdown-avatar{width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}.dropdown-name{font-size:13px;font-weight:600}.dropdown-email{font-size:11px;color:var(--text-muted)}.dropdown-divider{height:1px;background:var(--border)}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:transparent;border:none;cursor:pointer;font-size:13px;color:var(--text-main);text-align:left}.dropdown-item:hover{background:#f3f4f6}.dropdown-item.text-red{color:var(--danger)}.dropdown-item.text-red:hover{background:#fef2f2}.admin-content{flex:1;padding:24px}.page-container{display:flex;flex-direction:column;gap:20px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:12px}.page-title{font-size:22px;font-weight:700;color:var(--text-main);line-height:1.2}.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-top:4px}.breadcrumb span{cursor:default}.breadcrumb-link{color:var(--primary);cursor:pointer}.breadcrumb-link:hover{text-decoration:underline}.page-header-actions{display:flex;gap:8px;align-items:center}.badge-date{font-size:12px;color:var(--text-muted);background:#fff;border:1px solid var(--border);padding:5px 12px;border-radius:20px}.card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.card-header{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--border);font-size:14px;font-weight:600;color:var(--text-main);background:#fafbfc}.card-body{padding:18px}.card-body.p-0{padding:0}.card-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-top:1px solid var(--border);background:#fafbfc;font-size:12px}.flex-1{flex:1}.flex-col{display:flex;flex-direction:column}.gap-4{gap:16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.stat-grid{grid-template-columns:1fr}}.stat-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.stat-card-body{display:flex;align-items:center;justify-content:space-between;padding:20px}.stat-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:.85}.stat-value{font-size:30px;font-weight:800;line-height:1.1;margin:4px 0}.stat-change{font-size:11px;display:flex;align-items:center;gap:4px;opacity:.8}.stat-icon-wrap{width:54px;height:54px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#fff3}.stat-blue{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.stat-yellow{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.stat-green{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.stat-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.charts-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px}.col-span-2{grid-column:span 1}@media (max-width: 900px){.charts-grid{grid-template-columns:1fr}}.data-table{width:100%;border-collapse:collapse;font-size:13.5px}.data-table thead tr{background:#f8fafc;border-bottom:2px solid var(--border)}.data-table th{padding:11px 16px;text-align:left;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);white-space:nowrap}.data-table td{padding:12px 16px;border-bottom:1px solid #f1f5f9;vertical-align:middle}.data-table tbody tr:hover{background:#f8fafc}.data-table tbody tr:last-child td{border-bottom:none}.table-empty{text-align:center;padding:40px!important;color:var(--text-muted)}.table-empty svg{margin:0 auto 8px;display:block;opacity:.3}.table-title{font-weight:500;color:var(--text-main)}.table-user{font-weight:500}.table-action-icon{display:inline-flex;align-items:center;margin-right:5px;color:var(--text-muted);vertical-align:middle}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;white-space:nowrap}.badge-success{background:#dcfce7;color:#15803d}.badge-warning{background:#fef9c3;color:#a16207}.badge-danger{background:#fee2e2;color:#b91c1c}.badge-secondary{background:#f1f5f9;color:#475569}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#16a34a}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover{background:#d97706}.btn-outline{background:transparent;color:var(--primary);border:1.5px solid var(--primary)}.btn-outline:hover{background:#eff6ff}.btn-sm{padding:5px 10px;font-size:12px}.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.form-group label{font-size:12.5px;font-weight:600;color:var(--text-main)}.form-control{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:7px;font-size:13.5px;color:var(--text-main);background:#fff;outline:none;transition:border .15s}.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-control:disabled{background:#f8fafc;color:var(--text-muted);cursor:not-allowed}.form-hint{font-size:11px;color:var(--text-muted)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 640px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;gap:10px;margin-top:6px}textarea.form-control{resize:vertical;min-height:80px}.alert{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:7px;font-size:13px;margin-bottom:14px}.alert-success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.alert-danger{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.table-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:200px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input{width:100%;padding:8px 12px 8px 34px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;outline:none}.search-input:focus{border-color:var(--primary)}.filter-wrap{display:flex;align-items:center;gap:6px;color:var(--text-muted)}.filter-select{padding:8px 10px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;outline:none}.filter-select:focus{border-color:var(--primary)}.pagination{display:flex;gap:4px}.page-btn{width:30px;height:30px;border-radius:6px;border:1.5px solid var(--border);background:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.page-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page-btn:hover:not(.active){background:#f3f4f6}.text-muted{color:var(--text-muted);font-size:12px}.detail-layout{display:flex;gap:20px;align-items:flex-start}@media (max-width: 900px){.detail-layout{flex-direction:column}}.detail-field{margin-bottom:14px}.detail-field label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);display:block;margin-bottom:4px}.detail-field p{font-size:14px;color:var(--text-main)}.status-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}.timeline{padding:16px;display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:12px;padding-bottom:18px;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:7px;top:20px;bottom:0;width:2px;background:var(--border)}.timeline-item:last-child:before{display:none}.timeline-dot{width:16px;height:16px;border-radius:50%;background:var(--primary);border:2px solid #fff;box-shadow:0 0 0 2px var(--primary);flex-shrink:0;margin-top:2px}.timeline-content{flex:1}.timeline-title{font-size:13px;font-weight:600;text-transform:capitalize}.timeline-comment{font-size:12.5px;color:var(--text-muted);margin:2px 0 4px}.timeline-meta{font-size:11px;color:var(--text-muted)}.profile-layout{display:flex;gap:20px;align-items:flex-start}@media (max-width: 900px){.profile-layout{flex-direction:column}}.profile-sidebar-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:24px 20px;text-align:center;width:240px;flex-shrink:0}.profile-avatar-large{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;font-size:30px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 12px}.profile-card-name{font-size:16px;font-weight:700}.profile-card-role{font-size:12px;color:var(--primary);font-weight:600;margin:2px 0 4px}.profile-card-email{font-size:12px;color:var(--text-muted);word-break:break-all}.profile-tabs{display:flex;flex-direction:column;gap:6px;margin-top:18px}.profile-tab-btn{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:7px;border:1.5px solid var(--border);background:transparent;font-size:13px;cursor:pointer;color:var(--text-main);transition:all .15s}.profile-tab-btn:hover{background:#f3f4f6}.profile-tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.login-page{display:flex;min-height:100vh}.login-left{flex:1;background:linear-gradient(145deg,#1e2a3a,#1a3a5c 60%,#1e4080);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px;color:#fff}@media (max-width: 768px){.login-left{display:none}}.login-brand{text-align:center;margin-bottom:48px}.login-brand svg{opacity:.9;margin-bottom:16px;color:#60a5fa}.login-brand h1{font-size:32px;font-weight:800}.login-brand p{font-size:15px;color:#93c5fd;margin-top:6px}.login-features{display:flex;flex-direction:column;gap:14px}.login-feature-item{font-size:15px;color:#cbd5e1}.login-right{width:480px;display:flex;align-items:center;justify-content:center;padding:32px;background:#f0f2f5}@media (max-width: 768px){.login-right{width:100%}}.login-card{width:100%;max-width:400px;background:#fff;border-radius:14px;padding:36px 32px;box-shadow:var(--shadow-md);border:1px solid var(--border)}.login-card-header{margin-bottom:24px}.login-card-header h2{font-size:24px;font-weight:800}.login-card-header p{font-size:13px;color:var(--text-muted);margin-top:4px}.login-form{display:flex;flex-direction:column;gap:0}.input-icon-wrap{position:relative}.input-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.input-icon-right{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--text-muted);display:flex;align-items:center}.input-icon-wrap .form-control{padding-left:36px}.btn-login{width:100%;padding:11px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;transition:opacity .15s}.btn-login:hover:not(:disabled){opacity:.92}.btn-login:disabled{opacity:.7;cursor:not-allowed}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{text-align:center;font-size:11.5px;color:var(--text-muted);margin-top:24px}.kanban-board{display:flex;gap:14px;overflow-x:auto;padding-bottom:16px;align-items:flex-start;min-height:500px}.kanban-column{min-width:240px;width:240px;flex-shrink:0;background:#f8fafc;border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column}.kanban-column-header{padding:12px 14px;border-top:3px solid;border-radius:var(--radius) var(--radius) 0 0;display:flex;align-items:center;justify-content:space-between;background:#fff;font-size:13px}.kanban-count{padding:2px 8px;border-radius:12px;font-size:12px;font-weight:700}.kanban-cards{flex:1;padding:8px;display:flex;flex-direction:column;gap:8px;min-height:80px}.kanban-empty{text-align:center;color:#9ca3af;font-size:12px;padding:20px 8px;border:2px dashed #e5e7eb;border-radius:8px;margin:4px}.kanban-card{background:#fff;border-radius:8px;border:1px solid var(--border);padding:10px 12px;cursor:grab;transition:box-shadow .15s}.kanban-card:hover{box-shadow:0 4px 12px #0000001a}.kanban-card:active{cursor:grabbing}.kanban-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:6px;margin-bottom:4px}.kanban-card-title{font-size:13px;font-weight:600;color:var(--text-main);cursor:pointer;flex:1;line-height:1.3}.kanban-card-title:hover{color:var(--primary)}.kanban-card-menu-btn{background:none;border:none;cursor:pointer;color:#9ca3af;padding:2px;border-radius:4px;display:flex;align-items:center}.kanban-card-menu-btn:hover{background:#f3f4f6;color:var(--text-main)}.kanban-card-menu{position:absolute;right:0;top:24px;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-md);z-index:100;min-width:130px;overflow:hidden}.kanban-card-menu button{display:flex;align-items:center;gap:7px;width:100%;padding:8px 12px;background:none;border:none;cursor:pointer;font-size:12.5px;color:var(--text-main);text-align:left}.kanban-card-menu button:hover{background:#f3f4f6}.kanban-card-menu button.text-red{color:var(--danger)}.kanban-card-industry{font-size:11px;color:var(--primary);font-weight:600;margin-bottom:6px}.kanban-card-meta{display:flex;flex-direction:column;gap:3px;margin-bottom:8px}.kanban-card-meta span{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kanban-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:6px;border-top:1px solid #f1f5f9}.kanban-card-source{font-size:10px;background:#f1f5f9;color:#64748b;padding:2px 6px;border-radius:4px}.kanban-card-actions{display:flex;gap:4px;flex-wrap:wrap}.stage-btn{background:none;border:none;cursor:pointer;font-size:10px;padding:2px 5px;border-radius:4px}.stage-btn:hover{background:#f3f4f6}.leads-stats-bar{display:flex;gap:10px;flex-wrap:wrap}.leads-stat-pill{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid;border-radius:20px;padding:6px 14px;font-size:12px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.modal-box{background:#fff;border-radius:14px;box-shadow:0 20px 60px #0003;width:100%;max-width:540px;max-height:90vh;overflow-y:auto}.modal-box.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{font-size:16px;font-weight:700}.modal-header button{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:18px;line-height:1;padding:2px 6px;border-radius:4px}.modal-header button:hover{background:#f3f4f6;color:var(--text-main)}.modal-body{padding:20px}.contact-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-main);text-decoration:none}.contact-row:hover{color:var(--primary)}.scraper-banner{display:flex;align-items:flex-start;gap:10px;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius);padding:12px 16px;font-size:13px;color:#78350f}.scraper-preview{background:#f8fafc;border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:12px;margin-top:8px}.scraper-preview code{display:block;color:#1d4ed8;font-weight:600;margin-top:2px;font-family:monospace}.extraction-result{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;padding:12px;font-size:13px}.ml-2{margin-left:8px}.scraper-mode-card{display:flex;align-items:center;gap:14px;padding:16px 20px;border:2px solid var(--border);border-radius:10px;cursor:pointer;background:var(--card);transition:border-color .15s,box-shadow .15s;flex:1}.scraper-mode-card:hover{border-color:var(--primary)}.scraper-mode-card.active{border-color:var(--primary);background:#eff6ff;box-shadow:0 0 0 3px #3b82f61f}.scraper-mode-card .mode-icon{font-size:28px;line-height:1}.scraper-mode-card .mode-label{font-weight:700;font-size:15px;color:var(--text)}.scraper-mode-card .mode-desc{font-size:12px;color:var(--muted);margin-top:2px}.scraper-maps-tip{display:flex;align-items:flex-start;gap:10px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius);padding:12px 16px;font-size:13px;color:#1e40af}.text-center{text-align:center}
