:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:12px;padding:40px;box-shadow:0 10px 40px #0000001a;width:100%;max-width:400px}.login-card h1{margin:0 0 30px;color:#333;font-size:28px;text-align:center}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.login-button:disabled{opacity:.6;cursor:not-allowed}.home-container{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;padding:0 20px;position:sticky;top:0;z-index:100}.nav-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto;height:64px}.nav-logo{margin:0;font-size:24px;color:#667eea;font-weight:700}.nav-user{display:flex;align-items:center;gap:16px}.user-email{color:#666;font-size:14px}.logout-button{padding:8px 16px;background-color:#f44336;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.logout-button:hover{background-color:#d32f2f}.main-content{display:flex;flex:1;max-width:1400px;margin:0 auto;width:100%;padding:20px;gap:20px}.sidebar{width:250px;background:#fff;border-radius:8px;padding:20px 0;box-shadow:0 2px 4px #0000001a;height:fit-content;position:sticky;top:84px}.sidebar-nav{display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 20px;color:#666;text-decoration:none;transition:background-color .2s,color .2s;border-left:3px solid transparent}.nav-item:hover{background-color:#f5f5f5;color:#667eea}.nav-item.active{background-color:#f0f0ff;color:#667eea;border-left-color:#667eea;font-weight:500}.nav-item span{font-size:20px}.content-area{flex:1;background:#fff;border-radius:8px;padding:30px;box-shadow:0 2px 4px #0000001a}.welcome-section{margin-bottom:30px}.welcome-section h2{margin:0 0 8px;color:#333;font-size:28px}.welcome-section p{margin:0;color:#666;font-size:16px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:30px}.dashboard-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:24px;color:#fff;box-shadow:0 4px 6px #0000001a}.dashboard-card h3{margin:0 0 12px;font-size:16px;font-weight:500;opacity:.9}.card-value{margin:0;font-size:32px;font-weight:700}.customers-page{width:100%}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-header h1{margin:0;font-size:28px;color:#333}.create-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.create-button:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.error-banner{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin-bottom:20px;border:1px solid #fcc}.loading{text-align:center;padding:40px;color:#666;font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state p{font-size:18px;margin-bottom:20px}.table-container{overflow-x:auto;border-radius:8px;border:1px solid #e0e0e0}.customers-table{width:100%;border-collapse:collapse;background:#fff}.customers-table thead{background-color:#f8f9fa}.customers-table th{padding:16px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.customers-table td{padding:16px;border-bottom:1px solid #f0f0f0;color:#555;font-size:14px}.customers-table tbody tr:hover{background-color:#f8f9fa}.customers-table tbody tr:last-child td{border-bottom:none}.name-cell{font-weight:500;color:#333}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:24px;color:#333}.close-button{background:none;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#f0f0f0}.customer-form{padding:24px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.form-group{display:flex;flex-direction:column}.form-group label{margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.required{color:#f44336}.form-group input{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background-color:#fee;color:#c33;padding:12px 16px;border-radius:8px;margin:0 24px 20px;border:1px solid #fcc;font-size:14px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e0e0e0}.cancel-button,.submit-button{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-button{background-color:#f5f5f5;color:#666}.cancel-button:hover:not(:disabled){background-color:#e0e0e0}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.cancel-button:disabled,.submit-button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.form-row{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.customers-table{font-size:12px}.customers-table th,.customers-table td{padding:8px}}:root{--bg: #0b1220;--card: rgba(255,255,255,.06);--card2: rgba(255,255,255,.08);--border: rgba(255,255,255,.12);--text: rgba(255,255,255,.92);--muted: rgba(255,255,255,.68);--muted2: rgba(255,255,255,.55);--shadow: 0 18px 50px rgba(0,0,0,.45);--radius: 18px}*{box-sizing:border-box}body{margin:0}.page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px 16px;background:radial-gradient(1200px 600px at 10% 10%,rgba(120,120,255,.18),transparent 60%),radial-gradient(900px 500px at 90% 20%,rgba(0,220,180,.14),transparent 55%),radial-gradient(700px 500px at 50% 90%,rgba(255,140,0,.1),transparent 60%),var(--bg);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji"}.card{width:min(720px,100%);background:linear-gradient(180deg,var(--card),rgba(255,255,255,.03));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header{display:flex;gap:14px;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.title{margin:0;font-size:22px;letter-spacing:.2px}.subtitle{margin:8px 0 0;color:var(--muted);font-size:14px;line-height:1.35}.badge{font-size:12px;color:var(--muted2);padding:8px 10px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;white-space:nowrap}.dropzone{border:1px dashed rgba(255,255,255,.22);background:#ffffff08;border-radius:calc(var(--radius) - 6px);padding:18px;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease;-webkit-user-select:none;user-select:none}.dropzone:hover{transform:translateY(-1px);background:#ffffff0d;border-color:#ffffff52}.dropzone.disabled{opacity:.75;cursor:not-allowed}.fileInput{display:none}.dropInner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:12px}.icon{font-size:34px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.35))}.dropText{display:flex;flex-direction:column;gap:4px;font-size:14px}.dropText span{color:var(--muted)}.hint{margin-top:6px;font-size:12px;color:var(--muted2)}.fileRow{display:flex;align-items:center;gap:12px}.fileIcon{width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:#00ffb41a;border:1px solid rgba(0,255,180,.22)}.fileInfo{flex:1;min-width:0}.fileName{font-size:14px;font-weight:650;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fileMeta{margin-top:4px;font-size:12px;color:var(--muted)}.progressWrap{margin-top:10px;height:10px;border-radius:999px;background:#ffffff14;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.progressBar{height:100%;border-radius:999px;background:linear-gradient(90deg,#7878fff2,#00dcb4e6);width:0%;transition:width .2s ease}.actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}button{border:1px solid var(--border);border-radius:12px;padding:10px 14px;font-weight:650;cursor:pointer;background:transparent;color:var(--text)}button:disabled{opacity:.55;cursor:not-allowed}.primaryBtn{background:linear-gradient(90deg,#7878fff2,#00dcb4e6);border:0;color:#071018}.primaryBtn:hover:not(:disabled){filter:brightness(1.05)}.secondaryBtn{background:#ffffff0a}.secondaryBtn:hover:not(:disabled){background:#ffffff0f}.ghostBtn{background:#ffffff08}.ghostBtn:hover:not(:disabled){background:#ffffff0f}.alert{margin-top:14px;padding:12px;border-radius:14px;display:flex;align-items:center;gap:10px;border:1px solid var(--border);background:#ffffff0a;font-size:14px}.alert .alertDot{width:10px;height:10px;border-radius:999px;background:#ffffff80;box-shadow:0 0 0 4px #ffffff14}.alert.info{border-color:#7878ff47}.alert.info .alertDot{background:#7878fff2;box-shadow:0 0 0 4px #7878ff29}.alert.success{border-color:#00dcb442}.alert.success .alertDot{background:#00dcb4f2;box-shadow:0 0 0 4px #00dcb424}.alert.error{border-color:#ff5a5a42}.alert.error .alertDot{background:#ff5a5af2;box-shadow:0 0 0 4px #ff5a5a24}.footer{margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);color:var(--muted2);font-size:12px;line-height:1.35}.batch-progress-card{background:#fff;padding:22px;margin-bottom:25px;border-radius:12px;box-shadow:0 3px 10px #0000000f;border:1px solid #eee}.batch-header{display:flex;justify-content:space-between;align-items:center}.status-pill{padding:6px 14px;border-radius:25px;font-weight:600;font-size:14px;color:#fff}.status-pill.processing{background:#377dff}.status-pill.completed{background:#28a745}.status-pill.failed{background:#dc3545}.batch-body{margin-top:18px}.progress-bar-wrapper{width:100%;height:12px;background:#eaeaea;border-radius:10px;overflow:hidden;margin-bottom:18px}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#377dff,#1ec8c8);transition:width .4s ease-out}.progress-stats{display:flex;justify-content:space-between;margin-bottom:12px}.stat{text-align:center;flex:1}.stat .label{display:block;font-size:12px;color:#777}.stat .value{font-size:18px;font-weight:700}.stat.success .value{color:#28a745}.stat.failed .value{color:#dc3545}.live-indicator{display:flex;align-items:center;column-gap:8px;font-size:14px;color:#377dff}.live-indicator .dot{width:10px;height:10px;background:#377dff;border-radius:50%;animation:blink 1s infinite alternate}@keyframes blink{0%{opacity:.3}to{opacity:1}}.done-msg-big{padding:12px;background:#e7f8ec;border-left:4px solid #28a745;border-radius:8px;color:#226b33;font-weight:600}.error-msg-big{padding:12px;background:#fbeaea;border-left:4px solid #dc3545;border-radius:8px;color:#a42828;font-weight:600}.csv-loading{margin-top:16px;font-weight:600;color:#555}.dots span{animation:blink 1.4s infinite both}.dots span:nth-child(1){animation-delay:0s}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%{opacity:.2}20%{opacity:1}to{opacity:.2}}.csv-ready{margin-top:20px}.download-btn{display:inline-block;padding:10px 16px;background:#2e7d32;color:#fff;border-radius:8px;text-decoration:none;font-weight:600}.download-btn:hover{background:#1b5e20}
