@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";:root{--brand-primary: #e7000b;--brand-primary-hover: #cf000a;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #030213;--success-bg: #d1fae5;--success-border: #6ee7b7;--success-text: #059669;--warning-bg: #fef3c7;--warning-border: #fcd34d;--warning-text: #f59e0b;--error-bg: #fff1f2;--error-border: #fecdd3;--error-text: #e11d48;--info-bg: #dbeafe;--info-border: #93c5fd;--info-text: #2563eb;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--card-shadow: 0 1px 2px rgba(0, 0, 0, .05);--et-red: var(--brand-primary);--et-header-bg: var(--slate-900);--et-header: #030213;--et-border: var(--slate-200);--et-muted: var(--slate-500);--et-muted-text: var(--slate-500);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 12px;--radius-xl: 16px;--et-radius-sm: 6px;--et-radius-md: 10px;--et-radius-lg: 12px}*{box-sizing:border-box}html,body{max-width:100vw;overflow-x:hidden}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;line-height:1.5;color:var(--slate-500);background:linear-gradient(to bottom right,#f8fafc,#fff,#fee2e24d)}h1,h2,h3,h4,strong{color:var(--slate-900)}h1{font-size:32px;font-weight:600;line-height:1.2;margin:0}h2{font-size:24px;font-weight:600;line-height:1.3;margin:0}h3{font-size:16px;font-weight:500;line-height:1.4;margin:0}small,.text-small{font-size:14px}.page{max-width:1440px;margin:0 auto;padding:var(--space-5);padding-top:calc(var(--space-5) + 72px);padding-bottom:88px}.card{background:#fff;border:1px solid var(--slate-200);border-radius:16px;box-shadow:var(--card-shadow);padding:var(--space-6);margin-bottom:var(--space-4)}.section-title{margin:0 0 var(--space-3)}.field-note{color:var(--slate-500);font-size:14px;line-height:1.5}.muted{color:var(--slate-400)}label,.login-label{display:block;margin-bottom:var(--space-2);font-size:14px;font-weight:500;color:var(--slate-900)}input,select,textarea,button{font-family:inherit}input,select,textarea{width:100%;border:1px solid var(--slate-300);border-radius:8px;min-height:40px;padding:12px 16px;background:#fff;color:var(--slate-900);font-size:15px}input:focus,select:focus,textarea:focus{border:2px solid var(--brand-primary);outline:2px solid rgba(231,0,11,.2);outline-offset:2px}input:disabled,select:disabled,textarea:disabled{background:var(--slate-50);color:var(--slate-400);cursor:not-allowed}button{border:0;border-radius:10px;padding:10px 24px;min-height:40px;background:var(--brand-primary);color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease-in-out}button:hover:not(:disabled){background:var(--brand-primary-hover)}button:disabled{opacity:.6;cursor:not-allowed}.button-full{width:100%}.btn-ghost{background:transparent;border:1px solid var(--slate-300);color:var(--slate-500)}.btn-ghost:hover:not(:disabled){background:var(--slate-50)}.btn-sm{font-size:12px;padding:4px 12px}.btn-edit{font-size:12px;padding:4px 10px;background:var(--info-text);color:#fff}.btn-edit:hover:not(:disabled){background:var(--info-text);opacity:.9}.btn-delete{font-size:12px;padding:4px 10px;background:var(--error-text);color:#fff}.btn-delete:hover:not(:disabled){background:var(--error-text);opacity:.9}.btn-success-sm{font-size:12px;padding:4px 10px;background:var(--success-text);color:#fff}.btn-success-sm:hover:not(:disabled){background:var(--success-text);opacity:.9}.app-header{position:fixed;top:0;left:0;right:0;z-index:40;background:var(--slate-900);color:#fff;border-bottom:1px solid rgba(255,255,255,.1);padding:var(--space-4) var(--space-5);display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.app-header__nav{display:flex;gap:var(--space-1);position:absolute;left:50%;transform:translate(-50%)}.app-header__nav-item{padding:var(--space-2) var(--space-4);color:#fff9;text-decoration:none;font-size:.875rem;font-weight:500;border-radius:6px;transition:all .15s}.app-header__nav-item:hover{color:#fff;background:#ffffff14}.app-header__nav-item.active{color:#fff;background:#ffffff1f}.app-header__brand{display:flex;align-items:center;gap:var(--space-4);min-width:0;flex-shrink:1}.app-header__logo{width:auto;height:32px}.app-header__subtitle{color:#ffffffc2;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__title{color:#fff;font-size:24px;font-weight:600;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header__user{display:flex;align-items:center;gap:var(--space-4)}.app-header__user-identity{display:flex;flex-direction:column;text-align:right}.app-header__user-name{font-size:15px;font-weight:600;color:#fff}.app-header__company-name{font-size:13px;color:#ffffffb3;margin-top:1px}.app-header__user-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.app-header__role-badge{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px;background:#ffffff26;color:#ffffffe6;padding:2px 8px;border-radius:10px}.app-header__code-badge{font-size:11px;color:#ffffff80}.table-toolbar{margin-bottom:var(--space-3)}.table-wrap{overflow-x:auto;overflow-y:auto;border:1px solid var(--slate-200);border-radius:16px;max-width:100%;-webkit-overflow-scrolling:touch}.product-brand{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--brand-primary);margin-right:6px}.product-category{font-size:11px;color:var(--slate-400);margin-top:1px}.table{width:100%;min-width:900px;border-collapse:separate;border-spacing:0;font-size:14px}.table th,.table td{border-bottom:1px solid var(--slate-200);padding:var(--space-2);vertical-align:middle;background:#fff}.table th{position:sticky;top:0;z-index:3;background:var(--slate-50);text-align:left;color:var(--slate-900);font-size:14px;font-weight:500}.table tbody tr:hover td{background:var(--slate-50)}.forecast-table thead th{z-index:7;background:var(--slate-50);font-size:12px;font-weight:600;min-height:32px;height:32px;padding:6px 8px;line-height:1.2}.sort-btn{all:unset;cursor:pointer;color:var(--slate-900);font-weight:500}.forecast-table td{font-variant-numeric:tabular-nums;padding:8px;vertical-align:middle}.forecast-table th.month-col{text-align:center;min-width:130px;width:130px}.month-totals-row th{font-size:12px;font-weight:600;color:var(--brand-primary);border-bottom:2px solid var(--slate-200)}.forecast-table td.month-cell{text-align:center;vertical-align:middle;padding:var(--space-2);position:relative}.forecast-table .sticky-col{position:sticky;left:0;z-index:4;min-width:220px;background:#fff;box-shadow:2px 0 4px #0000000a}.forecast-table .sticky-col-2{position:sticky;left:220px;z-index:4;min-width:108px;background:#fff}.forecast-table thead .sticky-col,.forecast-table thead .sticky-col-2{z-index:6;background:var(--slate-50)}.quantity-input{width:96px;border:1.5px solid var(--slate-200);border-radius:8px;padding:8px 6px;font-size:14px;text-align:center;background:var(--slate-50);transition:border-color .15s,box-shadow .15s;display:inline-block;font-variant-numeric:tabular-nums}.quantity-input::placeholder{color:var(--slate-300)}.quantity-input:focus{outline:2px solid var(--brand-primary, #e7000b);outline-offset:-1px;border-color:var(--brand-primary, #e7000b);box-shadow:0 0 0 3px #e7000b26}.quantity-input.qty-valid{border-color:var(--success-border);background:var(--success-bg)}.quantity-input.qty-valid:focus{box-shadow:0 0 0 3px #6ee7b733}.quantity-input.qty-invalid{border-color:var(--warning-border);background:var(--warning-bg)}.quantity-input.qty-invalid:focus{box-shadow:0 0 0 3px #fcd34d33}.quantity-input.qty-locked{border-color:var(--slate-300);background:var(--slate-100);color:var(--slate-400);cursor:not-allowed}.qty-hint{font-size:11px;margin-top:2px;color:var(--warning-text);font-weight:500}.badges{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-2) 0}.badge{border-radius:24px;padding:6px 12px;font-size:12px;font-weight:500;border:1px solid var(--slate-300);background:var(--slate-50);color:var(--slate-500)}.badge-success{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}.badge-warning{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}.badge-danger{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.badge-info{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}.amount-inline{margin-top:var(--space-1);color:var(--slate-500);font-size:12px}.partner-meta{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.summary-stats{display:flex;gap:var(--space-3);flex-wrap:wrap}.summary-stat{min-width:184px;background:var(--slate-50);border:1px solid var(--slate-200);border-radius:16px;box-shadow:var(--card-shadow);padding:var(--space-3);display:flex;flex-direction:column}.summary-stat span{font-size:14px;color:var(--slate-500)}.summary-stat strong{font-size:24px;font-weight:600;line-height:1.3;margin-top:var(--space-1)}.login-page{min-height:100vh;display:grid;place-items:center;padding:var(--space-5);background:linear-gradient(to bottom right,#f8fafc,#fff,#fee2e24d)}.login-card{width:min(520px,100%);background:#fff;border:1px solid var(--slate-200);border-radius:16px;box-shadow:var(--card-shadow);padding:var(--space-8)}.login-logo{width:auto;height:36px}.login-card h1{margin-top:var(--space-4)}.login-intro{margin:var(--space-2) 0 var(--space-6);color:var(--slate-500)}.login-section{margin-top:var(--space-5)}.login-status{margin:var(--space-3) 0 0;color:var(--success-text);font-size:14px}.login-verify{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px dashed var(--slate-300)}.dev-link{margin-top:var(--space-3);background:transparent;color:var(--brand-primary);text-decoration:underline;padding:0;min-height:auto;border-radius:0}.skeleton{height:16px;border-radius:8px;background:linear-gradient(90deg,var(--slate-100),var(--slate-200),var(--slate-100));animation:pulse 1.2s infinite}.skeleton+.skeleton{margin-top:var(--space-2)}@keyframes pulse{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}.empty-state{border:1px dashed var(--slate-300);border-radius:16px;background:var(--slate-50);padding:var(--space-6);text-align:center;color:var(--slate-500);font-size:14px}.toast-stack{position:fixed;top:var(--space-4);right:var(--space-4);z-index:999;display:flex;flex-direction:column;gap:var(--space-2)}.toast{color:#fff;font-size:14px;padding:10px 16px;border-radius:12px;background:var(--slate-900);box-shadow:0 6px 20px #0f172a33}.toast-success{background:var(--success-text)}.toast-error{background:var(--error-text)}.toast-info{background:var(--info-text)}.row-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.welcome-banner{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,var(--slate-900) 0%,var(--slate-800) 100%);color:#fff;border-radius:16px;padding:var(--space-5) var(--space-6);margin-bottom:var(--space-4)}.welcome-banner h2{color:#fff;font-size:22px;margin:0 0 4px}.welcome-banner p{color:#ffffffb3;font-size:14px;margin:0}.welcome-banner__progress{display:flex;align-items:center;gap:var(--space-4)}.progress-ring{position:relative;width:56px;height:56px}.progress-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.progress-ring__bg{fill:none;stroke:#ffffff26;stroke-width:3}.progress-ring__fill{fill:none;stroke:var(--brand-primary);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .6s ease}.progress-ring__label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#fff}.progress-detail{display:flex;flex-direction:column;text-align:right}.progress-detail strong{color:#fff;font-size:16px}.progress-detail span{font-size:12px;color:#fff9}.division-tabs{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);overflow-x:auto;padding-bottom:var(--space-1)}.division-tab{padding:8px 16px;border-radius:10px;font-size:14px;font-weight:500;border:1px solid var(--slate-200);background:#fff;color:var(--slate-500);cursor:pointer;white-space:nowrap;transition:all .15s}.division-tab:hover{border-color:var(--slate-300);color:var(--slate-700)}.division-tab.active{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff;border-radius:9999px}.summary-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-4);flex-wrap:wrap}.summary-bar .summary-stat{flex:1;min-width:140px;background:#fff;border:1px solid var(--slate-200);border-radius:12px;padding:var(--space-3) var(--space-4);display:flex;flex-direction:column;gap:2px}.summary-bar .summary-stat span{font-size:12px;color:var(--slate-500);text-transform:uppercase;letter-spacing:.3px}.summary-bar .summary-stat strong{font-size:20px;color:var(--slate-900)}.filter-bar{display:flex;gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:nowrap;align-items:center}.filter-search{flex:1;min-width:200px;padding:8px 12px 8px 36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:10px center;background-color:#fff;border:1px solid var(--slate-200);border-radius:10px;font-size:14px;transition:border-color .15s}.filter-search:focus{outline:none;border-color:var(--brand-primary);box-shadow:0 0 0 3px #e7000b14}.filter-select{padding:8px 12px;border:1px solid var(--slate-200);border-radius:10px;font-size:14px;background:#fff;color:var(--slate-700);cursor:pointer;min-width:140px}.filter-select:focus{outline:none;border-color:var(--brand-primary)}.filter-clear{font-size:13px;color:var(--brand-primary);padding:8px 12px}.brand-group{margin-bottom:var(--space-3);min-width:0;max-width:100%;overflow:hidden}.brand-header{display:flex;align-items:center;padding:var(--space-3) var(--space-4);background:#fff;border:1px solid var(--slate-200);border-radius:12px;cursor:pointer;transition:background .15s,box-shadow .15s;-webkit-user-select:none;user-select:none;gap:var(--space-3)}.brand-header:hover{background:var(--slate-50);box-shadow:var(--card-shadow);transition:background .15s ease,box-shadow .15s ease}.brand-header__left{display:flex;align-items:center;gap:var(--space-2);min-width:240px;max-width:240px;flex-shrink:0;overflow:hidden}.brand-header__chevron{font-size:16px;color:var(--slate-400);width:16px}.brand-header__name{font-size:15px;font-weight:600;color:var(--slate-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.brand-header__count{font-size:11px;color:var(--slate-400);background:var(--slate-100);padding:1px 6px;white-space:nowrap;border-radius:8px}.brand-header__right{display:flex;align-items:center;gap:var(--space-3);min-width:90px;justify-content:flex-end;flex-shrink:0}.brand-header__total{font-size:14px;font-weight:600;color:var(--success-text);white-space:nowrap}.brand-header__completion{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--success-text);font-weight:500}.completion-bar{width:48px;height:4px;background:var(--slate-200);border-radius:2px;overflow:hidden}.completion-bar__fill{height:100%;background:var(--success-text);border-radius:2px;transition:width .3s ease}.mobile-price{display:none}.brand-table-wrap{margin-top:var(--space-2)}.brand-group .table-wrap{border-top-left-radius:0;border-top-right-radius:0;max-height:60vh}.mcq-col{text-align:center;width:56px;min-width:56px;font-size:13px;color:var(--slate-400);vertical-align:middle}.row-has-forecast{background:#d1fae526!important}.row-has-forecast:hover{background:#d1fae54d!important}.forecast-table tbody tr:hover{background:var(--slate-50)}.forecast-table tbody tr:nth-child(2n) td{background:#f8fafc80}.forecast-table tbody tr:nth-child(2n) .sticky-col,.forecast-table tbody tr:nth-child(2n) .sticky-col-2{background:#f8fafc}.forecast-table tbody tr:hover .sticky-col,.forecast-table tbody tr:hover .sticky-col-2{background:var(--slate-50)}.month-cell{text-align:center}.total-col{text-align:right;min-width:130px;padding:var(--space-3) var(--space-5, 20px);position:sticky;right:0;background:#fff!important;z-index:4;border-left:2px solid var(--slate-200);box-shadow:-4px 0 8px #0000000a;font-variant-numeric:tabular-nums}.forecast-table thead .total-col{background:var(--slate-50)!important;z-index:6}.forecast-table tbody tr:nth-child(2n) .total-col{background:#fafafa!important}.row-total strong{font-size:14px;color:var(--slate-900)}.row-total__qty{display:block;font-size:11px;color:var(--slate-400)}.stat-highlight{color:var(--success-text)!important}.submit-bar{background:#fff;border:0;padding:var(--space-3) var(--space-5);display:flex;justify-content:space-between;align-items:center;position:fixed;bottom:0;left:0;right:0;z-index:50;border-radius:0;box-shadow:0 -4px 24px #0000001f;border-top:1px solid var(--slate-200)}.submit-bar__left{display:flex;flex-direction:column;gap:2px}.submit-bar__total{font-size:22px;font-weight:700;color:var(--slate-900)}.submit-bar__lines{font-size:13px;color:var(--slate-500)}.submit-bar__actions{display:flex;align-items:center;gap:var(--space-3)}.btn-primary{background:var(--brand-primary);color:#fff;border:none;padding:10px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--brand-primary-hover)}.btn-primary:disabled{background:var(--slate-100, #f1f5f9);color:var(--slate-400, #94a3b8);border:1px solid var(--slate-200, #e2e8f0);cursor:not-allowed;opacity:1}.brand-table-wrap{position:relative}.brand-table-wrap .table-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;width:32px;pointer-events:none;background:linear-gradient(to left,rgba(0,0,0,.06),transparent);border-radius:0 16px 16px 0;z-index:5}.swipe-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#1e293bd9;color:#fff;padding:8px 18px;border-radius:20px;font-size:13px;font-weight:500;z-index:10;pointer-events:none;animation:swipeHintFade 3s ease-out forwards;white-space:nowrap}@keyframes swipeHintFade{0%{opacity:1}70%{opacity:1}to{opacity:0}}@media (max-width: 900px){.page{padding-top:var(--space-5);max-width:100vw;overflow-x:hidden}.app-header{position:relative;flex-direction:column;align-items:flex-start;padding:var(--space-2) var(--space-3);overflow:hidden;max-width:100vw}.card,.brand-card,.brand-group,.upload-dropzone,.welcome-banner,.summary-bar{max-width:100%;min-width:0;box-sizing:border-box}.upload-dropzone{padding:var(--space-5) var(--space-4)}.lock-timeline-row,.brand-month-totals{display:none}.overall-totals-grid{grid-template-columns:repeat(4,1fr);gap:4px}.app-header__nav{position:static;transform:none;flex-wrap:nowrap;gap:2px;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}.app-header__nav::-webkit-scrollbar{display:none}.app-header__nav-item{font-size:.78rem;padding:var(--space-1) var(--space-2);white-space:nowrap;flex-shrink:0}.app-header__user{width:100%;justify-content:space-between}.app-header__user-meta{text-align:left}.filter-bar{flex-wrap:wrap}.filter-search{min-width:100%}.filter-select{flex:1;min-width:120px}.welcome-banner{flex-direction:column;gap:var(--space-4)}.welcome-banner.collapsed{display:none}.summary-bar{display:grid;grid-template-columns:1fr 1fr;gap:8px}.submit-bar{position:fixed;bottom:0;left:0;right:0;border-radius:0;flex-direction:row;gap:var(--space-3);text-align:left;z-index:50;background:#fff;box-shadow:0 -4px 24px #0000001f;padding:var(--space-2) var(--space-3) calc(var(--space-2) + env(safe-area-inset-bottom));border-top:1px solid var(--slate-200)}.submit-bar__total{font-size:16px}.submit-bar__lines{font-size:11px}.submit-bar__actions .btn-primary{padding:8px 16px;font-size:13px}.page{padding-bottom:88px}.forecast-table .sticky-col{min-width:160px}.forecast-table .sticky-col strong{display:block;font-size:13px;line-height:1.3;word-break:break-word}.forecast-table .sticky-col .field-note{font-size:11px}.forecast-table .sticky-col-2{display:none}.forecast-table .sticky-col .mobile-price{display:block;font-size:11px;color:var(--success-text);font-weight:600}}@media (max-width: 640px){.app-header__subtitle{display:block;white-space:normal;overflow:visible;text-overflow:unset}.app-header__title{font-size:16px;white-space:normal;overflow:visible;text-overflow:unset}.app-header__brand{gap:var(--space-2)}.app-header__logo{height:24px}.app-header__top,.app-header__meta,.app-header__actions{display:flex;flex-wrap:wrap;gap:8px}.partner-name,.partner-id,.header-title,.app-header__user-name{white-space:normal;overflow:visible;text-overflow:unset;max-width:100%}.upload-dropzone{padding:var(--space-4) var(--space-3)}.upload-dropzone p{overflow-wrap:anywhere;word-break:break-word}}@media (min-width: 901px){.page{padding-bottom:88px}}.upload-dropzone{border:2px dashed var(--slate-300);border-radius:12px;padding:var(--space-8) var(--space-6);text-align:center;cursor:pointer;transition:all .15s;background:var(--slate-50);max-width:100%;box-sizing:border-box}.upload-dropzone:hover,.upload-dropzone.dragover{border-color:var(--brand-primary);background:#e7000b08}.upload-dropzone__icon{font-size:32px;margin-bottom:var(--space-3)}.upload-dropzone p{margin:4px 0;color:var(--slate-500)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.modal-dialog{background:#fff;border-radius:16px;padding:var(--space-8);max-width:520px;width:100%;text-align:center;box-shadow:0 25px 50px -12px #00000040;animation:modalIn .2s ease-out}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-icon{font-size:3rem;margin-bottom:var(--space-3)}.modal-title{font-size:1.35rem;font-weight:700;color:var(--slate-900);margin-bottom:var(--space-4)}.modal-body{font-size:1rem;color:var(--slate-700);line-height:1.6;margin-bottom:var(--space-3)}.modal-note{font-size:.9rem;color:var(--slate-500);line-height:1.6;margin-bottom:var(--space-3)}.modal-actions{display:flex;gap:var(--space-3);justify-content:center;margin-top:var(--space-5)}.modal-actions .btn-primary{padding:var(--space-3) var(--space-6);font-size:1rem}.modal-actions .btn-ghost{padding:var(--space-3) var(--space-5);font-size:.9rem;color:var(--slate-500)}.lock-col-locked{background-color:var(--slate-200)}.lock-col-locked-cell{background-color:var(--slate-100)}.lock-col-locked-header{background-color:var(--slate-200);color:var(--slate-500)}.lock-col-partial-header{background-color:var(--warning-bg)}.lock-col-locked-input{color:var(--slate-400)}.lock-pct-label{font-size:.65em;color:var(--slate-400);font-weight:400}.brand-subtotal-row{background-color:var(--slate-50);font-size:.8rem;color:var(--slate-500);border-top:1px solid var(--slate-200)}.brand-subtotal-row td{font-weight:600}.month-dollar{font-size:.75rem;color:var(--slate-500);font-weight:400;margin-top:2px}.btn-danger{background:var(--brand-primary);color:#fff;border:none;padding:4px 10px;border-radius:10px;cursor:pointer;font-size:12px}.btn-danger:hover:not(:disabled){background:var(--brand-primary-hover)}.callout-success{background-color:var(--success-bg);border:1px solid var(--success-border);padding:12px 16px}.callout-success p{color:var(--success-text)}@media (max-width: 480px){.page{padding:var(--space-2) var(--space-3);padding-bottom:90px;width:100%;max-width:100%;min-width:0;overflow-x:hidden}.card,.brand-group,.brand-header,.table-wrap,.upload-dropzone,.login-card,.empty-state,.empty-state-card,.overall-totals-card{width:100%;max-width:100%;min-width:0;box-sizing:border-box}.card,.brand-group,.brand-header,.login-card,.empty-state,.empty-state-card{overflow-x:hidden}.app-header{padding:10px 12px;overflow:visible;max-width:100%}.app-header__title,.app-header__subtitle,.app-header__user-name,.app-header__company-name,.app-header__role-badge,.app-header__code-badge{white-space:normal;overflow:visible;text-overflow:unset;max-width:100%}.app-header__title{font-size:14px;line-height:1.2}.app-header__nav{flex-wrap:wrap;overflow:visible;gap:8px}.app-header__nav-item{font-size:.72rem;padding:4px 8px}.app-header__user{width:100%;flex-wrap:wrap;align-items:flex-start;gap:8px}.summary-bar,.summary-stats{display:grid;grid-template-columns:1fr;gap:10px}.card{padding:var(--space-3)}.forecast-table .sticky-col{min-width:140px}.quantity-input{width:70px;font-size:13px}.forecast-table thead th{font-size:12px;font-weight:600;min-height:32px;height:32px;padding:6px 8px;line-height:1.2}.forecast-table tbody td{padding:8px;vertical-align:middle}.submit-bar{min-height:56px;padding:6px 10px calc(6px + env(safe-area-inset-bottom));box-shadow:0 -2px 8px #0206170f}.submit-bar .btn-primary,.submit-bar__actions .btn-primary{min-height:36px;padding:6px 12px;font-size:13px}.overall-totals-grid{grid-template-columns:repeat(4,1fr);gap:4px}.overall-totals-card{padding:12px}.brand-month-totals{grid-template-columns:repeat(4,1fr);gap:2px}.brand-month-totals__cell{font-size:10px}.brand-month-totals__label{font-size:9px}.lock-timeline-row{display:none}.filter-bar{display:grid!important;grid-template-columns:1fr;gap:8px}.filter-bar .filter-search{grid-column:1 / -1}.brand-group{border-radius:12px}.brand-header{padding:10px 12px}.brand-header__left{min-width:0;max-width:100%;flex:1}.brand-header__name{font-size:14px;line-height:1.2;max-width:44vw}.brand-header__count{font-size:10px;padding:1px 5px}}.btn-ghost{border-radius:10px}.baseline-label{font-size:10px;color:var(--slate-400);text-align:center;margin-top:1px;line-height:1;white-space:nowrap}.lock-timeline-row{border:none}.lock-timeline-row th{border:none!important;font-weight:400}.lock-timeline-cell{border-radius:4px;transition:background-color .2s}.submit-warnings{background:var(--warning-bg);border:1px solid var(--warning-border);border-radius:10px;padding:12px 16px;margin:16px 0;text-align:left}.submit-warnings__header{font-weight:600;font-size:.9rem;color:var(--warning-text);margin-bottom:8px}.submit-warnings__list{font-size:.8rem;color:var(--slate-700);margin:0;padding-left:20px;max-height:150px;overflow-y:auto}.submit-warnings__list li{margin-bottom:4px;line-height:1.4}.submit-warnings__note{font-size:.75rem;color:var(--slate-400);margin-top:8px;font-style:italic}.brand-sparkline{display:flex;align-items:flex-end;gap:2px;height:24px;padding:0 12px;flex-shrink:0}.brand-sparkline__bar{width:6px;min-height:2px;border-radius:2px 2px 0 0;transition:height .3s ease}.brand-sparkline__bar:hover{opacity:.7}.brand-month-totals{display:grid;grid-template-columns:repeat(12,1fr);gap:0;flex:1;min-width:0}.brand-month-totals__cell{display:flex;flex-direction:column;align-items:center;padding:2px 4px;font-size:11px;line-height:1.3}.brand-month-totals__label{color:var(--slate-400);font-size:10px;text-transform:uppercase}.brand-month-totals__value{font-weight:600;color:var(--slate-700);white-space:nowrap}.status-badge{display:inline-block;padding:2px 10px;border-radius:9999px;font-size:.75rem;font-weight:600}.status-badge--confirmed,.status-badge--submitted{background:var(--success-bg);color:var(--success-text)}.status-badge--pending{background:var(--warning-bg);color:var(--warning-text)}.empty-state-card{text-align:center;padding:48px 24px}.empty-state-card__icon{font-size:3rem;margin-bottom:12px}.empty-state-card__title{font-size:1.1rem;font-weight:600;color:var(--slate-700);margin-bottom:8px}.empty-state-card__desc{font-size:.9rem;color:var(--slate-400);max-width:360px;margin:0 auto;line-height:1.5}.breadcrumbs{font-size:.8rem;color:var(--slate-400);margin-bottom:12px}.breadcrumbs__sep{margin:0 6px;color:var(--slate-300)}.breadcrumbs__link{color:var(--slate-500);text-decoration:none}.breadcrumbs__link:hover{color:var(--brand-primary)}.breadcrumbs__current{color:var(--slate-700);font-weight:500}.undo-hint{font-size:.75rem;color:var(--slate-400);font-style:italic}.deadline-label{font-size:.6rem;color:var(--brand-primary);font-weight:600;white-space:nowrap;animation:deadline-pulse 2s ease-in-out infinite}@keyframes deadline-pulse{0%,to{opacity:1}50%{opacity:.5}}.welcome-step{margin-bottom:16px;padding-left:0}.welcome-step p{font-size:.85rem;color:var(--slate-400);margin:4px 0 0}.welcome-modal{max-width:520px;border-radius:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0003}.submit-success-card{text-align:center;padding:48px 24px;background:var(--success-bg);border:1px solid var(--success-border);border-radius:16px;margin-bottom:24px}.submit-success-card__icon{font-size:3rem;margin-bottom:12px}.submit-success-card h3{color:var(--success-text);margin-bottom:8px}.submit-success-card p{color:var(--slate-500);margin-bottom:24px}.submit-success-card__actions{display:flex;gap:12px;justify-content:center}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:16px 0}.pagination__btn{padding:6px 16px;border-radius:8px;border:1px solid var(--slate-200);background:#fff;cursor:pointer;font-size:.85rem}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pagination__info{font-size:.85rem;color:var(--slate-500)}.overall-totals-card{margin-bottom:16px;padding:16px 20px;overflow-x:auto}.overall-totals-title{font-size:.85rem;font-weight:600;color:var(--slate-500);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.overall-totals-grid{display:grid;grid-template-columns:repeat(13,1fr);gap:0;padding-bottom:4px}.overall-totals-cell{text-align:center;padding:8px 4px;border-radius:8px;background:var(--slate-50)}.overall-totals-cell--grand{background:var(--brand-primary);color:#fff;min-width:90px}.overall-totals-cell__month{font-size:.7rem;font-weight:600;color:var(--slate-400);margin-bottom:4px;text-transform:uppercase}.overall-totals-cell--grand .overall-totals-cell__month{color:#ffffffb3}.overall-totals-cell__qty{font-size:.9rem;font-weight:700;color:var(--slate-800)}.overall-totals-cell--grand .overall-totals-cell__qty{color:#fff}.overall-totals-cell__dollar{font-size:.7rem;color:var(--success-text);margin-top:2px}.overall-totals-cell--grand .overall-totals-cell__dollar{color:#ffffffd9}.mobile-month-pager{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--slate-50);border:1px solid var(--slate-200);border-radius:10px;margin-bottom:8px}.mobile-month-pager__label{font-size:14px;font-weight:600;color:var(--slate-700);display:flex;flex-direction:column;align-items:center;gap:2px}.mobile-month-pager__count{font-size:11px;font-weight:400;color:var(--slate-400)}.mobile-month-pager .btn-ghost{padding:6px 12px;font-size:13px;min-width:70px}@media (max-width: 767px){.forecast-table .month-cell{min-width:80px}.forecast-table .quantity-input{width:100%;min-width:60px;height:36px;font-size:15px;text-align:center}.forecast-table .sticky-col{min-width:120px;max-width:140px}.forecast-table .total-col{min-width:80px}}
