.pfy-wrap{min-height:calc(100vh - 140px);background:#07070f;border-radius:16px;overflow:hidden;position:relative}.pfy-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 50%,rgba(139,92,246,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(59,130,246,.06) 0%,transparent 50%);pointer-events:none;z-index:0}.pfy-command-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 140px);padding:40px 20px;position:relative;z-index:1}.pfy-header-logo{display:flex;flex-direction:row;align-items:center;gap:10px;margin-bottom:8px}.pfy-logo-icon{font-size:28px;color:#8b5cf6;text-shadow:0 0 20px rgba(139,92,246,.8),0 0 40px rgba(139,92,246,.4)}.pfy-logo-text{font-size:20px;font-weight:900;letter-spacing:.15em;color:#e2e8f0}.pfy-logo-ai{color:#8b5cf6}.pfy-tagline{font-size:14px;color:#94a3b8b3;letter-spacing:.08em;margin-bottom:48px}.pfy-command-wrap{max-width:680px;width:90%}.pfy-command-label{font-size:10px;letter-spacing:.2em;color:#8b5cf6;margin-bottom:8px;text-transform:uppercase}.pfy-command-input-wrap{position:relative}.pfy-command-input{width:100%;min-height:100px;padding:20px 120px 20px 20px;background:#ffffff08;border:1px solid rgba(139,92,246,.3);border-radius:12px;color:#e2e8f0;font-size:16px;line-height:1.6;resize:none;outline:none;transition:all .3s;font-family:inherit;box-sizing:border-box}.pfy-command-input::placeholder{color:#94a3b859}.pfy-command-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 1px #8b5cf6,0 0 40px #8b5cf633}.pfy-submit-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#8b5cf6,#3b82f6);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:700;font-size:13px;cursor:pointer;letter-spacing:.05em;box-shadow:0 0 20px #8b5cf666;transition:box-shadow .2s;white-space:nowrap}.pfy-submit-btn:hover{box-shadow:0 0 30px #8b5cf699}.pfy-command-examples{margin-top:20px;display:flex;flex-direction:column;gap:8px}.pfy-example{font-size:12px;color:#94a3b880;cursor:pointer;padding:6px 10px;border:1px solid rgba(255,255,255,.05);border-radius:6px;transition:color .2s,border-color .2s;background:transparent;text-align:left}.pfy-example:hover{color:#94a3b8cc;border-color:#8b5cf64d}.pfy-workflow{padding:24px;position:relative;z-index:1;display:flex;flex-direction:column;gap:20px}.pfy-steps{display:flex;gap:0;align-items:center;justify-content:center}.pfy-step{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;flex:1;max-width:140px}.pfy-step:not(:last-child):after{content:"";position:absolute;top:16px;left:50%;width:100%;height:1px;background:#ffffff14}.pfy-step-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);font-size:12px;color:#94a3b880;z-index:1;transition:all .3s}.pfy-step.active .pfy-step-dot{background:#8b5cf633;border-color:#8b5cf6;color:#8b5cf6;box-shadow:0 0 16px #8b5cf666}.pfy-step.done .pfy-step-dot{background:#10b98133;border-color:#10b981;color:#10b981}.pfy-step-label{font-size:10px;letter-spacing:.1em;color:#94a3b880;text-align:center;white-space:nowrap}.pfy-step.active .pfy-step-label{color:#8b5cf6}.pfy-step.done .pfy-step-label{color:#10b981}.pfy-split{display:grid;grid-template-columns:55fr 45fr;gap:16px;height:calc(100vh - 260px);min-height:500px}.pfy-chat-panel{background:#ffffff08;border:1px solid rgba(139,92,246,.15);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.pfy-chat-header{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.06);font-size:12px;letter-spacing:.1em;color:#94a3b8b3;display:flex;gap:8px;align-items:center;text-transform:uppercase;flex-shrink:0}.pfy-chat-icon{color:#8b5cf6}.pfy-prompt-echo{padding:12px 20px;background:#8b5cf60d;border-bottom:1px solid rgba(255,255,255,.04);display:flex;gap:10px;align-items:flex-start;flex-shrink:0}.pfy-prompt-label{font-size:9px;letter-spacing:.15em;color:#8b5cf6;padding-top:2px;white-space:nowrap;text-transform:uppercase}.pfy-prompt-text{font-size:13px;color:#e2e8f099;font-style:italic;line-height:1.4}.pfy-chat-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.pfy-chat-messages::-webkit-scrollbar{width:4px}.pfy-chat-messages::-webkit-scrollbar-track{background:transparent}.pfy-chat-messages::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:2px}.pfy-msg{display:flex;gap:10px;align-items:flex-start}.pfy-msg-ai{flex-direction:row}.pfy-msg-user{flex-direction:row-reverse}.pfy-msg-avatar{color:#8b5cf6;font-size:16px;padding-top:2px;flex-shrink:0}.pfy-msg-user .pfy-msg-avatar{color:#3b82f6}.pfy-msg-bubble{max-width:85%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5}.pfy-msg-ai .pfy-msg-bubble{background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);color:#e2e8f0;border-top-left-radius:4px}.pfy-msg-user .pfy-msg-bubble{background:#3b82f626;border:1px solid rgba(59,130,246,.25);color:#e2e8f0;border-top-right-radius:4px}.pfy-answer-area{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);background:#0003;flex-shrink:0}.pfy-text-answer{display:flex;gap:8px;align-items:center}.pfy-input-prefix,.pfy-input-suffix{font-size:13px;color:#8b5cf6;font-weight:700;flex-shrink:0}.pfy-answer-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e2e8f0;padding:8px 12px;font-size:13px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s}.pfy-answer-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 1px #8b5cf64d}.pfy-answer-input::placeholder{color:#94a3b859}.pfy-multi-select{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.pfy-select-chip{padding:6px 12px;border-radius:20px;font-size:12px;cursor:pointer;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);color:#94a3b8b3;transition:all .2s}.pfy-select-chip.selected{background:#8b5cf633;border-color:#8b5cf6;color:#c4b5fd}.pfy-age-range{display:flex;gap:8px;align-items:center}.pfy-age-input{width:72px;text-align:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e2e8f0;padding:8px 12px;font-size:13px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s}.pfy-age-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 1px #8b5cf64d}.pfy-age-dash{color:#94a3b880}.pfy-btn{padding:8px 16px;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;border:none;letter-spacing:.05em;transition:all .2s;font-family:inherit;text-transform:uppercase}.pfy-btn-sm{padding:7px 14px}.pfy-btn-primary{background:linear-gradient(135deg,#8b5cf6,#3b82f6);color:#fff;box-shadow:0 0 20px #8b5cf64d}.pfy-btn-primary:hover{box-shadow:0 0 30px #8b5cf680;transform:translateY(-1px)}.pfy-btn-secondary{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#e2e8f0}.pfy-btn-secondary:hover{background:#ffffff1f}.pfy-btn-ghost{background:transparent;border:1px solid rgba(139,92,246,.3);color:#8b5cf6}.pfy-btn-ghost:hover{background:#8b5cf61a}.pfy-btn-launch{width:100%;padding:16px;font-size:15px;letter-spacing:.1em;background:linear-gradient(135deg,#8b5cf6,#3b82f6);color:#fff;box-shadow:0 0 30px #8b5cf666;border:none;border-radius:8px;cursor:pointer;font-weight:700;font-family:inherit;transition:all .2s;text-transform:uppercase}.pfy-btn-launch:hover{box-shadow:0 0 50px #8b5cf699;transform:translateY(-2px)}.pfy-btn-launch.launching{opacity:.7;cursor:not-allowed;transform:none}.pfy-proceed{padding:16px;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:12px;flex-shrink:0}.pfy-proceed-hint{font-size:12px;color:#94a3b880;text-align:center}.pfy-creative-panel{background:#ffffff05;border:1px solid rgba(59,130,246,.12);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;position:relative;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.pfy-panel-title{padding:14px 20px;font-size:12px;letter-spacing:.12em;color:#94a3b8b3;border-bottom:1px solid rgba(255,255,255,.06);display:flex;justify-content:space-between;align-items:center;text-transform:uppercase;flex-shrink:0}.pfy-panel-hint{color:#8b5cf6b3;font-size:11px;letter-spacing:.05em}.pfy-generating{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:40px}.pfy-gen-orb{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.pfy-gen-ring{position:absolute;border-radius:50%;border:1px solid;animation:pfySpin linear infinite}.pfy-gen-ring.r1{width:120px;height:120px;border-color:#8b5cf666;animation-duration:3s}.pfy-gen-ring.r2{width:90px;height:90px;border-color:#3b82f680;animation-duration:2s;animation-direction:reverse}.pfy-gen-ring.r3{width:60px;height:60px;border-color:#06b6d499;animation-duration:1.5s}.pfy-gen-icon{font-size:24px;color:#8b5cf6;animation:pfyPulse 1.5s ease-in-out infinite;text-shadow:0 0 20px #8b5cf6;z-index:1}.pfy-gen-label{font-size:14px;font-weight:700;letter-spacing:.12em;color:#e2e8f0;text-transform:uppercase;display:flex;align-items:center;gap:8px}.pfy-gen-prompt{font-size:11px;color:#94a3b880;font-style:italic;text-align:center;max-width:280px;line-height:1.5}.pfy-gen-dots{display:flex;gap:6px;align-items:center}.pfy-gen-dots span{width:6px;height:6px;border-radius:50%;background:#8b5cf6;animation:pfyBlink 1.4s infinite;display:block}.pfy-gen-dots span:nth-child(2){animation-delay:.2s}.pfy-gen-dots span:nth-child(3){animation-delay:.4s}@keyframes pfySpin{to{transform:rotate(360deg)}}@keyframes pfyPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.9)}}@keyframes pfyBlink{0%,80%,to{opacity:0}40%{opacity:1}}.pfy-image-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:16px;overflow-y:auto;flex:1}.pfy-image-grid::-webkit-scrollbar{width:4px}.pfy-image-grid::-webkit-scrollbar-track{background:transparent}.pfy-image-grid::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:2px}.pfy-image-grid.small{grid-template-columns:repeat(3,1fr);gap:8px;padding:12px}.pfy-image-card{position:relative;border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:all .2s}.pfy-image-card:hover{border-color:#8b5cf666;transform:scale(1.02);box-shadow:0 0 20px #8b5cf633}.pfy-image-card.selected{border-color:#8b5cf6;box-shadow:0 0 24px #8b5cf666}.pfy-image-card img{width:100%;display:block;aspect-ratio:1;object-fit:cover;background:#ffffff0a}.pfy-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.pfy-image-card:hover .pfy-image-overlay{opacity:1}.pfy-image-card.selected .pfy-image-overlay{opacity:0}.pfy-image-check{width:40px;height:40px;border-radius:50%;background:#8b5cf6cc;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}.pfy-image-selected-badge{position:absolute;top:8px;right:8px;background:#8b5cf6;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase}.pfy-grid-footer{padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);display:flex;justify-content:center;flex-shrink:0}.pfy-copy-editor{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.pfy-copy-editor::-webkit-scrollbar{width:4px}.pfy-copy-editor::-webkit-scrollbar-track{background:transparent}.pfy-copy-editor::-webkit-scrollbar-thumb{background:#06b6d44d;border-radius:2px}.pfy-copy-section{display:flex;flex-direction:column;gap:8px}.pfy-copy-label{font-size:10px;letter-spacing:.15em;color:#8b5cf6;display:flex;gap:10px;align-items:center;text-transform:uppercase}.pfy-copy-hint{color:#94a3b866;font-size:10px;letter-spacing:.05em;font-weight:400;text-transform:none}.pfy-copy-item{padding:10px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;color:#e2e8f0;font-size:13px;line-height:1.5;outline:none;cursor:text;transition:border-color .2s,box-shadow .2s;font-family:inherit}.pfy-copy-item:focus{border-color:#06b6d4;box-shadow:0 0 0 1px #06b6d433}.pfy-copy-item.headline{font-weight:700;font-size:14px}.pfy-launchpad{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.pfy-launchpad::-webkit-scrollbar{width:4px}.pfy-launchpad::-webkit-scrollbar-track{background:transparent}.pfy-launchpad::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:2px}.pfy-launch-title{display:flex;flex-direction:column;gap:4px}.pfy-neon-text{font-size:22px;font-weight:900;letter-spacing:.15em;color:#8b5cf6;text-shadow:0 0 20px rgba(139,92,246,.5)}.pfy-launch-subtitle{font-size:12px;color:#94a3b880;letter-spacing:.1em;text-transform:uppercase}.pfy-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pfy-summary-card{padding:12px 14px;background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:10px}.pfy-summary-label{font-size:10px;letter-spacing:.1em;color:#94a3b880;margin-bottom:4px;text-transform:uppercase}.pfy-summary-value{font-size:13px;color:#e2e8f0;font-weight:600}.pfy-summary-value.neon{color:#8b5cf6}.pfy-summary-copy{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:10px;padding:14px}.pfy-copy-preview-headline{font-size:14px;font-weight:700;color:#e2e8f0;margin-bottom:6px}.pfy-copy-preview-text{font-size:12px;color:#94a3b899;line-height:1.5}.pfy-launch-actions{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:12px}.pfy-schedule-row{display:flex;gap:10px;align-items:center}.pfy-schedule-input{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e2e8f0;padding:8px 12px;font-size:13px;outline:none;font-family:inherit;transition:border-color .2s,box-shadow .2s;color-scheme:dark}.pfy-schedule-input:focus{border-color:#8b5cf6;box-shadow:0 0 0 1px #8b5cf64d}.pfy-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:pfySpin .8s linear infinite;vertical-align:middle}.pfy-success{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;padding:60px;text-align:center;position:relative;z-index:1;min-height:calc(100vh - 140px)}.pfy-success-orb{font-size:60px;text-shadow:0 0 40px rgba(139,92,246,.8);animation:pfyPulse 2s ease-in-out infinite}.pfy-success h2{font-size:32px;font-weight:900;letter-spacing:.1em;margin:0;background:linear-gradient(135deg,#8b5cf6,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pfy-success p{color:#94a3b8b3;font-size:15px;max-width:400px;line-height:1.6}.pfy-error-msg{font-size:11px;color:#f87171;margin-top:4px;letter-spacing:.03em}.pfy-creative-panel>*::-webkit-scrollbar{width:4px}.pfy-launch-error{margin:12px 0;padding:10px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:13px}.pfy-launch-note{text-align:center;font-size:11px;color:#94a3b866;margin-top:8px}.pfy-success-ids{background:#ffffff08;border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:16px;margin:16px 0 24px;width:100%;max-width:480px;text-align:left}.pfy-id-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:12px}.pfy-id-row:last-child{border-bottom:none}.pfy-id-label{color:#94a3b899;font-size:11px;text-transform:uppercase;letter-spacing:.05em}.pfy-id-val{color:#8b5cf6;font-family:monospace;font-size:12px}.pfy-success-actions{display:flex;flex-direction:column;gap:10px;align-items:center}.pfy-quick-form{padding:12px 16px 4px}.pfy-form-campaign-name{font-size:11px;font-family:monospace;color:#8b5cf6;background:#8b5cf614;border:1px solid rgba(139,92,246,.2);border-radius:6px;padding:6px 10px;margin-bottom:14px;letter-spacing:.03em}.pfy-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pfy-form-field{display:flex;flex-direction:column;gap:5px}.pfy-form-field.pfy-full{grid-column:1 / -1}.pfy-form-field label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#94a3b899}.pfy-form-field input,.pfy-form-field select{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:7px;color:#e2e8f0;font-size:13px;padding:7px 10px;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}.pfy-form-field input:focus,.pfy-form-field select:focus{border-color:#8b5cf680}.pfy-form-field select option{background:#1e1b2e;color:#e2e8f0}.pfy-finput{display:flex;align-items:center;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:7px;overflow:hidden}.pfy-finput input{background:transparent;border:none;flex:1;padding:7px 8px}.pfy-finput-pre,.pfy-finput-suf{padding:7px 8px;font-size:12px;color:#94a3b880}.pfy-age-row{display:flex;align-items:center;gap:6px}.pfy-age-row input{width:60px;text-align:center;flex:none}.pfy-age-dash{color:#94a3b866}.pfy-placement-chips{display:flex;flex-wrap:wrap;gap:8px}.pfy-img-card{position:relative;border-radius:10px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .2s,transform .15s;aspect-ratio:1}.pfy-img-card:hover{transform:scale(1.02);border-color:#8b5cf666}.pfy-img-card.selected{border-color:#8b5cf6;box-shadow:0 0 16px #8b5cf666}.pfy-img-card img{width:100%;height:100%;object-fit:cover;display:block}.pfy-img-selected-badge{position:absolute;top:6px;right:6px;background:#8b5cf6;color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:20px}.pfy-gen-more-hint{display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;color:#94a3b866;padding:8px 0}.pfy-launch-preview-img{width:120px;height:120px;border-radius:10px;overflow:hidden;border:2px solid rgba(139,92,246,.3);margin:0 auto 16px}.pfy-launch-preview-img img{width:100%;height:100%;object-fit:cover}:root{--bg: #f9fbff;--surface: #ffffff;--text: #111827;--muted: #6b7280;--primary: #2b6cb0;--accent: #2b897d;--danger: #e53e3e;--border: rgba(203, 213, 224, .65);--radius: 12px}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}.app{max-width:1400px;margin:0 auto;padding:20px 24px 60px;min-height:100vh;background:var(--bg)}.header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:22px;padding:18px 20px;border-radius:16px;background:var(--surface);border:1px solid var(--border);box-shadow:0 10px 20px #0f172a14}.title{font-size:26px;font-weight:900;margin-bottom:2px;color:var(--text)}.subtitle{color:var(--muted);font-size:13px}.tab-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}.tab-btn{background:#2b6cb012;border:1px solid rgba(43,108,176,.22);color:var(--primary);border-radius:10px;font-weight:700;font-size:13px;padding:7px 14px;cursor:pointer;transition:background .15s,color .15s}.tab-btn:hover{background:#2b6cb026}.tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.global-controls{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.time-selector{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.time-selector select{border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px;background:var(--surface);color:var(--text);cursor:pointer;outline:none;transition:border-color .15s}.time-selector select:focus{border-color:var(--primary)}.custom-range{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.custom-range input[type=date]{border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:13px;background:var(--surface);color:var(--text);outline:none}.custom-range input[type=date]:focus{border-color:var(--primary)}.oem-toggle{display:flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;background:var(--surface)}.oem-btn{background:transparent;border:none;border-right:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:600;padding:6px 14px;cursor:pointer;transition:background .15s,color .15s}.oem-btn:last-child{border-right:none}.oem-btn:hover{background:#2b6cb012;color:var(--primary)}.oem-btn.active{background:var(--primary);color:#fff}.kpi-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin:20px 0 22px}.kpi-card{background:var(--surface);border-radius:var(--radius);padding:16px 18px 14px;box-shadow:0 4px 12px #0f172a0f;border:1px solid var(--border);border-top-width:4px;transition:box-shadow .15s}.kpi-card:hover{box-shadow:0 8px 20px #0f172a1a}.kpi-label{color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.kpi-value{font-weight:900;font-size:24px;letter-spacing:-.02em;line-height:1.1}.kpi-sub{font-size:11px;color:var(--muted);margin-top:4px}.insights-section{margin:18px 0}.insight-badge{border-left:4px solid;padding:10px 14px;margin-bottom:8px;border-radius:6px;font-size:13px;line-height:1.5}.charts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}@media (max-width: 1100px){.charts-grid{grid-template-columns:1fr 1fr}}@media (max-width: 720px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--surface);border-radius:var(--radius);padding:16px 18px;border:1px solid var(--border);box-shadow:0 4px 12px #0f172a0f}.chart-title{font-weight:700;font-size:14px;margin-bottom:12px;color:var(--text)}.metrics-table-wrap{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:0 4px 12px #0f172a0d}.table-controls{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border);background:#0f172a05}.table-search{width:220px;border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:13px;outline:none;background:var(--surface);transition:border-color .15s}.table-search:focus{border-color:var(--primary)}.table-scroll{overflow-x:auto}.metrics-table{width:100%;border-collapse:collapse;font-size:13px}.metrics-table thead th{padding:10px 12px;background:#0f172a08;color:var(--text);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}.metrics-table thead th:hover{background:#2b6cb00f}.metrics-table tbody tr{border-bottom:1px solid rgba(15,23,42,.06);transition:background .1s}.metrics-table tbody tr:hover{background:#2b6cb00d}.metrics-table tbody td{padding:10px 12px;color:var(--text)}.row-selected{background:#2b6cb014!important}.totals-row td{font-weight:700;background:#0f172a08;border-top:2px solid var(--border);padding:10px 12px}.name-cell{text-align:left!important;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-notice{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;padding:8px 14px;border-radius:8px;font-size:13px;margin-bottom:12px}.mapping-tab{padding:4px 0}.mapping-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:20px;box-shadow:0 4px 12px #0f172a0d}.form-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.form-row input,.form-row select{border:1px solid var(--border);border-radius:8px;padding:7px 10px;font-size:13px;background:var(--surface);color:var(--text);outline:none;transition:border-color .15s;min-width:140px}.form-row input:focus,.form-row select:focus{border-color:var(--primary)}.form-row input[placeholder*=Display],.form-row input[placeholder*="Entity ID"],.form-row input[placeholder*=Raw]{min-width:200px}.mapping-hint{color:var(--muted);font-size:12px;margin:8px 0 0}.mapping-section{margin-top:22px}.mapping-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--surface);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border)}.mapping-table thead th{padding:9px 12px;background:#0f172a08;font-weight:700;font-size:12px;text-align:left;border-bottom:1px solid var(--border)}.mapping-table tbody td{padding:9px 12px;border-bottom:1px solid rgba(15,23,42,.05)}.mapping-table tbody tr:last-child td{border-bottom:none}.del-btn{background:#e53e3e1a;border:1px solid rgba(229,62,62,.25);color:var(--danger);border-radius:6px;padding:3px 8px;font-size:12px;cursor:pointer;transition:background .15s}.del-btn:hover{background:#e53e3e33}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:8px;padding:7px 16px;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap}.btn-primary:hover{background:#2558a0}.refresh,.generate{border:none;color:#fff;background:var(--primary);padding:9px 16px;font-weight:700;font-size:13px;border-radius:10px;cursor:pointer;transition:background .15s}.refresh:hover,.generate:hover{background:#2558a0}.generate{background:var(--accent)}.generate:hover{background:#237068}.status-ok{color:#059669;font-size:13px;font-weight:700}.alert{padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:13px}.alert.error{border:1px solid rgba(220,38,38,.25);background:#f8d7da99;color:var(--danger)}.load-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#ffffffbf;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;color:var(--text);z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.footer{margin-top:32px;text-align:center;color:var(--muted);font-size:12px;padding:16px 0;border-top:1px solid var(--border)}.section-content{background:var(--surface);border-radius:var(--radius);box-shadow:0 4px 12px #0f172a0f;border:1px solid var(--border);padding:24px;margin-top:16px}.info-box{color:var(--text);border:1px solid rgba(55,65,81,.2);background:#f8fafc;padding:8px 12px;border-radius:8px;font-size:13px}@media (max-width: 640px){.app{padding:12px 14px 40px}.kpi-row{grid-template-columns:repeat(2,1fr)}.title{font-size:20px}.global-controls{flex-direction:column;align-items:flex-start}}
