@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#ee4d2d;--primary-hover:#d74226;--primary-light:#fff0eb;--bg-color:#f8fafc;--surface:#fff;--border:#e2e8f0;--text-primary:#0f172a;--text-secondary:#64748b;--text-tertiary:#94a3b8;--success:#10b981;--success-bg:#ecfdf5;--info:#3b82f6;--info-bg:#eff6ff;--warning:#f59e0b;--warning-bg:#fffbeb;--danger:#ef4444;--danger-bg:#fef2f2;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--radius-sm:.375rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.5rem}[data-theme=dark]{--primary-light:#3f1911;--bg-color:#0f172a;--surface:#1e293b;--border:#334155;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-tertiary:#64748b;--success-bg:#064e3b;--info-bg:#1e3a8a;--warning-bg:#78350f;--danger-bg:#7f1d1d;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 4px 6px -1px #00000080, 0 2px 4px -2px #00000080;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #00000080}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5}.app-container{max-width:1400px;min-height:100vh;margin:0 auto;padding:2rem}.card{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:1.5rem;transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:var(--shadow-md)}.card-header{align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;display:flex}.hero-section{flex-direction:column;gap:1.5rem;margin-bottom:2rem;display:flex}@media (width>=768px){.hero-section{flex-direction:row;justify-content:space-between;align-items:center}}.logo-area{align-items:center;gap:1rem;display:flex}.logo-icon{background-color:var(--primary-light);width:3rem;height:3rem;color:var(--primary);border-radius:var(--radius-md);justify-content:center;align-items:center;display:flex}.page-title{letter-spacing:-.025em;font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:.875rem}.btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-size:.95rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 14px #ee4d2d63}.btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 20px #ee4d2d3b}.filter-bar{background-color:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;padding:1.5rem;display:grid}.filter-group{flex-direction:column;gap:.5rem;display:flex}.filter-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.75rem;font-weight:600}.filter-input{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);background-color:var(--bg-color);outline:none;padding:.625rem;font-size:.875rem;transition:border-color .2s}.filter-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.kpi-card{align-items:center;gap:1.25rem;display:flex}.kpi-icon-wrapper{border-radius:50%;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;display:flex}.kpi-icon-wrapper.komisi{background-color:var(--success-bg);color:var(--success)}.kpi-icon-wrapper.gmv{background-color:var(--info-bg);color:var(--info)}.kpi-icon-wrapper.pesanan{background-color:var(--primary-light);color:var(--primary)}.kpi-icon-wrapper.rasio{color:#a855f7;background-color:#f3e8ff}.kpi-content{flex-direction:column;display:flex}.kpi-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.kpi-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.charts-grid{grid-template-columns:1fr;gap:1.5rem;margin-bottom:2rem;display:grid}@media (width>=1024px){.charts-grid.col-2{grid-template-columns:2fr 1fr}.charts-grid.col-1-1{grid-template-columns:1fr 1fr}}.chart-container{width:100%;height:350px}.table-container{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%;font-size:.875rem}.data-table th{background-color:var(--bg-color);color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;padding:1rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:1rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:var(--bg-color)}.status-badge{border-radius:999px;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:600;display:inline-flex}.status-Selesai{background-color:var(--success-bg);color:var(--success)}.status-Tertunda{background-color:var(--warning-bg);color:var(--warning)}.status-Batal{background-color:var(--danger-bg);color:var(--danger)}.status-Default{background-color:var(--bg-color);color:var(--text-secondary)}.truncate{white-space:nowrap;text-overflow:ellipsis;max-width:250px;overflow:hidden}.empty-state{text-align:center;background-color:var(--surface);border-radius:var(--radius-xl);border:1px dashed var(--border);color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:5rem 2rem;display:flex}.empty-icon{width:4rem;height:4rem;color:var(--border);margin-bottom:1rem}.empty-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem;font-weight:600}.hide{display:none}.tooltip-custom{background-color:var(--surface);box-shadow:var(--shadow-md);border:1px solid var(--border);border-radius:8px;padding:12px}.tooltip-title{color:var(--text-primary);margin-bottom:4px;font-weight:600}.tooltip-value{color:var(--primary);font-weight:600}.tooltip-secondary{color:var(--text-secondary);margin-top:4px;font-size:12px}.tabs-container{border-bottom:2px solid var(--border);gap:1rem;margin-bottom:2rem;padding-bottom:.5rem;display:flex}.tab-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;font-size:1rem;font-weight:600;transition:color .2s;position:relative}.tab-btn:hover,.tab-btn.active{color:var(--primary)}.tab-btn.active:after{content:"";background-color:var(--primary);border-radius:3px 3px 0 0;height:3px;position:absolute;bottom:-.65rem;left:0;right:0}.master-detail-layout{grid-template-columns:1fr;gap:1.5rem;display:grid}@media (width>=1024px){.master-detail-layout{grid-template-columns:350px 1fr}}.selection-list{flex-direction:column;gap:.5rem;max-height:450px;padding-right:.5rem;display:flex;overflow-y:auto}.selection-item{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;justify-content:space-between;align-items:center;padding:1rem;transition:all .2s;display:flex}.selection-item:hover{border-color:var(--primary-light);background-color:var(--bg-color)}.selection-item.active{border-color:var(--primary);background-color:var(--primary-light);box-shadow:0 0 0 1px var(--primary)}.selection-info{flex-direction:column;width:70%;display:flex}.selection-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.25rem;font-weight:600;overflow:hidden}.selection-subtitle{color:var(--text-secondary);font-size:.75rem}.selection-metric{text-align:right;width:30%}.selection-value{color:var(--primary);font-size:.9rem;font-weight:700}.detail-panel{flex-direction:column;gap:1.5rem;display:flex}.search-box{border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-color);width:100%;color:var(--text-primary);outline:none;margin-bottom:1rem;padding:.75rem}.search-box:focus{border-color:var(--primary)}.auth-screen{background:radial-gradient(1200px 600px at 10% -10%, var(--primary-light), transparent 60%), radial-gradient(1000px 500px at 110% 110%, var(--primary-light), transparent 60%), var(--bg-color);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:2rem}.auth-header{text-align:center;margin-bottom:1.5rem}.auth-logo{background:var(--primary-light);width:64px;height:64px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto .75rem;display:flex}.auth-title{color:var(--text-primary);font-size:1.4rem;font-weight:700}.auth-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.9rem}.auth-form{flex-direction:column;gap:.4rem;display:flex}.auth-label{color:var(--text-secondary);align-items:center;gap:.4rem;margin-top:.6rem;font-size:.8rem;font-weight:600;display:inline-flex}.auth-input{border:1px solid var(--border);border-radius:var(--radius-md);background-color:var(--bg-color);width:100%;color:var(--text-primary);outline:none;padding:.7rem .9rem;font-size:.95rem;transition:border-color .15s,box-shadow .15s}.auth-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.auth-input-wrap{position:relative}.auth-eye{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;border-radius:6px;padding:6px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.auth-eye:hover{color:var(--text-primary);background:var(--bg-color)}.auth-submit{justify-content:center;width:100%;margin-top:1rem;padding:.8rem 1rem}.auth-alert{border-radius:var(--radius-md);border:1px solid #0000;align-items:center;gap:.5rem;margin-top:.5rem;padding:.6rem .8rem;font-size:.85rem;display:flex}.auth-alert-error{background:var(--danger-bg);color:var(--danger);border-color:var(--danger)}.auth-alert-warn{background:var(--warning-bg);color:var(--warning);border-color:var(--warning)}.auth-alert-info{background:var(--success-bg);color:var(--success);border-color:var(--success)}.auth-hint{color:var(--text-tertiary);text-align:center;margin-top:.6rem;font-size:.8rem}.auth-footer{text-align:center;color:var(--text-tertiary);margin-top:1.25rem;font-size:.75rem}.auth-strength{margin:.4rem 0 .2rem}.auth-strength-bar{background:var(--border);border-radius:4px;width:100%;height:6px;overflow:hidden}.auth-strength-label{margin-top:.3rem;font-size:.75rem;font-weight:600}.auth-strength-issues{color:var(--text-tertiary);margin-top:.15rem;font-size:.7rem}.auth-topbar{z-index:50;position:fixed;top:14px;right:18px}.auth-usermenu{position:relative}.auth-userbtn{background:var(--surface);border:1px solid var(--border);color:var(--text-primary);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .8rem;font-size:.85rem;font-weight:600;display:inline-flex}.auth-userbtn:hover{border-color:var(--primary);color:var(--primary)}.auth-userdrop{border:1px solid var(--border);border-radius:var(--radius-md);min-width:200px;box-shadow:var(--shadow-md);flex-direction:column;padding:.4rem;display:flex;position:absolute;top:calc(100% + 6px);right:0}.auth-userdrop-item{border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:.5rem;padding:.55rem .7rem;font-size:.85rem;display:flex}.auth-userdrop-item:hover{background:var(--bg-color)}.auth-userdrop-item.danger{color:var(--danger)}.auth-userdrop-item.danger:hover{background:var(--danger-bg)}.auth-modal-backdrop{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.auth-modal{border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;max-width:440px;box-shadow:var(--shadow-lg);padding:1.5rem}.auth-modal-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.auth-modal-header h3{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.05rem;display:inline-flex}.auth-modal-close{cursor:pointer;color:var(--text-tertiary);background:0 0;border:none;border-radius:6px;padding:6px}.auth-modal-close:hover{color:var(--text-primary);background:var(--bg-color)}.auth-idle-warn{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning);z-index:60;border-radius:999px;padding:.5rem .9rem;font-size:.85rem;position:fixed;bottom:16px;left:50%;transform:translate(-50%)}.mode-toggle{background-color:var(--bg-color);border:1px solid var(--border);border-radius:999px;align-items:center;gap:2px;padding:4px;display:inline-flex;position:relative}.mode-toggle-btn{cursor:pointer;color:var(--text-secondary);white-space:nowrap;background:0 0;border:none;border-radius:999px;align-items:center;gap:.35rem;padding:.35rem .9rem;font-size:.8rem;font-weight:600;transition:all .25s;display:flex}.mode-toggle-btn.active{background-color:var(--primary);color:#fff;box-shadow:0 2px 8px #ee4d2d59}.mode-toggle-btn.active.pro-mode{background:linear-gradient(135deg,#7c3aed,#5b21b6);box-shadow:0 2px 8px #7c3aed66}.pro-badge{color:#fff;letter-spacing:.05em;vertical-align:middle;background:linear-gradient(135deg,#7c3aed,#5b21b6);border-radius:4px;align-items:center;margin-left:.2rem;padding:.1rem .4rem;font-size:.6rem;font-weight:800;display:inline-flex}.pro-upload-section{border-radius:var(--radius-lg);background:linear-gradient(135deg,#7c3aed0d,#3b82f60d);border:1px solid #7c3aed33;margin-bottom:2rem;padding:1.5rem;transition:padding .3s}.pro-upload-section.collapsed{padding-bottom:1.25rem}.pro-upload-header{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:var(--radius-md);justify-content:space-between;align-items:center;margin:-.25rem;padding:.25rem;transition:background-color .2s;display:flex}.pro-upload-header:hover{background-color:#7c3aed0f}.pro-upload-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:.25rem;font-size:1rem;font-weight:700;display:flex}.pro-upload-count{color:#7c3aed;letter-spacing:.02em;background:#7c3aed1f;border-radius:999px;align-items:center;margin-left:.25rem;padding:.1rem .5rem;font-size:.65rem;font-weight:700;display:inline-flex}.pro-upload-chevron{color:var(--text-tertiary);flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1)}.pro-upload-chevron.rotated{transform:rotate(-90deg)}.pro-upload-body{opacity:1;grid-template-rows:1fr;transition:grid-template-rows .35s cubic-bezier(.4,0,.2,1),opacity .3s;display:grid}.pro-upload-body>.pro-upload-grid{overflow:hidden}.pro-upload-body.hidden{opacity:0;grid-template-rows:0fr}.pro-upload-subtitle{color:var(--text-secondary);margin-bottom:0;font-size:.8rem;transition:margin-bottom .3s}.pro-upload-section:not(.collapsed) .pro-upload-subtitle{margin-bottom:0}.pro-upload-body:not(.hidden){margin-top:1.25rem}.pro-upload-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (width>=768px){.pro-upload-grid{grid-template-columns:repeat(3,1fr)}}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius-md);text-align:center;cursor:pointer;background-color:var(--surface);padding:1.25rem;transition:all .25s;position:relative;overflow:hidden}.upload-zone:hover{border-color:var(--primary);background-color:var(--primary-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.upload-zone.uploaded{border-color:var(--success);background-color:var(--success-bg);border-style:solid}.upload-zone.uploaded-pro{background-color:#7c3aed12;border-style:solid;border-color:#7c3aed}.upload-zone-icon{background-color:var(--primary-light);width:2.5rem;height:2.5rem;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto .75rem;transition:all .25s;display:flex}.upload-zone.uploaded .upload-zone-icon{background-color:var(--success-bg);color:var(--success)}.upload-zone.uploaded-pro .upload-zone-icon{color:#7c3aed;background-color:#7c3aed26}.upload-zone-label{color:var(--text-primary);margin-bottom:.25rem;font-size:.8rem;font-weight:700}.upload-zone-hint{color:var(--text-secondary);font-size:.7rem}.upload-zone-filename{color:var(--success);white-space:nowrap;text-overflow:ellipsis;margin-top:.4rem;font-size:.7rem;font-weight:600;overflow:hidden}.upload-zone.uploaded-pro .upload-zone-filename{color:#7c3aed}.upload-zone-clickable{cursor:pointer}.upload-zone-merge-info{color:#7c3aed;background:#7c3aed1a;border-radius:999px;align-items:center;gap:.35rem;margin-top:.5rem;padding:.2rem .6rem;font-size:.68rem;font-weight:600;display:inline-flex}.fb-merge-toggle{border-top:1px dashed var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;gap:.5rem;margin-top:.85rem;padding-top:.75rem;transition:opacity .2s;display:flex}.fb-merge-toggle:hover{opacity:.85}.fb-merge-checkbox{accent-color:#7c3aed;cursor:pointer;border-radius:3px;flex-shrink:0;width:1rem;height:1rem}.fb-merge-label{color:var(--text-secondary);font-size:.7rem;font-weight:600;transition:color .2s}.fb-merge-toggle:hover .fb-merge-label,.fb-merge-checkbox:checked+.fb-merge-label{color:#7c3aed}.roas-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.roas-kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:.25rem;padding:1rem 1.25rem;display:flex}.roas-kpi-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.7rem;font-weight:600}.roas-kpi-value{color:var(--text-primary);font-size:1.35rem;font-weight:700}.roas-kpi-value.good{color:var(--success)}.roas-kpi-value.bad{color:var(--danger)}.roas-table-wrapper{border-radius:var(--radius-md);border:1px solid var(--border);overflow-x:auto}.roas-table{border-collapse:collapse;text-align:left;width:100%;min-width:950px;font-size:.85rem}.roas-table th{background-color:var(--bg-color);color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em;padding:.85rem 1rem;font-size:.75rem;font-weight:600}.roas-table td{border-bottom:1px solid var(--border);color:var(--text-primary);white-space:nowrap;padding:.9rem 1rem}.roas-table tr:last-child td{border-bottom:none}.roas-row-good{background:#10b9810f}.roas-row-good:hover{background:#10b9811f}.roas-row-bad{background:#ef44440d}.roas-row-bad:hover{background:#ef44441a}.roas-row-neutral{background:0 0}.roas-row-neutral:hover{background-color:var(--bg-color)}.roas-badge{border-radius:999px;align-items:center;gap:.3rem;padding:.25rem .65rem;font-size:.8rem;font-weight:700;display:inline-flex}.roas-badge-good{color:#059669;background:#10b98126;border:1px solid #10b9814d}.roas-badge-bad{color:#dc2626;background:#ef44441f;border:1px solid #ef444440}.roas-badge-neutral{background:var(--bg-color);color:var(--text-secondary);border:1px solid var(--border)}.roas-value-good{color:#059669;font-weight:700}.roas-value-bad{color:#dc2626;font-weight:700}.ad-name-cell{color:var(--text-primary);text-overflow:ellipsis;max-width:200px;font-weight:600;overflow:hidden}.click-comparison{align-items:center;gap:.5rem;font-size:.8rem;display:flex}.click-rate{color:var(--text-tertiary);font-size:.7rem}.pro-empty{text-align:center;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3rem 2rem;display:flex}.pro-empty-icon{color:#7c3aed;background:linear-gradient(135deg,#7c3aed1a,#3b82f61a);border-radius:50%;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;display:flex}.mode-indicator-strip{border-radius:var(--radius-sm);align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem;font-size:.75rem;font-weight:600;display:flex}.mode-indicator-strip.pro{color:#7c3aed;background:linear-gradient(135deg,#7c3aed1a,#3b82f614);border:1px solid #7c3aed33}
