*,:before,:after{box-sizing:border-box}body{color:#1a1a2e;background:#f0f2f5;min-height:100vh;margin:0;font-family:Inter,system-ui,sans-serif}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1a1a1a;background:#f8f8f8;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif}.app{background:linear-gradient(#f8f8f8 0%,#f0f0f0 100%);flex-direction:column;align-items:center;min-height:100vh;padding:3rem 1.5rem 4rem;display:flex}.app-header{text-align:center;border-bottom:3px solid #000;width:100%;max-width:920px;margin-bottom:2.5rem;padding-bottom:1.5rem}.app-header h1{color:#1a1a1a;letter-spacing:-.02em;margin:0 0 .75rem;font-size:2.25rem;font-weight:700}.subtitle{color:#666;letter-spacing:.01em;margin:0;font-size:.95rem;font-weight:400}.card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;flex-direction:column;gap:2.5rem;width:100%;max-width:920px;padding:3rem 3.5rem;display:flex;box-shadow:0 4px 20px #00000014,0 1px 4px #0000000f}.step{flex-direction:column;gap:.75rem;display:flex}.step-label{text-transform:uppercase;letter-spacing:.08em;color:#666;margin-bottom:.5rem;font-size:.8rem;font-weight:600}.drop-zone{cursor:pointer;color:#666;background:#fafafa;border:2px dashed #d0d0d0;border-radius:10px;flex-direction:column;align-items:center;gap:1rem;padding:3rem;font-size:.95rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex}.drop-zone:hover{color:#000;background:#fff;border-color:#000;transform:translateY(-2px);box-shadow:0 4px 12px #0000000f}.drop-icon{color:#999;stroke-width:1.5px;width:48px;height:48px;transition:color .2s}.drop-zone:hover .drop-icon{color:#000}.brand-select{color:#1a1a1a;cursor:pointer;appearance:none;letter-spacing:-.01em;background-color:#0000;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23666666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"),linear-gradient(#fff 0%,#fafafa 100%);background-position:right 1.25rem center,0 0;background-repeat:no-repeat,repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;border:2px solid #e0e0e0;border-radius:10px;min-height:56px;padding:1rem 3.5rem 1rem 1.5rem;font-family:inherit;font-size:1.05rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000000a,0 1px 2px #0000000f}.brand-select:hover{background-color:#0000;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23000000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"),linear-gradient(#fafafa 0%,#f5f5f5 100%);background-position:right 1.25rem center,0 0;background-repeat:no-repeat,repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;border-color:#1a1a1a;transform:translateY(-1px);box-shadow:0 4px 12px #00000014,0 2px 4px #0000000f}.brand-select:focus{background:#fff;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23000000' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"), #fff;background-position:right 1.25rem center,0 0;background-repeat:no-repeat,repeat;border-color:#000;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #00000014,0 4px 12px #0000001f}.brand-select:disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5;border-color:#e0e0e0}.brand-select option{color:#1a1a1a;background:#fff;padding:.75rem;font-weight:500}.reporting-period{color:#1a1a1a;background:#f8f8f8;border:1px solid #e0e0e0;border-radius:8px;align-items:center;gap:.75rem;padding:.85rem 1.25rem;font-size:.9rem;font-weight:500;display:flex}.reporting-period__icon{opacity:.6;flex-shrink:0;font-size:1.25rem}.generate-btn{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#000;border:none;border-radius:8px;align-self:flex-start;padding:1rem 2.5rem;font-family:inherit;font-size:.95rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00000026,0 1px 3px #0000001a}.generate-btn:hover:not(:disabled){background:#1a1a1a;transform:translateY(-2px);box-shadow:0 4px 12px #0003,0 2px 4px #0000001f}.generate-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #00000026}.generate-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.alert{border-left:4px solid;border-radius:8px;align-items:center;gap:.5rem;padding:1rem 1.5rem;font-size:.9rem;font-weight:500;display:flex}.alert-success{color:#166534;background:#f0f9f4;border-color:#22c55e}.alert-error{color:#991b1b;background:#fef2f2;border-color:#ef4444}.preview{border-top:2px solid #e0e0e0;flex-direction:column;gap:1.5rem;margin-top:1rem;padding-top:2.5rem;display:flex}.preview-title{color:#1a1a1a;letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:700}.metrics-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem;display:grid}.metric-card{background:#fff;border:1px solid #e8e8e8;border-radius:10px;flex-direction:column;gap:.75rem;padding:1.5rem;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;box-shadow:0 1px 3px #0000000a}.metric-card:hover{border-color:#000;transform:translateY(-4px);box-shadow:0 8px 24px #0000001f,0 4px 8px #00000014}.metric-label{text-transform:uppercase;letter-spacing:.1em;color:#888;font-size:.7rem;font-weight:600}.metric-value{color:#1a1a1a;letter-spacing:-.02em;font-size:1.65rem;font-weight:700}.meta-row{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.meta-tag{color:#fff;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;background:#000;border-radius:6px;padding:.5rem 1.25rem;font-size:.75rem;font-weight:600}.tabs{background:#f0f0f0;border-radius:10px;gap:.5rem;width:100%;max-width:920px;margin-bottom:2rem;padding:.5rem;display:flex}.tab{color:#666;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:0 0;border:none;border-radius:7px;flex:1;padding:.85rem 2rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.tab:hover{color:#1a1a1a;background:#fff9}.tab--active{color:#fff;background:#000;box-shadow:0 2px 8px #00000026}.brands-manager{flex-direction:column;gap:1.25rem;display:flex}.brands-manager__toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.brands-manager__title{color:#1a1a1a;letter-spacing:-.02em;margin:0;font-size:1.5rem;font-weight:700}.brands-manager__actions{gap:.75rem;display:flex}.btn-add{color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#000;border:none;border-radius:8px;padding:.75rem 1.75rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px #00000026}.btn-add:hover{background:#1a1a1a;transform:translateY(-2px);box-shadow:0 4px 10px #0003}.btn-download{color:#1a1a1a;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#fff;border:1.5px solid #d0d0d0;border-radius:8px;padding:.75rem 1.75rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-download:hover{color:#fff;background:#000;border-color:#000;box-shadow:0 2px 6px #00000026}.table-wrapper{border:1px solid #e0e0e0;border-radius:10px;overflow-x:auto;box-shadow:0 2px 8px #0000000d}.brands-table{border-collapse:collapse;width:100%;font-size:.9rem}.brands-table th{color:#fff;text-transform:uppercase;letter-spacing:.1em;text-align:left;white-space:nowrap;background:#1a1a1a;border-bottom:none;padding:1rem 1.25rem;font-size:.7rem;font-weight:600}.brands-table td{vertical-align:middle;color:#1a1a1a;background:#fff;border-bottom:1px solid #f0f0f0;height:52px;padding:0 1.25rem}.brands-table tr:last-child td{border-bottom:none}.brands-table tr:hover td{background:#fafafa}.editable-cell{cursor:pointer;min-width:120px;font-weight:500}.editable-cell.editing{padding:0 .5rem}.cell-input{box-sizing:border-box;background:#fff;border:1.5px solid #000;border-radius:6px;outline:none;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.9rem;font-weight:500}.cell-text{display:block}.cell-empty{color:#ccc;font-style:italic}.col-del{text-align:center;width:40px;padding:0 .5rem!important}.btn-delete{color:#666;cursor:pointer;background:#fff;border:1.5px solid #e0e0e0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.2rem;font-weight:700;line-height:1;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-delete:hover{color:#dc2626;background:#fee;border-color:#ef4444;transform:scale(1.05)}.table-empty{text-align:center;color:#999;font-size:.9rem;font-style:italic;font-weight:400;padding:2.5rem!important}.brands-manager__hint{color:#666;margin:0;font-size:.8rem;font-weight:500}.brands-manager__hint kbd{color:#fff;background:#1a1a1a;border-radius:4px;padding:.2em .6em;font-family:Courier New,monospace;font-size:.75rem;font-weight:600;box-shadow:0 1px 2px #0000001a}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:100;background:#0009;justify-content:center;align-items:center;animation:.2s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border:1px solid #e0e0e0;border-radius:12px;width:90%;max-width:450px;padding:2.5rem 3rem;animation:.2s slide-up;box-shadow:0 20px 60px #0000004d,0 8px 24px #00000026}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-message{color:#1a1a1a;margin:0 0 2rem;font-size:1rem;font-weight:500;line-height:1.6}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.modal-btn{cursor:pointer;text-transform:uppercase;letter-spacing:.05em;border:none;border-radius:8px;padding:.75rem 1.75rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.modal-btn--cancel{color:#666;background:#f0f0f0}.modal-btn--cancel:hover{color:#1a1a1a;background:#e0e0e0}.modal-btn--confirm{color:#fff;background:#000;box-shadow:0 2px 6px #0003}.modal-btn--confirm:hover{background:#1a1a1a;transform:translateY(-1px);box-shadow:0 4px 10px #00000040}.brands-manager__left{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.save-status{border:1px solid;border-radius:6px;padding:.35rem 1rem;font-size:.8rem;font-weight:600}.save-status--saving{color:#854d0e;background:#fef9c3;border-color:#fbbf24}.save-status--saved{color:#065f46;background:#d1fae5;border-color:#10b981}.save-status--error{color:#991b1b;background:#fee2e2;border-color:#ef4444}.btn-open-file{color:#1a1a1a;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;background:#fff;border:1.5px solid #d0d0d0;border-radius:8px;padding:.75rem 1.5rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-open-file:hover{color:#fff;background:#000;border-color:#000}.file-notice{color:#854d0e;background:#fef9c3;border:1px solid #fbbf24;border-radius:8px;padding:1rem 1.5rem;font-size:.85rem;font-weight:500}.file-notice code{background:#fde047;border-radius:4px;padding:.2em .5em;font-family:Courier New,monospace;font-size:.82rem;font-weight:600}.quick-generate{flex-direction:column;gap:2rem;display:flex}.month-input{color:#1a1a1a;cursor:pointer;letter-spacing:-.01em;background:linear-gradient(#fff 0%,#fafafa 100%);border:2px solid #e0e0e0;border-radius:10px;width:100%;max-width:300px;min-height:56px;padding:1rem 1.5rem;font-family:inherit;font-size:1.05rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 4px #0000000a,0 1px 2px #0000000f}.month-input:hover{background:linear-gradient(#fafafa 0%,#f5f5f5 100%);border-color:#1a1a1a;transform:translateY(-1px);box-shadow:0 4px 12px #00000014,0 2px 4px #0000000f}.month-input:focus{background:#fff;border-color:#000;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #00000014,0 4px 12px #0000001f}.unmatched-brands-notice{background:#fafafa;border-left:3px solid #1a1a1a;border-radius:6px;margin-top:1rem;padding:1.25rem 1.5rem}.notice-content{flex-direction:column;gap:.75rem;display:flex}.notice-label{color:#1a1a1a;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;font-weight:600}.notice-brands{flex-wrap:wrap;gap:.5rem;display:flex}.notice-brand{color:#1a1a1a;letter-spacing:-.01em;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:.4rem .9rem;font-size:.85rem;font-weight:500;display:inline-block;box-shadow:0 1px 2px #0000000a}.notice-hint{color:#666;font-size:.8rem;font-style:italic;font-weight:400}.login-container{background:linear-gradient(#f8f8f8 0%,#f0f0f0 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.login-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;width:100%;max-width:420px;padding:3rem;box-shadow:0 4px 20px #00000014,0 1px 4px #0000000f}.login-header{text-align:center;border-bottom:3px solid #000;margin-bottom:2rem;padding-bottom:1.5rem}.login-header h1{color:#1a1a1a;letter-spacing:-.02em;margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.login-subtitle{color:#666;margin:0;font-size:.9rem;font-weight:400}.login-form{flex-direction:column;gap:1.25rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-label{text-transform:uppercase;letter-spacing:.08em;color:#666;font-size:.8rem;font-weight:600}.form-input{color:#1a1a1a;background:#fafafa;border:2px solid #e0e0e0;border-radius:8px;padding:.85rem 1rem;font-family:inherit;font-size:.95rem;transition:all .2s}.form-input:focus{background:#fff;border-color:#000;outline:none;box-shadow:0 0 0 3px #00000014}.form-input::placeholder{color:#999}.login-footer{text-align:center;border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:1.5rem}.login-footer p{color:#999;margin:0;font-size:.8rem}.logout-btn{cursor:pointer!important;color:#666!important;background:0 0!important;border:1px solid #e0e0e0!important;border-radius:6px!important;padding:.5rem 1rem!important;font-size:.85rem!important;font-weight:500!important;transition:all .2s!important}.logout-btn:hover{color:#000!important;background:#f5f5f5!important;border-color:#000!important}
