@import "https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;500&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#080b11;--bg-secondary:#0f1524;--card-bg:#0f1626a6;--card-border:#ffffff14;--card-border-glow:#8b5cf64d;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-primary:#8b5cf6;--accent-secondary:#6366f1;--accent-glow:#8b5cf626;--accent-success:#10b981;--accent-danger:#ef4444;--accent-warning:#f59e0b;--font-sans:"Outfit", system-ui, -apple-system, sans-serif;--font-mono:"Fira Code", "Courier New", monospace;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--transition-fast:all .15s ease-out;--shadow-premium:0 10px 30px -10px #000000b3, 0 1px 1px 0 #ffffff0d inset;--shadow-glow:0 0 25px -5px #8b5cf633}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(circle at 10% 20%,#6366f114 0%,#0000 40%),radial-gradient(circle at 90% 80%,#8b5cf614 0%,#0000 45%);background-attachment:fixed;min-height:100vh;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--card-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}#root{flex-direction:column;gap:2rem;width:100%;max-width:1300px;min-height:100vh;margin:0 auto;padding:2rem 1.5rem;display:flex}.glass-panel{z-index:1;background:var(--card-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--card-border);box-shadow:var(--shadow-premium);transition:var(--transition-smooth);border-radius:16px;padding:1.5rem;position:relative}.glass-panel.has-open-dropdown{z-index:100}.glass-panel:hover{border-color:#ffffff1f}.app-header{box-sizing:border-box;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;min-height:90px;padding:1.5rem 2.25rem;display:flex;overflow:visible!important}.app-title-group{align-items:center;gap:1rem;display:flex}.logo-icon{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));width:42px;height:42px;box-shadow:var(--shadow-glow);color:#fff;border-radius:12px;justify-content:center;align-items:center;display:flex}.logo-text{flex-direction:column;justify-content:center;display:flex}.logo-text h1{letter-spacing:-.5px;background:linear-gradient(90deg,#fff,#c084fc);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin:0;font-size:1.75rem;font-weight:700;line-height:1.2}.logo-text p{color:var(--text-secondary);margin:.15rem 0 0;font-size:.85rem;line-height:1.4}.btn{font-family:var(--font-sans);cursor:pointer;transition:var(--transition-smooth);border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1.25rem;font-size:.9rem;font-weight:500;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--accent-primary), var(--accent-secondary));color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 0 30px -3px #8b5cf666}.btn-primary:active{transform:translateY(0)}.btn-secondary{border-color:var(--card-border);color:var(--text-primary);background:#ffffff0d}.btn-secondary:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.btn-success{background:var(--accent-success);color:#fff}.btn-success:hover{filter:brightness(1.1);transform:translateY(-1px)}.dropzone{text-align:center;cursor:pointer;transition:var(--transition-smooth);background:#0f16264d;border:2px dashed #ffffff26;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:1.25rem;padding:3rem 2rem;display:flex}.dropzone.drag-active{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);background:#8b5cf60d;transform:scale(1.01)}.dropzone-icon-container{width:70px;height:70px;color:var(--accent-primary);transition:var(--transition-smooth);background:#8b5cf61a;border-radius:50%;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.dropzone:hover .dropzone-icon-container{color:#c084fc;background:#8b5cf633;transform:scale(1.1)}.dropzone h3{color:var(--text-primary);font-size:1.25rem;font-weight:600}.dropzone p{color:var(--text-secondary);max-width:400px;font-size:.9rem}.dropzone-file-input{display:none}.dashboard-grid{grid-template-columns:320px 1fr;align-items:start;gap:1.5rem;display:grid}.dashboard-grid>:last-child{min-width:0}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}.sidebar-panel{flex-direction:column;gap:1.25rem;display:flex}.sidebar-panel h2{border-bottom:1px solid var(--card-border);align-items:center;gap:.5rem;padding-bottom:.75rem;font-size:1.2rem;font-weight:600;display:flex}.mapping-group{flex-direction:column;gap:.75rem;display:flex}.mapping-item{flex-direction:column;gap:.35rem;display:flex}.draggable-item{z-index:1;background:#ffffff03;border:1px solid #ffffff05;border-radius:8px;padding:.4rem;transition:all .2s;position:relative}.draggable-item.has-open-dropdown{z-index:10}.draggable-item:hover{background:#ffffff05;border-color:#ffffff0d}.draggable-item.dragging{opacity:.35;border:1px dashed var(--accent-primary);background:#8b5cf60d}.drag-container{align-items:flex-start;gap:.5rem;width:100%;display:flex}.drag-handle{cursor:grab;transition:background var(--transition-fast), color var(--transition-fast);color:var(--text-secondary);opacity:.5;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-top:.15rem;padding:.2rem;display:flex}.drag-handle:hover{color:var(--accent-primary);opacity:1;background:#ffffff14}.drag-handle:active{cursor:grabbing}.mapping-item-content{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.mapping-label{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:.8rem;font-weight:500;display:flex}.mapping-badge{color:#c084fc;white-space:nowrap;background:#8b5cf626;border-radius:4px;flex-shrink:0;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.mapping-select{background:var(--bg-primary);border:1px solid var(--card-border);color:var(--text-primary);font-family:var(--font-sans);cursor:pointer;width:100%;transition:var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a78bfa' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:.85rem;border-radius:8px;padding:.5rem 2rem .5rem .75rem;font-size:.85rem}.mapping-select option{color:var(--text-primary);background:#110f1e}.mapping-select:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px #8b5cf633}.time-input-container{align-items:center;width:100%;display:flex;position:relative}.time-input{background:var(--bg-primary);border:1.5px solid var(--card-border);color:var(--text-primary);font-family:var(--font-sans);width:100%;transition:var(--transition-fast);box-sizing:border-box;border-radius:10px;padding:.75rem 2.5rem .75rem 1rem;font-size:1.05rem}.time-input:focus{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px #8b5cf633}.time-input-clear-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:.85rem}.time-input-clear-btn:hover{color:var(--text-primary);background:#ffffff14}.custom-select-container{width:100%;position:relative}.custom-select-trigger{text-align:left;background:var(--bg-primary);border:1px solid var(--card-border);color:var(--text-primary);font-family:var(--font-sans);cursor:pointer;width:100%;transition:var(--transition-fast);-webkit-user-select:none;user-select:none;border-radius:8px;justify-content:space-between;align-items:center;padding:.5rem .75rem;font-size:.85rem;display:flex}.custom-select-trigger:focus,.custom-select-trigger.active{border-color:var(--accent-primary);outline:none;box-shadow:0 0 0 2px #8b5cf633}.custom-select-trigger .chevron-icon{color:var(--accent-primary);transition:transform var(--transition-fast);flex-shrink:0;margin-left:.5rem}.custom-select-trigger.active .chevron-icon{transform:rotate(180deg)}.custom-select-dropdown{z-index:1000;border:1px solid var(--card-border);max-height:250px;box-shadow:var(--shadow-lg), 0 10px 30px #0009;-webkit-backdrop-filter:blur(15px);background:#0d0b17fa;border-radius:8px;padding:.25rem 0;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto}.custom-select-dropdown::-webkit-scrollbar{width:6px}.custom-select-dropdown::-webkit-scrollbar-track{background:0 0}.custom-select-dropdown::-webkit-scrollbar-thumb{background:#8b5cf640;border-radius:3px}.custom-select-dropdown::-webkit-scrollbar-thumb:hover{background:#8b5cf673}.custom-select-option{cursor:pointer;color:var(--text-secondary);-webkit-user-select:none;user-select:none;align-items:center;gap:.4rem;padding:.55rem .75rem;font-size:.82rem;transition:all .15s;display:flex}.custom-select-option:hover{color:var(--text-primary);background:#8b5cf61f}.custom-select-option.selected{color:var(--accent-primary);background:#8b5cf640;font-weight:600}.custom-select-option .col-letter{color:var(--accent-primary);font-family:var(--font-mono);font-size:.75rem;font-weight:700}.custom-select-option .col-text{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.option-switch{border-bottom:1px dashed var(--card-border);justify-content:space-between;align-items:center;padding:.65rem 0;display:flex}.option-switch:last-child{border-bottom:none}.option-info{flex-direction:column;gap:.15rem;padding-right:1rem;display:flex}.option-title{font-size:.85rem;font-weight:500}.option-desc{color:var(--text-muted);font-size:.75rem}.switch-container{flex-shrink:0;width:40px;height:22px;display:inline-block;position:relative}.switch-container input{opacity:0;width:0;height:0}.switch-slider{cursor:pointer;border:1px solid var(--card-border);background-color:#ffffff1a;border-radius:34px;transition:all .3s;position:absolute;inset:0}.switch-slider:before{content:"";background-color:var(--text-secondary);border-radius:50%;width:14px;height:14px;transition:all .3s;position:absolute;bottom:3px;left:3px}input:checked+.switch-slider{background-color:var(--accent-primary)}input:checked+.switch-slider:before{background-color:#fff;transform:translate(18px)}.file-bar{border:1px solid var(--card-border);background:#ffffff05;border-radius:12px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:.75rem 1.25rem;display:flex}.file-info{align-items:center;gap:.75rem;display:flex}.file-info-icon{color:var(--accent-primary)}.file-details h4{color:var(--text-primary);font-size:.95rem;font-weight:600}.file-details p{color:var(--text-secondary);font-size:.75rem}.results-area{flex-direction:column;gap:1.5rem;display:flex}.tab-nav{border-bottom:1px solid var(--card-border);gap:.5rem;padding-bottom:.25rem;display:flex}.tab-btn{color:var(--text-secondary);font-family:var(--font-sans);cursor:pointer;transition:var(--transition-fast);background:0 0;border:none;padding:.5rem 1rem;font-size:.95rem;font-weight:500;position:relative}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--accent-primary);font-weight:600}.tab-btn.active:after{content:"";background:linear-gradient(to right, var(--accent-primary), var(--accent-secondary));border-radius:2px;height:2px;position:absolute;bottom:-.25rem;left:0;right:0}.output-section{flex-direction:column;gap:1.5rem;display:flex}.group-container{border:1px solid var(--card-border);background:#ffffff03;border-radius:12px;flex-direction:column;gap:.75rem;padding:1.25rem;display:flex}.group-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.group-date{font-family:var(--font-sans);color:#e9d5ff;background:#a855f71a;border:1px solid #a855f733;border-radius:6px;padding:.25rem .75rem;font-size:1.05rem;font-weight:600}.code-wrapper{background:#060913;border:1px solid #ffffff0d;border-radius:8px;position:relative;overflow-x:auto}.code-block{font-family:var(--font-mono);color:#38bdf8;white-space:pre;width:max-content;min-width:100%;min-height:50px;padding:1rem;font-size:.8rem;line-height:1.6}.copy-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;align-items:center;gap:.35rem;padding:.4rem .75rem;font-size:.75rem;display:inline-flex}.copy-btn:hover{color:#fff;background:#ffffff1a;border-color:#fff3}.copy-btn.copied{color:var(--accent-success);background:#10b98126;border-color:#10b9814d}.preview-table-container{border:1px solid var(--card-border);background:#080c16;border-radius:10px;overflow-x:auto}.preview-table{border-collapse:collapse;text-align:left;width:100%;font-size:.85rem}.preview-table th{border-bottom:1px solid var(--card-border);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;background:#ffffff05;padding:.75rem 1rem;font-size:.8rem;font-weight:600}.preview-table td.spacer-col,.preview-table th.spacer-col{background:0 0;border-left:2px dashed #ffffff0f;border-right:2px dashed #ffffff0f;width:20px;min-width:20px;max-width:20px;padding:0}.spacer-item{opacity:.85;border-style:dashed}.spacer-remove-btn{color:#f87171;cursor:pointer;transition:var(--transition-fast);background:#ef44441a;border:1px solid #ef444433;border-radius:4px;justify-content:center;align-items:center;padding:.15rem;display:inline-flex}.spacer-remove-btn:hover{color:#fca5a5;background:#ef444433}.add-spacer-btn{justify-content:center;width:100%;margin-top:.75rem}.preview-table td{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid #ffffff0a;max-width:250px;padding:.75rem 1rem;overflow:hidden}.preview-table tr:last-child td{border-bottom:none}.preview-table tr:hover td{color:#fff;background:#ffffff03}.preview-link{color:var(--accent-secondary);text-decoration:none}.preview-link:hover{color:#818cf8;text-decoration:underline}.role-badge{color:var(--text-primary);background:#ffffff0d;border-radius:4px;padding:.1rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.role-badge.has-hours{color:#a5b4fc;background:#6366f126;border:1px solid #6366f14d}.global-actions{justify-content:flex-end;gap:.75rem;margin-bottom:.5rem;display:flex}.active-roles-summary{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.role-chip{border:1px solid var(--card-border);color:var(--text-secondary);background:#ffffff08;border-radius:6px;align-items:center;gap:.35rem;padding:.25rem .6rem;font-size:.75rem;display:flex}.role-chip.active{color:#34d399;background:#10b98114;border-color:#10b9814d}.role-chip.inactive{opacity:.5;text-decoration:line-through}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;max-width:500px;margin:0 auto;padding:4rem 2rem;display:flex}.empty-state-icon{border:1px solid var(--card-border);width:80px;height:80px;color:var(--text-muted);background:#ffffff05;border-radius:50%;justify-content:center;align-items:center;display:flex}.empty-state h2{color:var(--text-primary);font-size:1.5rem;font-weight:600}.empty-state p{color:var(--text-secondary);font-size:.95rem}.toast{border:1px solid var(--accent-success);box-shadow:0 10px 25px -5px #00000080, var(--shadow-glow);color:#fff;z-index:1000;background:#0d1527;border-radius:10px;align-items:center;gap:.75rem;padding:.85rem 1.5rem;font-size:.9rem;animation:.3s cubic-bezier(.16,1,.3,1) forwards slideIn;display:flex;position:fixed;bottom:2rem;right:2rem}@keyframes slideIn{0%{opacity:0;transform:translateY(100px)scale(.9)}to{opacity:1;transform:translateY(0)scale(1)}}.helper-text{color:var(--text-muted);margin-top:.25rem;font-size:.75rem;line-height:1.4}.text-danger{color:var(--accent-danger)}.text-success{color:var(--accent-success)}.text-warning{color:var(--accent-warning)}.instructions-card{flex-direction:column;gap:.75rem;margin-top:1rem;display:flex}.instruction-step{gap:.75rem;font-size:.85rem;display:flex}.step-num{color:#c084fc;background:#8b5cf626;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.75rem;font-weight:600;display:flex}.step-text{color:var(--text-secondary)}.loading-spinner{border:3px solid #ffffff0d;border-top:3px solid var(--accent-primary);border-radius:50%;width:24px;height:24px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.flex{display:flex!important}.flex-col{flex-direction:column!important}.items-center{align-items:center!important}.justify-between{justify-content:space-between!important}.justify-center{justify-content:center!important}.flex-wrap{flex-wrap:wrap!important}.flex-shrink-0{flex-shrink:0!important}.gap-1{gap:.25rem!important}.gap-2{gap:.5rem!important}.gap-3{gap:.75rem!important}.gap-4{gap:1rem!important}.gap-6{gap:1.5rem!important}.w-full{width:100%!important}.max-w-sm{max-width:384px!important}.max-w-2xl{max-width:672px!important}.max-w-3xl{max-width:768px!important}.mx-auto{margin-left:auto!important;margin-right:auto!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:.75rem!important}.mb-4{margin-bottom:1rem!important}.mb-6{margin-bottom:1.5rem!important}.mt-2{margin-top:.5rem!important}.p-3{padding:.75rem!important}.p-4{padding:1rem!important}.py-6{padding-top:1.5rem!important;padding-bottom:1.5rem!important}.rounded-xl{border-radius:12px!important}.text-xs{font-size:.75rem!important}.text-sm{font-size:.875rem!important}.text-base{font-size:1rem!important}.text-lg{font-size:1.125rem!important}.text-xl{font-size:1.25rem!important}.text-2xl{font-size:1.5rem!important}.font-mono{font-family:var(--font-mono)!important}.font-semibold{font-weight:600!important}.font-bold{font-weight:700!important}.tracking-tight{letter-spacing:-.025em!important}.tracking-wide{letter-spacing:.025em!important}.leading-relaxed{line-height:1.625!important}
