body{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{width:100%;height:100vh}.settings-page{height:100vh;padding-top:var(--header-height);background:#fafaf8;flex-direction:column;display:flex}.settings-header{color:#fff;background:#0d9488;align-items:center;gap:20px;padding:15px 30px;display:flex;box-shadow:0 2px 8px #0000001a}.settings-header h1{margin:0;font-size:24px;font-weight:600}.settings-content{flex:1;width:100%;max-width:800px;margin:0 auto;padding:30px;overflow-y:auto}.settings-section{background:#fff;border-radius:8px;margin-bottom:20px;padding:30px;box-shadow:0 2px 4px #0000001a}.settings-section h2{color:#333;margin:0 0 10px;font-size:20px}.status-display{background:#f9f9f9;border-radius:4px;align-items:center;gap:12px;padding:12px;display:flex}.status-badge.success{color:#fff;background:#4caf50}.status-badge.warning{color:#fff;background:#ff9800}.masked-key{color:#666;letter-spacing:2px;font-family:Courier New,monospace;font-size:14px}.api-key-input{border:1px solid #ddd;border-radius:4px;width:100%;padding:12px;font-family:Courier New,monospace;font-size:14px;transition:border-color .2s}.api-key-input:focus{border-color:#0d9488;outline:none}.api-key-input:disabled{cursor:not-allowed;background:#f5f5f5}.input-hint{color:#999;margin:8px 0 0;font-size:12px;line-height:1.6}.input-hint a{color:#0d9488;text-decoration:none}.input-hint a:hover{text-decoration:underline}.message{border-radius:4px;padding:12px 16px;font-size:14px;line-height:1.6}.message-success{color:#2e7d32;background:#e8f5e9;border-left:4px solid #4caf50}.message-error{color:#c62828;background:#ffebee;border-left:4px solid #f44336}.message-info{color:#1565c0;background:#e3f2fd;border-left:4px solid #2196f3}.info-box{background:#f9f9f9;border-left:4px solid #0d9488;border-radius:4px;margin-bottom:20px;padding:20px}.info-box h3{color:#333;margin:0 0 12px;font-size:16px}.info-box ul{margin:0;padding-left:20px}.info-box li{color:#555;margin-bottom:8px;font-size:14px;line-height:1.6}.info-box li strong{color:#333}.warning-box{background:#fff3e0;border-left:4px solid #ff9800;border-radius:4px;padding:20px}.warning-box p{color:#e65100;margin:0 0 10px;font-size:14px;line-height:1.6}.warning-box p:last-child{margin-bottom:0}.provider-config{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:25px;padding:25px}.provider-config h3{color:#0d9488;margin:0 0 20px;font-size:18px;font-weight:600}.api-base-input,.model-select{border:1px solid #ddd;border-radius:4px;width:100%;padding:12px;font-size:14px;transition:border-color .2s}.api-base-input:focus,.model-select:focus{border-color:#0d9488;outline:none}.api-base-input:disabled,.model-select:disabled{cursor:not-allowed;background:#f5f5f5}.add-provider-hint{text-align:center;color:#999;border:2px dashed #e0e0e0;border-radius:8px;margin-top:20px;padding:20px;font-size:14px}.add-provider-hint p{margin:0}.settings-content::-webkit-scrollbar{width:8px}.settings-content::-webkit-scrollbar-track{background:#f1f1f1}.settings-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.settings-content::-webkit-scrollbar-thumb:hover{background:#555}.data-import-page{height:100vh;padding-top:var(--header-height);background:#fafaf8;flex-direction:column;display:flex}.import-header{color:#fff;background:#0d9488;align-items:center;gap:20px;padding:15px 30px;display:flex;box-shadow:0 2px 8px #0000001a}.import-header h1{margin:0;font-size:24px;font-weight:600}.import-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:30px;overflow-y:auto}.import-section{background:#fff;border-radius:8px;margin-bottom:20px;padding:30px;box-shadow:0 2px 4px #0000001a}.import-section h2{color:#333;margin:0 0 10px;font-size:20px}.section-description{color:#666;margin:0 0 25px;font-size:14px;line-height:1.6}.upload-area{text-align:center;background:#fafafa;border:2px dashed #ddd;border-radius:8px;margin-bottom:20px;padding:40px;transition:all .3s}.upload-area.drag-active{background:#f0f4ff;border-color:#0d9488}.files-list{flex-direction:column;gap:10px;display:flex}.files-header{color:#0d9488;background:#f0f4ff;border-radius:4px;justify-content:space-between;align-items:center;padding:10px;font-weight:500;display:flex}.clear-all-btn{color:#fff;cursor:pointer;background:#f44336;border:none;border-radius:4px;padding:6px 12px;font-size:12px;transition:background .2s}.clear-all-btn:hover{background:#d32f2f}.file-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;align-items:center;gap:15px;padding:15px;display:flex}.file-selected{background:#fff;border-radius:6px;align-items:center;gap:15px;padding:20px;display:flex}.file-icon{font-size:48px}.file-info{text-align:left;flex:1}.file-name{color:#333;margin-bottom:5px;font-size:16px;font-weight:500}.file-size{color:#999;font-size:14px}.remove-file-btn{color:#fff;cursor:pointer;background:#f44336;border:none;border-radius:4px;padding:8px 12px;font-size:16px;transition:background .2s}.remove-file-btn:hover{background:#d32f2f}.upload-prompt{flex-direction:column;align-items:center;gap:15px;display:flex}.upload-icon{font-size:64px}.upload-prompt p{color:#666;margin:0;font-size:16px}.file-input{display:none}.file-input-label{color:#fff;cursor:pointer;background:#0d9488;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:500;transition:background .2s}.file-input-label:hover{background:#0f766e}.file-hint{color:#999;font-size:12px}.button-group{gap:12px;margin-bottom:20px;display:flex}.btn{cursor:pointer;border:none;border-radius:4px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s}.btn-secondary{color:#333;background:#f0f0f0}.import-results{margin-top:20px}.import-results h3{color:#333;margin:0 0 15px;font-size:18px}.results-summary{background:#f9f9f9;border-radius:8px;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:20px;padding:20px;display:grid}.summary-stat{text-align:center;background:#fff;border-radius:6px;padding:15px}.summary-stat.success{border-left:4px solid #4caf50}.summary-stat.error{border-left:4px solid #f44336}.import-result h4{color:#333;margin:0 0 15px;font-size:16px}.import-result h5{color:#666;margin:15px 0 10px;font-size:14px}.import-result{border-radius:8px;margin-top:20px;padding:20px}.import-result.success{background:#e8f5e9;border-left:4px solid #4caf50}.import-result.error{background:#ffebee;border-left:4px solid #f44336}.import-result h3{color:#333;margin:0 0 15px;font-size:18px}.result-stats{grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:20px;display:grid}.stat-item{text-align:center;background:#fff;border-radius:6px;padding:15px}.stat-item.success{border-left:4px solid #4caf50}.stat-item.warning{border-left:4px solid #ff9800}.stat-label{color:#999;margin-bottom:5px;font-size:12px;display:block}.stat-value{color:#333;font-size:24px;font-weight:600;display:block}.matched-products,.created-products,.unmatched-products,.warnings,.errors{background:#fff;border-radius:6px;margin-top:20px;padding:15px}.matched-products h4,.created-products h4,.unmatched-products h4,.warnings h4,.errors h4{color:#333;margin:0 0 10px;font-size:16px}.created-products{border-left:4px solid #52c41a}.created-products h5{color:#52c41a}.new-badge{color:#fff;background:#52c41a;border-radius:3px;margin-left:8px;padding:2px 8px;font-size:12px;font-weight:400;display:inline-block}.products-list{flex-direction:column;gap:10px;display:flex}.product-item{background:#f9f9f9;border-left:3px solid #0d9488;border-radius:4px;padding:12px}.product-name{color:#333;margin-bottom:5px;font-size:14px;font-weight:500}.product-metrics{color:#666;gap:15px;font-size:12px;display:flex}.unmatched-products ul,.warnings ul,.errors ul{margin:10px 0 0;padding-left:20px}.unmatched-products li,.warnings li,.errors li{color:#666;margin-bottom:5px;font-size:14px}.errors li{color:#d32f2f}.hint{color:#999;margin:5px 0 10px;font-size:12px}.fields-info{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}.field-group{background:#f9f9f9;border-left:3px solid #0d9488;border-radius:6px;padding:15px}.field-group h3{color:#0d9488;margin:0 0 10px;font-size:16px}.field-group ul{margin:0;padding-left:20px}.field-group li{color:#555;margin-bottom:8px;font-size:14px;line-height:1.6}.instructions{background:#f9f9f9;border-left:3px solid #0d9488;border-radius:6px;padding:15px}.instructions ol{margin:0;padding-left:20px}.instructions li{color:#555;margin-bottom:10px;font-size:14px;line-height:1.6}.extracted-products{background:#f0f4ff;border-left:4px solid #0d9488;border-radius:8px;margin-top:20px;padding:20px}.extracted-products h3{color:#333;margin:0 0 10px;font-size:18px}.products-preview{flex-direction:column;gap:8px;max-height:300px;margin-top:15px;display:flex;overflow-y:auto}.product-preview-item{color:#333;background:#fff;border-radius:4px;padding:10px;font-size:14px}.product-preview-item.more{text-align:center;color:#666;font-style:italic}.product-list-page{height:100vh;padding-top:var(--header-height);background:#fafaf8;flex-direction:column;display:flex}.filter-group select,.filter-group input[type=date]{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;min-width:120px;padding:6px 12px;font-size:14px}.filter-group select:hover,.filter-group input[type=date]:hover{border-color:#0d9488}.filter-group select:focus,.filter-group input[type=date]:focus{border-color:#0d9488;outline:none;box-shadow:0 0 0 3px #0d94881a}.products-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));align-content:start;gap:20px;padding:30px;display:grid;overflow-y:auto}.product-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:8px;padding:20px;transition:all .3s;box-shadow:0 2px 8px #00000014}.product-card:hover{border-color:#0d9488;transform:translateY(-4px);box-shadow:0 4px 16px #0d948826}.product-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.product-header h3{color:#333;flex:1;margin:0;font-size:16px;font-weight:600;line-height:1.4}.category-tag{color:#666;white-space:nowrap;background:#f0f0f0;border-radius:12px;flex-shrink:0;padding:4px 10px;font-size:12px}.product-stats{flex-direction:column;gap:12px;display:flex}.stat-item{flex-direction:column;gap:4px;display:flex}.stat-item.primary{background:#fff;border:1px solid #e5e5e5;border-radius:6px;padding:12px}.stat-item.primary .stat-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.stat-item.primary .stat-value{color:#0d9488;font-family:JetBrains Mono,SF Mono,Roboto Mono,monospace;font-size:28px;font-weight:700}.stat-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.stat-label{color:#999;font-size:12px}.stat-value{color:#333;font-size:18px;font-weight:600}.stat-value.accent{color:#0d9488}.product-footer{color:#999;border-top:1px solid #f0f0f0;margin-top:12px;padding-top:12px;font-size:12px}.empty-state{text-align:center;color:#999;grid-column:1/-1;padding:60px 20px}.empty-state p{margin:8px 0;font-size:16px}.empty-state .hint{color:#bbb;font-size:14px}@media (width<=1200px){.products-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (width<=768px){.filters-section{border-bottom:none;flex-direction:column;align-items:stretch;gap:12px;max-height:0;padding:0 20px;transition:max-height .3s ease-out;overflow:hidden}.filters-section .desktop-only{display:none}.filters-section.expanded{border-bottom:1px solid #e0e0e0;max-height:800px;padding:20px;transition:max-height .3s ease-in}.products-grid{grid-template-columns:1fr;padding:20px}.filter-group{flex-direction:column;align-items:stretch;gap:6px}.filter-group label{font-size:14px;font-weight:500}.filter-group select,.filter-group input[type=date]{width:100%;min-height:44px;font-size:16px}.reset-btn{width:100%;min-height:44px;margin-top:8px;margin-left:0;font-size:16px}}.mobile-filter-bar{display:none}@media (width<=768px){.product-list-page{padding-top:48px}.filters-section{border-bottom:none;padding:0}.filters-section.expanded{border-bottom:1px solid #e0e0e0;flex-direction:column;align-items:stretch;gap:12px;padding:16px;display:flex}.filters-section.expanded .filter-group,.filters-section.expanded .filter-group select,.filters-section.expanded .filter-group input[type=date]{width:100%}.filters-section.expanded .reset-btn{order:99;width:100%;margin:4px 0 0}.mobile-filter-bar{background:#fff;border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;gap:12px;min-height:56px;padding:12px 16px;display:flex}.mobile-filter-bar .filter-group{flex-direction:row;flex:1;align-items:center;gap:8px}.mobile-filter-bar .filter-group label{color:#666;white-space:nowrap;font-size:13px;display:none}.mobile-filter-bar .filter-group select{flex:1;min-width:0;min-height:44px;padding:8px 12px;font-size:14px}.mobile-filter-toggle{color:#fff;cursor:pointer;white-space:nowrap;background:#0d9488;border:none;border-radius:6px;min-width:80px;min-height:44px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .2s;display:block}.mobile-filter-toggle:active{background:#0f766e}.product-card{margin-bottom:8px;padding:12px}.product-card-header h3{-webkit-line-clamp:2;-webkit-box-orient:vertical;max-height:2.8em;font-size:15px;line-height:1.4;display:-webkit-box;overflow:hidden}.product-card-body{gap:8px}.metric-value{font-size:20px}.product-metrics{flex-wrap:wrap;gap:12px;display:flex}.metric-item{flex:0 0 calc(50% - 6px);min-width:0}.product-card-footer{color:#999;border-top:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding-top:8px;font-size:12px;display:flex}.product-card-footer .session-info,.product-card-footer .gpm-info{display:inline}.product-card .metric-item:nth-child(n+5){display:none}.product-card{cursor:pointer;-webkit-tap-highlight-color:#0000000d}.product-card:active{transition:transform .1s;transform:scale(.98)}}.dashboard-page{height:100vh;padding-top:var(--header-height);background:#fafaf8;flex-direction:column;display:flex}.dashboard-header{color:#fff;background:#1a1a2e;align-items:center;gap:20px;padding:15px 30px;display:flex;box-shadow:0 2px 8px #0000001a}.dashboard-header h1{flex:1;margin:0;font-size:24px;font-weight:600}.view-mode-toggle{gap:10px;display:flex}.view-btn{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:4px;padding:8px 16px;font-size:14px;transition:all .2s}.view-btn:hover{background:#fff3}.view-btn.active{background:#0d9488;font-weight:600}.back-btn{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:4px;padding:8px 16px;font-size:14px;transition:background .2s}.back-btn:hover{background:#ffffff4d}.summary-cards{background:#fff;border-bottom:1px solid #e0e0e0;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;padding:20px 30px;display:grid}.summary-card{background:#fff;border:1px solid #e5e5e5;border-radius:6px;padding:20px;box-shadow:0 1px 3px #00000014}.summary-label{color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;font-weight:500}.summary-value{color:#0d9488;font-family:JetBrains Mono,SF Mono,Roboto Mono,monospace;font-size:32px;font-weight:700}.filters-section{background:#fff;border-bottom:1px solid #e0e0e0;flex-wrap:wrap;align-items:center;gap:20px;padding:20px 30px;display:flex}.filter-group{align-items:center;gap:8px;display:flex}.filter-group label{color:#666;white-space:nowrap;font-size:14px}.filter-group select,.filter-group input[type=number]{background:#fff;border:1px solid #ddd;border-radius:4px;min-width:120px;padding:6px 12px;font-size:14px}.filter-group select:hover,.filter-group input[type=number]:hover{border-color:#0d9488}.filter-group select:focus,.filter-group input[type=number]:focus{border-color:#0d9488;outline:none;box-shadow:0 0 0 3px #0d94881a}.reset-btn{color:#666;cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;margin-left:auto;padding:6px 16px;font-size:14px;transition:all .2s}.reset-btn:hover{background:#e0e0e0;border-color:#ccc}.metrics-table-container{flex:1;padding:30px;overflow:auto}.metrics-table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;overflow:hidden;box-shadow:0 2px 8px #00000014}.metrics-table thead{color:#fff;background:#1a1a2e}.metrics-table th{text-align:left;white-space:nowrap;padding:16px;font-size:14px;font-weight:600}.metrics-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.metrics-table tbody tr:hover{background:#fafaf8}.metrics-table td{color:#333;padding:16px;font-size:14px}.metrics-table td.product-name{text-overflow:ellipsis;white-space:nowrap;max-width:300px;font-weight:500;overflow:hidden}.metrics-table td.number{text-align:right;font-family:SF Mono,Monaco,Courier New,monospace}.metrics-table td.highlight{color:#0d9488;font-weight:600}.metrics-table td.date{color:#999;font-size:13px}.metrics-table td.empty-state{text-align:center;color:#999;padding:60px 20px;font-size:16px}.metrics-table .low{color:#dc2626;font-weight:600}.metrics-table .medium{color:#d97706;font-weight:600}.metrics-table .high{color:#059669;font-weight:600}@media (width<=1200px){.metrics-table-container{overflow-x:auto}.metrics-table{min-width:1000px}}@media (width<=768px){.dashboard-page{padding-top:48px}.dashboard-header{flex-wrap:wrap;padding:12px 16px}.dashboard-header h1{width:100%;margin-bottom:8px;font-size:18px}.view-mode-toggle{flex:1}.view-btn{flex:1;min-height:44px;font-size:13px}.back-btn{min-height:44px}.summary-cards{grid-template-columns:1fr 1fr;gap:12px;padding:16px}.summary-card{background:#f8f9fa;padding:16px}.summary-label{color:#495057;margin-bottom:6px;font-size:12px;font-weight:600}.summary-value{color:#212529;font-size:24px}.filters-section{flex-direction:column;align-items:stretch;padding:16px}.filter-group{flex-direction:column;align-items:stretch;gap:6px}.filter-group label{font-size:14px;font-weight:500}.filter-group select,.filter-group input[type=number]{width:100%;min-height:44px;font-size:16px}.reset-btn{width:100%;min-height:44px;margin-top:8px;margin-left:0;font-size:16px}.metrics-table-container{padding:16px;position:relative}.metrics-table-container:after{content:"→";color:#0d9488;opacity:.5;pointer-events:none;font-size:24px;animation:2s infinite slideHint;position:absolute;top:50%;right:20px;transform:translateY(-50%)}@keyframes slideHint{0%,to{opacity:.5;transform:translateY(-50%)translate(0)}50%{opacity:1;transform:translateY(-50%)translate(5px)}}.metrics-table-container::-webkit-scrollbar{height:8px}.metrics-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.metrics-table-container::-webkit-scrollbar-thumb{background:#0d9488;border-radius:4px}.metrics-table-container::-webkit-scrollbar-thumb:hover{background:#0f766e}.metrics-table{min-width:800px}.metrics-table th,.metrics-table td{padding:12px;font-size:13px}.heatmap-controls{flex-direction:column;gap:12px;padding:16px}.control-group{flex-direction:column;align-items:stretch;gap:6px}.control-group select{width:100%;min-height:44px;font-size:16px}}.heatmap-container{flex-direction:column;flex:1;padding:30px;display:flex;overflow:hidden}.heatmap-controls{background:#fff;border-radius:8px;gap:20px;margin-bottom:20px;padding:15px 20px;display:flex;box-shadow:0 2px 8px #00000014}.control-group{align-items:center;gap:10px;display:flex}.control-group label{color:#666;font-size:14px;font-weight:500}.control-group select{background:#fff;border:1px solid #ddd;border-radius:4px;min-width:200px;padding:8px 12px;font-size:14px}.heatmap-wrapper{background:#fff;border-radius:8px;flex-direction:column;flex:1;display:flex;overflow:hidden;box-shadow:0 2px 8px #00000014}.heatmap-legend{border-bottom:1px solid #e0e0e0;align-items:center;gap:10px;padding:15px 20px;display:flex}.legend-label{color:#666;font-size:12px;font-weight:500}.legend-gradient{background:linear-gradient(90deg,#f5f5f5,#0d9488);border:1px solid #e0e0e0;border-radius:4px;flex:1;max-width:200px;height:20px}.heatmap-scroll{flex:1;overflow:auto}.heatmap-table{border-collapse:collapse;width:100%;font-size:13px}.heatmap-table thead{color:#fff;z-index:10;background:#1a1a2e;position:sticky;top:0}.heatmap-table th{text-align:center;white-space:nowrap;border-right:1px solid #ffffff1a;padding:12px 8px;font-size:12px;font-weight:600}.heatmap-table th.product-header{z-index:11;text-align:left;background:#1a1a2e;min-width:200px;max-width:200px;padding-left:15px;position:sticky;left:0}.heatmap-table th.date-header{min-width:80px}.heatmap-table tbody tr{border-bottom:1px solid #f0f0f0}.heatmap-table td{text-align:center;border-right:1px solid #f0f0f0;padding:12px 8px;font-family:SF Mono,Monaco,Courier New,monospace;font-size:12px;transition:all .2s}.heatmap-table td.product-cell{text-align:left;text-overflow:ellipsis;white-space:nowrap;z-index:1;background:#fff;min-width:200px;max-width:200px;padding-left:15px;font-family:inherit;font-weight:500;position:sticky;left:0;overflow:hidden;box-shadow:2px 0 4px #0000000d}.heatmap-table td.heatmap-cell{cursor:pointer;font-weight:600}.heatmap-table td.heatmap-cell:hover{z-index:2;transform:scale(1.1);box-shadow:0 0 8px #0d94884d}.heatmap-container .empty-state{color:#999;background:#fff;border-radius:8px;justify-content:center;align-items:center;height:300px;font-size:16px;display:flex}.heatmap-view-toggle{background:#fff;border-radius:8px;gap:10px;margin-bottom:20px;padding:15px 20px;display:flex;box-shadow:0 2px 8px #00000014}.heatmap-view-toggle .view-btn{color:#0d9488;cursor:pointer;background:#0d94881a;border:2px solid #0000;border-radius:6px;flex:1;padding:10px 20px;font-size:15px;font-weight:600;transition:all .2s}.heatmap-view-toggle .view-btn:hover{background:#0d948833;transform:translateY(-2px)}.heatmap-view-toggle .view-btn.active{color:#fff;background:#0d9488;border-color:#0d9488;box-shadow:0 4px 12px #0d94884d}.content-list-container{padding:20px;padding-top:calc(var(--header-height) + 20px);box-sizing:border-box;max-width:1400px;min-height:100vh;margin:0 auto}.content-list-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.content-list-header h2{color:#333;margin:0;font-size:24px}.create-btn{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:transform .2s,box-shadow .2s}.create-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.filters{background:#fff;border-radius:8px;flex-wrap:wrap;align-items:flex-end;gap:15px;margin-bottom:20px;padding:20px;display:flex;box-shadow:0 2px 8px #0000001a}.filter-group{flex-direction:column;gap:5px;display:flex}.filter-group label{color:#666;font-size:13px;font-weight:500}.filter-group input,.filter-group select{border:1px solid #ddd;border-radius:4px;min-width:150px;padding:8px 12px;font-size:14px}.filter-group input:focus,.filter-group select:focus{border-color:#0d9488;outline:none}.reset-btn{cursor:pointer;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;padding:8px 16px;font-size:14px;transition:background .2s}.reset-btn:hover{background:#e8e8e8}.stats{color:#666;background:#f9f9f9;border-radius:6px;gap:30px;margin-bottom:20px;padding:15px 20px;font-size:14px;display:flex}.stats span{font-weight:500}.content-table-wrapper{background:#fff;border-radius:8px;overflow-x:auto;box-shadow:0 2px 8px #0000001a}.content-table{border-collapse:collapse;width:100%}.content-table thead{background:#f8f9fa}.content-table th{text-align:left;color:#555;white-space:nowrap;border-bottom:2px solid #e0e0e0;padding:12px 15px;font-size:13px;font-weight:600}.content-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.content-table th.sortable:hover{background:#e8e8e8}.content-table td{color:#333;border-bottom:1px solid #f0f0f0;padding:12px 15px;font-size:14px}.content-table tbody tr:hover{background:#f9f9f9}.content-table .product-name,.content-table .selling-point{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.content-table .revenue{color:#4caf50;font-weight:600}.content-table .conversion-rate{color:#ff9800;font-weight:600}.status-badge.annotated{color:#4caf50;background:#e8f5e9}.status-badge.not-annotated{color:#ff9800;background:#fff3e0}.action-btn{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:4px;padding:6px 12px;font-size:13px;transition:background .2s}.action-btn:hover{background:#0f766e}.pagination{justify-content:center;align-items:center;gap:20px;margin-top:20px;padding:20px;display:flex}.pagination button{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:8px 16px;font-size:14px;transition:all .2s}.pagination button:hover:not(:disabled){color:#fff;background:#0d9488;border-color:#0d9488}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:#666;font-size:14px}.loading{text-align:center;color:#999;padding:40px;font-size:16px}@media (width<=1200px){.filters{flex-direction:column;align-items:stretch}.filter-group input,.filter-group select{min-width:100%}}@media (width<=768px){.content-list-container{padding:10px}.content-table-wrapper{overflow-x:scroll}.content-table{min-width:1000px}}.content-work-order{flex-direction:column;gap:16px;display:flex}.content-work-order.embedded{margin-top:12px}.content-work-order-toolbar{justify-content:flex-end;display:flex}.generate-work-order-btn,.primary-btn,.secondary-btn{cursor:pointer;border:none;border-radius:6px;font-size:13px;font-weight:500}.generate-work-order-btn,.primary-btn{color:#fff;background:#0d9488;padding:8px 14px}.secondary-btn{color:#374151;background:#f3f4f6;padding:8px 12px}.work-order-composer,.work-order-group,.work-order-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px}.work-order-composer{padding:16px}.work-order-composer-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.work-order-composer-grid label,.work-order-filters{flex-direction:column;gap:6px;display:flex}.work-order-composer-grid select,.work-order-filters select,.work-order-card-actions select{border:1px solid #d1d5db;border-radius:6px;padding:8px 10px;font-size:13px}.work-order-source-preview{background:#f8fafc;border-radius:6px;margin-top:12px;padding:12px}.source-preview-title{color:#6b7280;margin-bottom:6px;font-size:12px}.source-preview-expression{color:#111827;font-size:14px;font-weight:500;line-height:1.6}.source-preview-meta{color:#6b7280;margin-top:6px;font-size:12px}.work-order-composer-actions,.work-order-card-head,.work-order-section-header,.work-order-card-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.work-order-composer-actions{justify-content:flex-end;margin-top:12px}.work-order-section-header h4,.work-order-group-title{margin:0}.work-order-filters{flex-flow:wrap}.work-orders-groups{flex-direction:column;gap:8px;display:flex}.work-order-group{padding:12px}.work-order-group-title{color:#111827;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;font-weight:600;display:flex}.status-badge{border-radius:12px;padding:4px 10px;font-size:12px;font-weight:500;line-height:1.2;display:inline-block}.status-badge.status-pending{color:#6b7280;background:#f3f4f6}.status-badge.status-produced{color:#1e40af;background:#dbeafe}.status-badge.status-published{color:#065f46;background:#d1fae5}.status-badge.status-data-collected{color:#6b21a8;background:#e9d5ff}.status-badge.status-closed{color:#6b7280;background:#f3f4f6}.work-order-card{margin-top:8px;padding:12px}.work-order-card-title{color:#111827;flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.work-order-product-tag{color:#4b5563;text-overflow:ellipsis;white-space:nowrap;background:#f3f4f6;border-radius:999px;align-items:center;max-width:min(100%,220px);padding:3px 10px;font-size:12px;font-weight:500;display:inline-flex;overflow:hidden}.work-order-card-meta,.work-order-empty,.work-order-empty-inline{color:#6b7280;font-size:12px}.work-order-detail{color:#e5e7eb;background:#0f172a;border-radius:6px;margin-top:12px;padding:12px;font-size:12px;line-height:1.5;overflow-x:auto}.work-order-empty,.work-order-empty-inline{padding:16px 0}@media (width<=768px){.work-order-section-header,.work-order-card-head,.work-order-card-actions{flex-direction:column;align-items:stretch}.work-order-filters{flex-direction:column}}.searchable-select{width:100%;position:relative}.searchable-select-trigger{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;min-height:42px;padding:10px 12px;font-size:14px;transition:all .2s;display:flex}.searchable-select-trigger:hover{border-color:#0d9488}.searchable-select-value{text-overflow:ellipsis;white-space:nowrap;color:#111827;flex:1;overflow:hidden}.searchable-select-arrow{color:#6b7280;flex-shrink:0;font-size:10px;transition:transform .2s}.searchable-select-icons{flex-shrink:0;align-items:center;gap:6px;display:flex}.searchable-select-search-icon{opacity:.5;font-size:12px}.searchable-select-option.empty-option{color:#0d9488;border-bottom:1px solid #e5e7eb;font-weight:500}.searchable-select-dropdown{z-index:1000;background:#fff;border:1px solid #d1d5db;border-radius:6px;flex-direction:column;max-height:320px;display:flex;position:absolute;top:calc(100% + 4px);left:0;right:0;box-shadow:0 4px 12px #00000026}.searchable-select-search{border-bottom:1px solid #e5e7eb;padding:8px}.searchable-select-input{border:1px solid #d1d5db;border-radius:4px;outline:none;width:100%;padding:8px 10px;font-size:14px;transition:border-color .2s}.searchable-select-input:focus{border-color:#0d9488}.searchable-select-options{max-height:260px;overflow-y:auto}.searchable-select-option{cursor:pointer;color:#111827;text-overflow:ellipsis;white-space:nowrap;padding:10px 12px;font-size:14px;transition:background .15s;overflow:hidden}.searchable-select-option:hover{background:#f3f4f6}.searchable-select-option.selected{color:#0d9488;background:#ecfeff;font-weight:500}.searchable-select-empty{text-align:center;color:#9ca3af;padding:20px 12px;font-size:13px}@media (width<=768px){.searchable-select-dropdown{border-radius:12px 12px 0 0;max-height:60vh;position:fixed;inset:auto 0 0;box-shadow:0 -4px 12px #00000026}.searchable-select-options{max-height:calc(60vh - 60px)}.searchable-select-option{padding:14px 16px;font-size:16px}.searchable-select-input{padding:10px 12px;font-size:16px}}.work-orders-page{padding:20px;padding-top:calc(var(--header-height) + 20px);box-sizing:border-box;max-width:1400px;min-height:100vh;margin:0 auto}.work-orders-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:12px;display:flex}.work-orders-header h2{color:#111827;margin:0;font-size:24px}.work-orders-header p{color:#6b7280;margin:6px 0 0;font-size:14px}.work-orders-summary{color:#0f766e;background:#ecfeff;border:1px solid #99f6e4;border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600}.work-orders-filters-panel{background:#fff;border-radius:8px;margin-bottom:16px;padding:12px 16px;box-shadow:0 2px 8px #00000014}.work-orders-filters-panel label{flex-direction:column;gap:6px;max-width:360px;display:flex}.work-orders-filters-panel span{color:#6b7280;font-size:13px;font-weight:500}.work-orders-filters-panel select{border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:14px}.work-orders-empty-state{text-align:center;color:#6b7280;background:#fff;border-radius:8px;padding:40px 20px;box-shadow:0 2px 8px #00000014}@media (width<=768px){.work-orders-page{padding:10px}.work-orders-header{flex-direction:column}}.content-form-container{max-width:900px;margin:0 auto;margin-top:calc(var(--header-height) + 20px);min-height:calc(100vh - var(--header-height) - 40px);box-sizing:border-box;background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 12px #0000001a}.content-form-header{border-bottom:2px solid #f0f0f0;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;display:flex}.content-form-header h2{color:#333;margin:0;font-size:24px}.steps-nav{justify-content:space-between;margin-bottom:40px;display:flex;position:relative}.steps-nav:before{content:"";z-index:0;background:#e0e0e0;height:2px;position:absolute;top:20px;left:0;right:0}.step-item{cursor:pointer;z-index:1;flex-direction:column;flex:1;align-items:center;gap:8px;display:flex;position:relative}.step-number{color:#999;background:#fff;border:2px solid #e0e0e0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:600;transition:all .3s;display:flex}.step-item.active .step-number{color:#fff;background:#0d9488;border-color:#0d9488}.step-item.completed .step-number{color:#fff;background:#4caf50;border-color:#4caf50}.step-label{color:#999;text-align:center;font-size:12px}.step-item.active .step-label{color:#0d9488;font-weight:600}.step-item.completed .step-label{color:#4caf50}.form-content{min-height:400px;margin-bottom:30px}.form-step h3{color:#333;border-bottom:1px solid #f0f0f0;margin-bottom:25px;padding-bottom:10px;font-size:20px}.form-group .hint{color:#999;margin-left:5px;font-size:12px;font-weight:400}.form-group input[type=text],.form-group input[type=url],.form-group input[type=number],.form-group input[type=datetime-local],.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.radio-group,.checkbox-group{flex-wrap:wrap;gap:15px;display:flex}.radio-label,.checkbox-label{cursor:pointer;color:#666;align-items:center;gap:8px;font-size:14px;display:flex}.radio-label input[type=radio],.checkbox-label input[type=checkbox]{cursor:pointer;width:auto}.warning{color:#856404;background:#fff3cd;border:1px solid #ffc107;border-radius:4px;padding:12px;font-size:14px}.field-note{color:#999;margin-top:8px;font-size:13px}.buypoint-checkbox-group{background:#fafafa;border:1px solid #e0e0e0;border-radius:4px;max-height:300px;padding:10px;overflow-y:auto}.buypoint-checkbox-label{border-radius:4px;width:100%;margin:0;padding:8px 10px;transition:background .2s}.buypoint-checkbox-label:hover{background:#f0f0f0}.buypoint-checkbox-label input[type=checkbox]{margin-right:8px}.buypoint-checkbox-label span{word-break:break-word;flex:1}.value-preview{background:#f9f9f9;border-left:4px solid #0d9488;border-radius:6px;margin-top:15px;padding:15px}.preview-title{color:#0d9488;margin-bottom:10px;font-size:13px;font-weight:600}.value-item{color:#666;font-size:13px;line-height:1.8}.value-item div{margin-bottom:5px}.value-item strong{color:#333}.audience-selector{flex-direction:column;gap:20px;display:flex}.audience-group h4{color:#0d9488;margin-bottom:10px;font-size:15px}.audience-item{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;padding:12px;transition:all .2s}.audience-item:hover{background:#f0f0f0;border-color:#0d9488}.audience-item input[type=checkbox]{margin-top:2px}.audience-desc{color:#333;margin-bottom:5px;font-size:14px;font-weight:600}.audience-detail{color:#666;font-size:12px;line-height:1.6}.form-preview{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;margin-top:30px;padding:20px}.form-preview h4{color:#333;margin-bottom:15px;font-size:16px}.preview-grid{color:#666;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px;font-size:14px;display:grid}.preview-grid div{background:#fff;border-radius:4px;padding:8px}.preview-grid strong{color:#333}.form-actions{border-top:1px solid #f0f0f0;justify-content:flex-end;gap:15px;padding-top:20px;display:flex}.content-form-loading{text-align:center;color:#999;padding:60px;font-size:16px}@media (width<=768px){.content-form-container{padding:15px}.steps-nav{flex-wrap:wrap}.step-item{flex:0 0 calc(25% - 10px);margin-bottom:15px}.step-label{font-size:10px}.radio-group,.checkbox-group{flex-direction:column}.preview-grid{grid-template-columns:1fr}}.form-section-divider{border-top:2px dashed #e0e0e0;margin:30px 0 20px;padding-top:20px}.form-section-divider h4{color:#0d9488;margin:0 0 15px;font-size:16px;font-weight:600}.required{color:#f44336;margin-left:4px}.radio-label{cursor:pointer;border:1px solid #e0e0e0;border-radius:6px;align-items:flex-start;gap:8px;padding:10px;transition:all .2s;display:flex}.radio-label:hover{background:#f0fdf4;border-color:#0d9488}.radio-label input[type=radio]{margin-top:2px}.radio-label span{color:#555;flex:1;font-size:14px;line-height:1.5}.chat-window{background:#fff;border-radius:8px;flex-direction:column;height:100%;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000001a}.chat-header{background:#fafafa;border-bottom:1px solid #e0e0e0;flex-direction:column;flex-shrink:0;gap:12px;padding:15px 20px;display:flex}.chat-header h3{color:#333;border:none;margin:0;padding:0;font-size:18px}.quick-actions{flex-wrap:wrap;gap:8px;display:flex}.quick-action-btn{color:#333;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #ddd;border-radius:4px;align-items:center;gap:4px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.quick-action-btn:hover:not(:disabled){color:#0d9488;background:#f5f5f5;border-color:#0d9488;transform:translateY(-1px);box-shadow:0 2px 4px #0d948833}.quick-action-btn:disabled{color:#999;cursor:not-allowed;background:#f5f5f5;border-color:#e0e0e0}.quick-action-btn:active:not(:disabled){transform:translateY(0)}.generate-plan-btn{color:#fff;cursor:pointer;background:#2196f3;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;transition:background .2s}.generate-plan-btn:disabled{cursor:not-allowed;background:#ccc}.messages-container{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:15px;padding:20px;display:flex;overflow-y:auto}.empty-state{color:#999;text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:20px;display:flex}.empty-state p{margin:5px 0}.product-stats-summary{width:100%;max-width:600px}.product-stats-summary h4{color:#333;margin:0 0 20px;font-size:18px;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-bottom:20px;display:grid}.stat-card{text-align:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000000d}.stat-label{color:#666;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px;font-weight:500}.stat-value{color:#0d9488;flex-direction:column;align-items:center;gap:4px;font-family:JetBrains Mono,SF Mono,Roboto Mono,monospace;font-size:24px;font-weight:700;display:flex}.stat-value.warning{color:#dc2626}.stat-value.amber{color:#d97706}.stat-value.success{color:#059669}.warning-badge{color:#dc2626;background:#fee;border-radius:4px;padding:2px 8px;font-family:inherit;font-size:11px;font-weight:500}.product-stats-summary .hint{color:#999;margin-top:10px;font-size:14px}.hint{color:#bbb;max-width:300px;font-size:12px}.message{margin-bottom:10px;display:flex}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{border-radius:8px;max-width:80%;padding:12px 16px;font-size:14px;line-height:1.6}.message.user .message-content{color:#fff;background:#2196f3}.message.assistant .message-content{color:#333;background:#f0f0f0}.message-content p{margin:0 0 8px}.input-container{background:#fafafa;border-top:1px solid #e0e0e0;flex-shrink:0;gap:10px;padding:15px 20px;display:flex}.input-container textarea{resize:none;border:1px solid #ddd;border-radius:4px;outline:none;flex:1;padding:10px;font-family:inherit;font-size:14px}.input-container textarea:focus{border-color:#2196f3}.input-actions{align-items:flex-end;gap:8px;display:flex}.model-toggle-btn{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;transition:all .2s;display:flex}.model-toggle-btn.sonnet{color:#f59e0b;border-color:#f59e0b}.model-toggle-btn.opus{color:#8b5cf6;border-color:#8b5cf6}.model-toggle-btn:hover{background:#f5f5f5;transform:translateY(-1px)}.input-container button{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:4px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .2s}.input-container button:disabled{cursor:not-allowed;background:#ccc}@media (width<=768px){.chat-window{border-radius:0;height:100%}.chat-header{gap:10px;padding:12px}.chat-header h3{font-size:16px}.quick-actions{grid-template-columns:1fr 1fr;gap:8px;display:grid}.quick-action-btn{justify-content:center;width:100%;min-height:44px;padding:8px;font-size:12px}.messages-container{flex:1;gap:10px;padding:12px;overflow-y:auto}.product-stats-summary{width:100%;max-width:none;margin-bottom:12px}.product-stats-summary h4{margin:0 0 12px;font-size:16px}.stats-grid{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}.stat-card{padding:10px}.stat-label{margin-bottom:4px;font-size:11px}.stat-value{font-size:18px}.warning-badge{padding:1px 6px;font-size:10px}.message-content{max-width:90%;padding:10px 12px;font-size:14px}.input-container{background:#fff;border-top:1px solid #e0e0e0;flex-direction:column;gap:8px;padding:12px}.input-container textarea{min-height:44px;max-height:120px;font-size:16px}.input-actions{flex-direction:row;gap:8px}.model-toggle-btn{flex-shrink:0;width:44px;height:44px}.input-container button{flex:1;min-height:44px;padding:10px 12px;font-size:14px}}.hypothesis-list-container{max-width:1200px;margin:0 auto;padding:76px 20px 20px}.hypothesis-list-header{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.hypothesis-list-header h3{color:#333;margin:0;font-size:24px}.create-hypothesis-btn{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:transform .2s,box-shadow .2s}.create-hypothesis-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.hypothesis-group{margin-bottom:30px}.group-header{margin-bottom:15px}.group-header h4{color:#0d9488;align-items:center;gap:10px;margin:0;font-size:18px;display:flex}.group-header .count{color:#999;font-size:14px}.hypothesis-cards{grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px;display:grid}.hypothesis-card{cursor:pointer;background:#fff;border-radius:8px;padding:20px;transition:all .2s;box-shadow:0 2px 8px #0000001a}.hypothesis-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.hypothesis-header{justify-content:space-between;align-items:flex-start;margin-bottom:10px;display:flex}.hypothesis-header h4{color:#333;flex:1;margin:0;font-size:16px}.ai-badge{color:#fff;background:#0d9488;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.hypothesis-desc{color:#666;margin-bottom:15px;font-size:13px;line-height:1.6}.hypothesis-metrics{flex-direction:column;gap:8px;margin-bottom:15px;display:flex}.metric-row{align-items:center;gap:8px;font-size:13px;display:flex}.metric-label{color:#666}.metric-value{color:#333;font-weight:500}.metric-separator{color:#ddd}.validation-result{background:#f9f9f9;border-left:4px solid #0d9488;border-radius:6px;margin-bottom:10px;padding:12px}.validation-result strong{color:#0d9488;margin-bottom:5px;font-size:13px;display:block}.validation-result p{color:#666;margin:0;font-size:13px;line-height:1.6}.validated-time{color:#999;text-align:right;font-size:12px}.empty-message{text-align:center;color:#999;padding:40px;font-size:14px}.hypothesis-list-loading{text-align:center;color:#999;padding:60px;font-size:16px}@media (width<=768px){.hypothesis-list-container{padding:10px}.hypothesis-cards{grid-template-columns:1fr}}.hypothesis-form-container{background:#fff;border-radius:8px;max-width:900px;margin:76px auto 0;padding:20px;box-shadow:0 2px 12px #0000001a}.hypothesis-form-header{border-bottom:2px solid #f0f0f0;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;display:flex}.hypothesis-form-header h2{color:#333;margin:0;font-size:24px}.hypothesis-form-content{max-height:calc(100vh - 250px);padding-right:10px;overflow-y:auto}.form-section{background:#f9f9f9;border-radius:8px;margin-bottom:30px;padding:20px}.form-section h3{color:#333;border-bottom:1px solid #e0e0e0;margin:0 0 20px;padding-bottom:10px;font-size:18px}.form-group .required{color:#f44336}.form-group .hint{color:#999;margin-top:5px;font-size:12px;display:block}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#0d9488;outline:none}.form-group textarea{resize:vertical;font-family:inherit}.form-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;display:grid}.hypothesis-form-actions{border-top:1px solid #f0f0f0;justify-content:flex-end;gap:15px;margin-top:20px;padding-top:20px;display:flex}.btn-primary,.btn-secondary{cursor:pointer;border:none;border-radius:6px;padding:10px 24px;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{color:#fff;background:#0d9488}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#666;background:#fff;border:1px solid #ddd}.hypothesis-form-loading{text-align:center;color:#999;padding:60px;font-size:16px}@media (width<=768px){.hypothesis-form-container{padding:15px}.form-row{grid-template-columns:1fr}}.hypothesis-detail-container{background:#fff;border-radius:8px;max-width:1000px;margin:76px auto 0;padding:20px;box-shadow:0 2px 12px #0000001a}.hypothesis-detail-header{border-bottom:2px solid #f0f0f0;justify-content:space-between;align-items:flex-start;margin-bottom:30px;padding-bottom:20px;display:flex}.hypothesis-detail-header h2{color:#333;margin:0 0 10px;font-size:24px}.header-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.source-badge{color:#fff;background:#0d9488;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.header-meta .date{color:#999;font-size:13px}.header-actions{align-items:center;gap:10px;display:flex}.btn-edit{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:6px;padding:8px 16px;font-size:14px;transition:background .2s}.close-btn{color:#999;cursor:pointer;background:0 0;border:none;padding:5px 10px;font-size:24px;transition:color .2s}.close-btn:hover{color:#333}.hypothesis-detail-content{max-height:calc(100vh - 200px);padding-right:10px;overflow-y:auto}.detail-section{background:#f9f9f9;border-radius:8px;margin-bottom:30px;padding:20px}.detail-section h3{color:#333;border-bottom:1px solid #e0e0e0;margin:0 0 15px;padding-bottom:10px;font-size:18px}.description-text{color:#666;margin:0;font-size:14px;line-height:1.8}.test-method-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;display:grid}.method-item{flex-direction:column;gap:5px;display:flex}.method-item label{color:#999;font-size:13px;font-weight:500}.method-item span{color:#333;font-size:14px}.metrics-comparison{overflow-x:auto}.comparison-table{border-collapse:collapse;background:#fff;border-radius:6px;width:100%;overflow:hidden}.comparison-table thead{background:#f8f9fa}.comparison-table th{text-align:left;color:#555;border-bottom:2px solid #e0e0e0;padding:12px 15px;font-size:13px;font-weight:600}.comparison-table td{color:#333;border-bottom:1px solid #f0f0f0;padding:12px 15px;font-size:14px}.comparison-table tbody tr:last-child td{border-bottom:none}.achievement-positive{color:#4caf50;font-weight:600}.achievement-negative{color:#f44336;font-weight:600}.sample-size{color:#666;text-align:right;margin-top:10px;font-size:13px}.related-contents{overflow-x:auto}.contents-table{border-collapse:collapse;background:#fff;border-radius:6px;width:100%;overflow:hidden}.contents-table thead{background:#f8f9fa}.contents-table th{text-align:left;color:#555;white-space:nowrap;border-bottom:2px solid #e0e0e0;padding:12px 15px;font-size:13px;font-weight:600}.contents-table td{color:#333;border-bottom:1px solid #f0f0f0;padding:12px 15px;font-size:14px}.contents-table tbody tr:hover{background:#f9f9f9}.contents-table .revenue{color:#4caf50;font-weight:600}.contents-table .conversion-rate{color:#ff9800;font-weight:600}.validation-box{border-left:4px solid;border-radius:6px;padding:15px}.validation-box.validated{background:#e8f5e9;border-color:#4caf50}.validation-box.rejected{background:#ffebee;border-color:#f44336}.validation-box p{color:#333;margin:0 0 10px;font-size:14px;line-height:1.8}.validation-time{color:#999;text-align:right;font-size:12px}.hypothesis-detail-loading{text-align:center;color:#999;padding:60px;font-size:16px}@media (width<=768px){.hypothesis-detail-container{padding:15px}.hypothesis-detail-header{flex-direction:column;gap:15px}.header-actions{justify-content:flex-end;width:100%}.test-method-grid{grid-template-columns:1fr}.comparison-table,.contents-table{min-width:600px}}.seeding-strategy{background:#fafafa;flex-direction:column;gap:24px;height:100%;padding:20px;display:flex;overflow-y:auto}.strategy-header{border-bottom:2px solid #0d9488;justify-content:space-between;align-items:center;padding-bottom:16px;display:flex}.strategy-header h3{color:#333;margin:0;font-size:20px;font-weight:600}.generate-strategy-btn{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.generate-strategy-btn:hover:not(:disabled){background:#0b7c72;transform:translateY(-1px);box-shadow:0 4px 8px #0d94884d}.generate-strategy-btn:disabled{cursor:not-allowed;background:#ccc;transform:none}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.strategy-section{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 8px #00000014}.strategy-section h4{color:#333;margin:0 0 16px;font-size:16px;font-weight:600}.hook-filters{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.filter-btn{color:#666;cursor:pointer;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .2s}.filter-btn:hover{background:#ebebeb;border-color:#0d9488}.filter-btn.active{color:#fff;background:#0d9488;border-color:#0d9488}.hooks-list{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;display:grid}.hook-card{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:14px;transition:all .2s;position:relative}.hook-card:hover{border-color:#0d9488;transform:translateY(-2px);box-shadow:0 2px 8px #0d948826}.hook-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.hook-type{color:#0d9488;background:#0d94881a;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:600}.hook-status{color:#fff;border-radius:10px;padding:3px 8px;font-size:11px;font-weight:500}.hook-status.status-待测试{background:#999}.hook-status.status-测试中{background:#2196f3}.hook-status.status-已验证{background:#4caf50}.hook-status.status-已否定{background:#f44336}.hook-expression{color:#333;margin-bottom:10px;font-size:14px;font-weight:500;line-height:1.6}.hook-meta{color:#999;gap:12px;font-size:12px;display:flex}.hook-layer,.hook-trigger{align-items:center;display:flex}.penetration-matrix{flex-direction:column;gap:16px;display:flex}.matrix-summary{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;display:grid}.summary-card{color:#fff;text-align:center;background:linear-gradient(135deg,#0d9488 0%,#0b7c72 100%);border-radius:8px;padding:16px}.summary-label{opacity:.9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:12px}.summary-value{font-family:JetBrains Mono,SF Mono,Roboto Mono,monospace;font-size:24px;font-weight:700}.matrix-note{color:#666;text-align:center;background:#f9f9f9;border-radius:6px;padding:12px;font-size:13px}.penetration-conclusions{min-height:100px}.conclusions-list{flex-direction:column;gap:12px;display:flex}.conclusion-card{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:16px}.conclusion-badge{color:#16a34a;margin-bottom:8px;font-size:12px;font-weight:600}.conclusion-hook{color:#333;margin-bottom:8px;font-size:15px;font-weight:500;line-height:1.6}.conclusion-meta{color:#666;font-size:12px}.empty-state{text-align:center;color:#999;padding:40px 20px;font-size:14px}.empty-state .hint{color:#bbb;margin-top:8px;font-size:13px}.seeding-strategy-empty{color:#999;justify-content:center;align-items:center;height:100%;font-size:16px;display:flex}@media (width<=768px){.hooks-list{grid-template-columns:1fr}.matrix-summary{grid-template-columns:repeat(2,1fr)}.hook-filters{flex-direction:column}.filter-btn{width:100%}}.conversion-strategy{background:#fafafa;flex-direction:column;gap:24px;height:100%;padding:20px;display:flex;overflow-y:auto}.feedback-signals{flex-direction:column;gap:12px;display:flex}.feedback-signal{border-radius:8px;padding:16px;animation:.3s ease-out slideIn;box-shadow:0 2px 8px #0000001a}.feedback-signal.high-conversion{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:2px solid #f59e0b}.feedback-signal.traffic-burst{background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border:2px solid #3b82f6}.signal-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.signal-title{color:#333;font-size:16px;font-weight:600}.dismiss-btn{cursor:pointer;color:#666;background:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;transition:all .2s;display:flex}.dismiss-btn:hover{color:#333;background:#0003}.signal-message{color:#333;margin-bottom:8px;font-size:14px;line-height:1.6}.signal-meta{color:#666;font-family:JetBrains Mono,SF Mono,Roboto Mono,monospace;font-size:12px}.buypoints-container{grid-template-columns:1fr 1fr;gap:20px;display:grid}.buypoints-category h5{color:#333;margin:0 0 12px;font-size:15px;font-weight:600}.buypoints-list{flex-direction:column;gap:10px;display:flex}.buypoint-card{background:#fff;border:1px solid #e0e0e0;border-left:4px solid #0d9488;border-radius:6px;padding:12px;transition:all .2s;position:relative}.buypoint-card.rational{border-left-color:#2196f3}.buypoint-card.emotional{border-left-color:#f06292}.buypoint-card:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.buypoint-expression{color:#333;margin-bottom:8px;font-size:14px;font-weight:500;line-height:1.6}.buypoint-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.buypoint-layer,.buypoint-trigger{color:#666;background:#f5f5f5;border-radius:10px;padding:2px 8px;font-size:11px}.buypoint-status{color:#fff;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.buypoint-status.status-待测试{background:#999}.buypoint-status.status-测试中{background:#2196f3}.buypoint-status.status-已验证{background:#4caf50}.buypoint-status.status-已否定{background:#f44336}.channels-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.channel-card{background:#fff!important;border:1px solid #e0e0e0!important;border-radius:8px!important;padding:16px!important;transition:all .2s!important}.channel-card:hover{border-color:#0d9488!important;transform:translateY(-2px)!important;box-shadow:0 4px 12px #0d948826!important}.channel-card.is-empty{background:#fafafa!important;align-items:center!important;height:40px!important;min-height:40px!important;padding:0 14px!important;display:flex!important}.channel-card.is-empty:hover{box-shadow:none!important;border-color:#e0e0e0!important;transform:none!important}.channel-header{border-bottom:1px solid #f0f0f0;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:12px;display:flex}.channel-card.is-empty .channel-header{border-bottom:none!important;gap:6px!important;width:100%!important;margin-bottom:0!important;padding-bottom:0!important}.channel-icon{font-size:24px}.channel-card.is-empty .channel-icon{font-size:18px!important}.channel-name{color:#333;font-size:14px;font-weight:600}.channel-card.is-empty .channel-name{font-size:13px!important;font-weight:500!important}.channel-empty-status{color:#999!important;white-space:nowrap!important;margin-left:auto!important;font-size:12px!important}.buypoint-effects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.buypoint-effect-card{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:14px;transition:all .2s}.buypoint-effect-card:hover{border-color:#0d9488;transform:translateY(-2px);box-shadow:0 2px 8px #0d948826}.effect-card-header{border-bottom:1px solid #e0e0e0;margin-bottom:12px;padding-bottom:10px}.effect-expression{color:#333;margin-bottom:4px;font-size:14px;font-weight:600;line-height:1.4}.effect-meta{color:#999;font-size:12px}.effect-metrics{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;display:grid}.effect-metric-item{flex-direction:column;gap:4px;display:flex}.effect-metric-label{color:#999;text-transform:uppercase;font-size:11px}.effect-metric-value{color:#0d9488;font-size:16px;font-weight:600}.effect-card-footer{color:#999;border-top:1px solid #f0f0f0;padding-top:8px;font-size:11px}.channel-metrics{flex-direction:column;gap:8px;display:flex}.channel-metrics .metric-item{justify-content:space-between;align-items:center;gap:12px;min-width:0;display:flex}.channel-metrics .metric-label{color:#999!important;text-transform:none!important;letter-spacing:normal!important;flex-shrink:0!important;font-size:11px!important}.channel-metrics .metric-value{color:#0d9488!important;text-align:right!important;min-width:0!important;font-family:JetBrains Mono,SF Mono,Roboto Mono,monospace!important;font-size:14px!important;font-weight:600!important;line-height:1.2!important}.attribution-container{min-height:200px}.attribution-table-wrapper{border:1px solid #e0e0e0;border-radius:6px;overflow-x:auto}.attribution-table{border-collapse:collapse;width:100%;font-size:14px}.attribution-table thead{color:#fff;background:#1a1a2e}.attribution-table th{text-align:left;white-space:nowrap;padding:12px;font-size:13px;font-weight:600}.attribution-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.attribution-table tbody tr:hover{background:#fafafa}.attribution-table td{color:#555;padding:12px}.channel-cell{color:#333;font-weight:500}.number-cell{text-align:right;font-family:SF Mono,Monaco,Courier New,monospace}.number-cell.highlight{color:#0d9488;font-weight:600}.conversion-strategy-empty{color:#999;justify-content:center;align-items:center;height:100%;font-size:16px;display:flex}@media (width<=1024px){.buypoints-container{grid-template-columns:1fr}.channels-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.channels-grid{grid-template-columns:1fr}.attribution-table-wrapper{overflow-x:scroll}.attribution-table{min-width:600px}}.matrix-tag-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.matrix-tag-label{color:#999;flex-shrink:0;font-size:11px;font-weight:500}.matrix-tag-list{flex-wrap:wrap;gap:6px;display:flex}.matrix-tag{white-space:nowrap;border-radius:10px;padding:3px 8px;font-size:11px;font-weight:500}.matrix-tag.form-graphic{color:#1e40af;background:#dbeafe}.matrix-tag.form-video{color:#6b21a8;background:#e9d5ff}.matrix-tag.form-live{color:#991b1b;background:#fee2e2}.matrix-tag.form-social-copy{color:#065f46;background:#d1fae5}.matrix-tag.form-shelf-copy{color:#9a3412;background:#fed7aa}.matrix-tag.form-default{color:#6b7280;background:#f3f4f6}.matrix-tag.channel{color:#0f766e;background:#f0fdfa;border:1px solid #99f6e4}.matrix-tag.stage{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.matrix-tags-container{margin-top:10px}.card-generate-btn{color:#0d9488;cursor:pointer;background:#ecfdf5;border:1px solid #99f6e4;border-radius:999px;margin-top:12px;margin-left:auto;padding:6px 12px;font-size:12px;font-weight:600;transition:all .2s;display:block}.card-generate-btn:hover{background:#ccfbf1;border-color:#5eead4}.card-work-order-panel{border-top:1px dashed #d1d5db;margin-top:12px;padding-top:12px}:root{--header-height:56px;--color-primary:#1a1a2e;--color-primary-light:#2d2d44;--color-primary-dark:#0f0f1a;--color-bg-base:#fafaf8;--color-bg-card:#fff;--color-bg-elevated:#fff;--color-accent:#0d9488;--color-accent-light:#14b8a6;--color-accent-dark:#0f766e;--color-amber:#d97706;--color-amber-light:#f59e0b;--color-amber-dark:#b45309;--color-success:#059669;--color-warning:#dc2626;--color-info:#0d9488;--color-text-primary:#1a1a2e;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-text-inverse:#fff;--color-border-light:#e5e5e5;--color-border-medium:#d1d5db;--color-border-dark:#9ca3af;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 2px 8px #0000001a;--shadow-lg:0 4px 16px #0000001f;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--font-sans:-apple-system, BlinkMacSystemFont, "PingFang SC", "Noto Sans SC", "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-mono:"JetBrains Mono", "SF Mono", "Roboto Mono", "Consolas", "Monaco", monospace;--text-xs:11px;--text-sm:13px;--text-base:14px;--text-lg:16px;--text-xl:18px;--text-2xl:24px;--text-3xl:32px;--text-4xl:40px;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--leading-tight:1.2;--leading-normal:1.5;--leading-relaxed:1.75}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--color-text-primary);background:var(--color-bg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.metric-value,.data-number,.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.app-header{background:var(--color-primary);height:56px;color:var(--color-text-inverse);padding:0 var(--spacing-xl);box-shadow:var(--shadow-sm);z-index:1000;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.app-header .brand{align-items:baseline;gap:var(--spacing-sm);display:flex}.app-header .brand-name{font-size:var(--text-xl);font-weight:var(--font-bold);letter-spacing:-.02em}.app-header .brand-name-en{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.app-header nav{gap:var(--spacing-xl);display:flex}.app-header nav a,.app-header nav button{color:var(--color-text-inverse);font-size:var(--text-base);font-weight:var(--font-medium);padding:var(--spacing-sm) 0;cursor:pointer;opacity:.7;background:0 0;border:none;border-bottom:2px solid #0000;text-decoration:none;transition:opacity .2s}.app-header nav a:hover,.app-header nav button:hover{opacity:1}.app-header nav a.active,.app-header nav button.active{opacity:1;border-bottom-color:var(--color-accent)}.card{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);transition:box-shadow .2s}.card:hover{box-shadow:var(--shadow-sm)}.card-elevated{background:var(--color-bg-card);box-shadow:var(--shadow-sm);border-radius:var(--radius-md);padding:var(--spacing-lg);border:none}.card-warning{border-left:3px solid var(--color-warning)}.metric-card{gap:var(--spacing-xs);flex-direction:column;display:flex}.metric-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text-primary);line-height:var(--leading-tight)}.metric-value.accent{color:var(--color-accent)}.metric-value.success{color:var(--color-success)}.metric-value.warning{color:var(--color-warning)}.metric-change{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-secondary)}.metric-change.positive{color:var(--color-success)}.metric-change.negative{color:var(--color-warning)}.btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--text-base);font-weight:var(--font-medium);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;transition:all .2s;display:inline-flex}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-light)}.btn-accent{background:var(--color-accent);color:var(--color-text-inverse)}.btn-accent:hover:not(:disabled){background:var(--color-accent-light)}.btn-secondary{color:var(--color-text-primary);border:1px solid var(--color-border-medium);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--color-bg-base)}.btn:disabled{opacity:.5;cursor:not-allowed}.table{border-collapse:collapse;background:var(--color-bg-card);width:100%}.table thead{border-bottom:1px solid var(--color-border-light)}.table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.table td{padding:var(--spacing-md);font-size:var(--text-base);color:var(--color-text-primary);border-bottom:1px solid var(--color-border-light)}.table tbody tr:hover{background:var(--color-bg-base)}.table tbody tr:last-child td{border-bottom:none}.tag{padding:2px var(--spacing-sm);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-sm);background:var(--color-bg-base);color:var(--color-text-secondary);align-items:center;display:inline-flex}.tag-accent{color:var(--color-accent-dark);background:#0d94881a}.tag-success{color:var(--color-success);background:#0596691a}.tag-warning{color:var(--color-warning);background:#dc26261a}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-4xl{font-size:var(--text-4xl)}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s ease-out fadeIn}@media (width<=768px){.app-header{padding:0 var(--spacing-md)}.app-header nav{gap:var(--spacing-md)}.metric-value{font-size:var(--text-2xl)}}.app{background:var(--color-bg-base);flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{height:var(--header-height);background:var(--color-primary);color:var(--color-text-inverse);padding:0 var(--spacing-xl);box-shadow:var(--shadow-sm);z-index:1000;justify-content:space-between;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.header-left{align-items:baseline;gap:var(--spacing-lg);display:flex}.header-left .brand{align-items:baseline;gap:var(--spacing-sm);display:flex}.header-left .brand-name{font-size:var(--text-xl);font-weight:var(--font-bold);letter-spacing:-.02em;color:var(--color-text-inverse)}.header-left .brand-name-en{font-size:var(--text-xs);font-weight:var(--font-medium);color:#ffffff80;text-transform:uppercase;letter-spacing:.05em}.header-left .back-btn{padding:var(--spacing-xs) var(--spacing-md);color:var(--color-text-inverse);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);background:#ffffff1a;border:none;transition:background .2s}.header-left .back-btn:hover{background:#ffffff26}.header-nav{gap:var(--spacing-xl);align-items:center;display:flex}.nav-link{color:var(--color-text-inverse);font-size:var(--text-base);font-weight:var(--font-medium);padding:var(--spacing-sm) 0;cursor:pointer;opacity:.7;background:0 0;border:none;border-bottom:2px solid #0000;text-decoration:none;transition:opacity .2s}.nav-link:hover:not(:disabled){opacity:1}.nav-link.active{opacity:1;border-bottom-color:var(--color-accent)}.nav-link:disabled{opacity:.3;cursor:not-allowed}.header-right{align-items:center;gap:var(--spacing-md);display:flex}.user-info{align-items:center;gap:var(--spacing-md);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);background:#ffffff1a;display:flex}.user-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-inverse)}.logout-btn{padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-text-inverse);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);font-weight:var(--font-medium);background:#ffffff26;border:1px solid #fff3;transition:all .2s}.logout-btn:hover{background:#ffffff40;border-color:#ffffff4d}.main-content{padding:var(--spacing-xl);flex:1;margin-top:56px;overflow-y:auto}.product-list-container{max-width:1400px;margin:0 auto}.product-list-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;display:flex}.product-list-header h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text-primary)}.product-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.product-card{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-lg);cursor:pointer;transition:all .2s}.product-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border-medium)}.product-card.low-new-customer{border-left:3px solid var(--color-warning)}.product-card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light)}.product-name{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-xs);line-height:var(--leading-tight)}.product-category{padding:2px var(--spacing-sm);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-sm);background:var(--color-bg-base);color:var(--color-text-secondary);align-items:center;display:inline-flex}.product-metrics{gap:var(--spacing-md);margin-bottom:var(--spacing-md);grid-template-columns:repeat(2,1fr);display:grid}.product-metric{gap:var(--spacing-xs);flex-direction:column;display:flex}.product-metric-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.product-metric-value{font-family:var(--font-mono);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-text-primary);line-height:var(--leading-tight)}.product-metric-value.accent{color:var(--color-accent)}.product-metric-value.success{color:var(--color-success)}.product-metric-value.warning{color:var(--color-warning)}.product-card-footer{padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light);font-size:var(--text-sm);color:var(--color-text-secondary);justify-content:space-between;align-items:center;display:flex}.war-room{gap:var(--spacing-lg);height:100vh;padding-top:var(--header-height);box-sizing:border-box;grid-template-columns:400px 1fr;display:grid}.left-panel{gap:var(--spacing-lg);padding:var(--spacing-lg);flex-direction:column;display:flex;overflow-y:auto}.back-link{color:var(--color-text-secondary);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;background:0 0;border:none;align-self:flex-start;align-items:center;gap:4px;padding:0;transition:color .2s;display:inline-flex}.back-link:hover{color:var(--color-accent);text-decoration:underline}.right-panel{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-md);flex-direction:column;display:flex;overflow:hidden}.product-title{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-lg)}.product-title h2{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-primary);line-height:var(--leading-tight)}.info-card{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-lg)}.card-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.card-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary)}.smart-complete-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);border:none;transition:background .2s;position:relative}.smart-complete-btn.loading{padding-left:40px}.smart-complete-btn .spinner{animation:1s linear infinite spin;position:absolute;left:12px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.smart-complete-btn:hover:not(:disabled){background:var(--color-accent-light)}.smart-complete-btn:disabled{opacity:.5;cursor:not-allowed}.info-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(120px,1fr));display:grid}.info-item{gap:var(--spacing-xs);flex-direction:column;display:flex}.info-item label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.info-item span{font-size:var(--text-base);color:var(--color-text-primary)}.description{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border-light)}.description label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-xs);display:block}.description p{font-size:var(--text-sm);color:var(--color-text-primary);line-height:var(--leading-relaxed)}.warroom-tabs{padding:0 var(--spacing-lg);background:var(--color-bg-card);border-bottom:1px solid var(--color-border-light);gap:0;display:flex}.tab-btn{padding:var(--spacing-md) var(--spacing-lg);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text-secondary);background:0 0;border:none;border-bottom:2px solid #0000;transition:all .2s}.tab-btn:hover{color:var(--color-text-primary)}.tab-btn.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.hypothesis-tab-content{background:var(--color-bg-card);flex:1;overflow-y:auto}.chat-window{flex-direction:column;height:100%;display:flex}.chat-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.chat-header h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary)}.generate-plan-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);border:none;transition:background .2s}.generate-plan-btn:hover:not(:disabled){background:var(--color-accent-light)}.generate-plan-btn:disabled{opacity:.5;cursor:not-allowed}.messages-container{padding:var(--spacing-lg);gap:var(--spacing-md);flex-direction:column;flex:1;display:flex;overflow-y:auto}.empty-state{text-align:center;height:100%;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state p{font-size:var(--text-base);margin-bottom:var(--spacing-sm)}.empty-state .hint{font-size:var(--text-sm);color:var(--color-text-tertiary);line-height:var(--leading-relaxed)}.message{gap:var(--spacing-xs);flex-direction:column;animation:.3s ease-out fadeIn;display:flex}.message.user{align-items:flex-end}.message.assistant{align-items:flex-start}.message-content{max-width:80%;padding:var(--spacing-md);border-radius:var(--radius-md);font-size:var(--text-base);line-height:var(--leading-relaxed)}.message.user .message-content{background:var(--color-primary);color:var(--color-text-inverse)}.message.assistant .message-content{background:var(--color-bg-base);color:var(--color-text-primary);border:1px solid var(--color-border-light)}.message-content p{margin-bottom:var(--spacing-sm)}.message-content p:last-child{margin-bottom:0}.loading-indicator{color:var(--color-text-secondary);font-style:italic}.input-container{gap:var(--spacing-md);padding:var(--spacing-lg);border-top:1px solid var(--color-border-light);background:var(--color-bg-card);display:flex}.input-container textarea{padding:var(--spacing-md);border:1px solid var(--color-border-medium);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:var(--text-base);resize:none;flex:1;transition:border-color .2s}.input-container textarea:focus{border-color:var(--color-accent);outline:none}.input-container button{padding:var(--spacing-md) var(--spacing-lg);background:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);border:none;transition:background .2s}.input-container button:hover:not(:disabled){background:var(--color-accent-light)}.input-container button:disabled{opacity:.5;cursor:not-allowed}.loading{padding:var(--spacing-2xl);font-size:var(--text-lg);color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.error-page{justify-content:center;align-items:center;gap:var(--spacing-lg);text-align:center;flex-direction:column;height:100vh;display:flex}.error-page h1{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text-primary)}.error-page p{font-size:var(--text-lg);color:var(--color-text-secondary)}.error-page button{padding:var(--spacing-md) var(--spacing-xl);background:var(--color-accent);color:var(--color-text-inverse);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-medium);border:none;transition:background .2s}.error-page button:hover{background:var(--color-accent-light)}.mobile-menu-btn{cursor:pointer;padding:var(--spacing-xs);z-index:1001;background:0 0;border:none;display:none}.hamburger{flex-direction:column;gap:4px;width:24px;display:flex}.hamburger span{background:var(--color-text-inverse);width:100%;height:2px;transition:all .3s;display:block}.hamburger.open span:first-child{transform:rotate(45deg)translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg)translate(6px,-6px)}.mobile-menu-overlay{z-index:999;background:#00000080;animation:.3s fadeIn;position:fixed;inset:0}@media (width<=1024px){.war-room{grid-template-columns:1fr}.left-panel{max-height:50vh}}@media (width<=768px){.app-header{padding:0 var(--spacing-md)}.mobile-menu-btn{display:block}.header-nav{background:var(--color-primary);width:70%;max-width:320px;height:calc(100vh - 48px);padding:var(--spacing-lg) 0;z-index:1000;flex-direction:column;align-items:stretch;gap:0;transition:right .3s;position:fixed;top:48px;right:-100%;box-shadow:-2px 0 8px #0003}.header-nav.mobile-open{right:0}.nav-link{padding:16px var(--spacing-xl);border-bottom:none;border-left:3px solid #0000;min-height:48px;font-size:16px}.nav-link.active{border-bottom:none;border-left-color:var(--color-accent);background:#ffffff1a}.nav-link.desktop-only{display:flex}.app-header{height:48px;padding:0 12px}.header-left .brand-name-en{display:none}.header-left .brand-name{font-size:16px}.user-name{text-overflow:ellipsis;white-space:nowrap;max-width:60px;overflow:hidden}.logout-btn{min-width:44px;min-height:44px;padding:8px;font-size:0}.logout-btn:before{content:"⎋";font-size:18px;display:inline-block}button,.btn,a,input[type=submit]{min-width:44px;min-height:44px}input,textarea,select{min-height:44px;font-size:16px}.main-content{padding:var(--spacing-md);margin-top:48px}.product-grid,.product-metrics{grid-template-columns:1fr}}.selling-points-system{margin-top:20px}.selling-layer{background:#f9f9f9;border-radius:8px;margin-bottom:30px;padding:20px}.layer-title{color:#333;border-bottom:2px solid #0d9488;margin-bottom:15px;padding-bottom:10px;font-size:18px;font-weight:600}.facts-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:15px;display:grid}.fact-card{background:#fff;border-left:4px solid #4caf50;border-radius:6px;padding:15px;transition:transform .2s,box-shadow .2s;box-shadow:0 2px 4px #0000000d}.fact-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.fact-category{color:#fff;background:#4caf50;border-radius:12px;margin-bottom:8px;padding:3px 10px;font-size:12px;display:inline-block}.fact-text{color:#555;margin:0;font-size:14px;line-height:1.6}.translations-list{flex-direction:column;gap:20px;display:flex}.translation-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 6px #00000014}.translation-fact{color:#333;background:#f0f0f0;border-radius:6px;margin-bottom:15px;padding:12px;font-size:15px}.translation-fact strong{color:#0d9488}.translation-values{flex-direction:column;gap:12px;display:flex}.value-item{border-left:4px solid;border-radius:6px;padding:12px}.value-item.core{background:#e8f5e9;border-left-color:#4caf50}.value-item.extended{background:#fff3e0;border-left-color:#ff9800}.value-item.breakthrough{background:#f3e5f5;border-left-color:#9c27b0}.value-label{color:#555;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.value-item p{color:#666;margin:0;font-size:14px;line-height:1.6}.reasons-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;display:grid}.reason-card{background:#fff;border-left:5px solid;border-radius:8px;padding:20px;box-shadow:0 2px 6px #00000014}.reason-card.core{border-left-color:#4caf50}.reason-card.extended{border-left-color:#ff9800}.reason-card.breakthrough{border-left-color:#9c27b0}.reason-card h5{color:#333;border-bottom:1px solid #eee;margin-bottom:15px;padding-bottom:10px;font-size:16px}.reason-section{margin-bottom:15px}.reason-section strong{color:#555;margin-bottom:8px;font-size:14px;display:block}.reason-section ul{margin:0;padding:0;list-style:none}.reason-section li{color:#666;padding:8px 0 8px 20px;font-size:13px;line-height:1.6;position:relative}.reason-section li:before{content:"•";color:#0d9488;font-weight:700;position:absolute;left:8px}.reason-card .note{color:#856404;background:#fff3cd;border-radius:4px;margin-top:10px;padding:4px 10px;font-size:12px;display:inline-block}.selling-stats{color:#fff;text-align:center;background:#0d9488;border-radius:8px;margin-top:20px;padding:15px}.selling-stats p{margin:0;font-size:16px}.selling-stats strong{margin:0 5px;font-size:24px}@media (width<=768px){.facts-grid,.reasons-grid{grid-template-columns:1fr}.translation-values{gap:10px}}.product-info-layers-content{flex-direction:column;gap:10px;display:flex}.layer-section{border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.layer-header{cursor:pointer;background:#f5f5f5;justify-content:space-between;align-items:center;padding:12px 16px;transition:background .2s;display:flex}.layer-header:hover{background:#ebebeb}.layer-name{color:#333;font-size:14px;font-weight:600}.layer-toggle{color:#666;font-size:12px}.layer-items{margin:0;padding:0;list-style:none}.layer-items li{color:#555;border-top:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:10px 16px;font-size:14px;line-height:1.6;display:flex}.layer-items li .item-text{flex:1}.source-badge{border-radius:4px;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.source-badge.ai{color:#666;background:#e0e0e0}.source-badge.manual{color:#1976d2;background:#e3f2fd}.add-item-form{background:#fafafa;border-top:1px solid #f0f0f0;gap:8px;padding:12px 16px;display:flex}.add-item-form input{border:1px solid #ddd;border-radius:4px;flex:1;padding:6px 12px;font-size:14px}.add-item-form button{cursor:pointer;border:none;border-radius:4px;padding:6px 16px;font-size:13px;font-weight:500;transition:background .2s}.add-item-form button:first-of-type{color:#fff;background:#0d9488}.add-item-form button:first-of-type:hover:not(:disabled){background:#0f766e}.add-item-form button:first-of-type:disabled{opacity:.5;cursor:not-allowed}.add-item-form button:last-of-type{color:#666;background:#e0e0e0}.add-item-form button:last-of-type:hover{background:#d0d0d0}.add-item-btn{color:#666;cursor:pointer;background:#f5f5f5;border:1px dashed #ccc;border-radius:4px;margin:8px 16px;padding:6px 12px;font-size:13px;transition:all .2s}.add-item-btn:hover{color:#0d9488;background:#e8f5e9;border-color:#0d9488}.layer-items li:first-child{border-top:none}@media (width<=768px){.product-info-layers-content{gap:8px}.layer-section{border-radius:4px}.layer-header{padding:10px 12px;font-size:13px}.layer-name{font-size:13px}.layer-items li{padding:8px 12px;font-size:13px}.layer-items{max-height:0;transition:max-height .3s ease-out;overflow:hidden}.layer-section.expanded .layer-items{max-height:2000px;transition:max-height .3s ease-in}}.audience-needs-content{flex-direction:column;gap:24px;display:flex}.needs-section h4{color:#333;border-bottom:2px solid #0d9488;margin:0 0 16px;padding-bottom:8px;font-size:16px;font-weight:600}.motives-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;display:grid}.motive-card{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;padding:12px}.motive-label{color:#0d9488;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:12px;font-weight:600}.motive-value{color:#555;font-size:14px;line-height:1.5}.triggers-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;display:grid}.trigger-card{background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:12px}.trigger-label{color:#333;margin-bottom:8px;font-size:13px;font-weight:600}.trigger-items{margin:0;padding:0;list-style:none}.trigger-items li{color:#666;padding:4px 0 4px 12px;font-size:13px;line-height:1.5;position:relative}.trigger-items li:before{content:"•";color:#0d9488;font-weight:700;position:absolute;left:0}.scenarios-list{flex-direction:column;gap:16px;display:flex}.scenario-card{background:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:16px}.scenario-description{color:#333;margin-bottom:12px;font-size:15px;font-weight:600;line-height:1.6}.scenario-details{flex-direction:column;gap:10px;display:flex}.scenario-motive,.scenario-factors{color:#555;font-size:14px}.scenario-motive strong,.scenario-factors strong{color:#0d9488;margin-right:6px}.scenario-factors ul{margin:6px 0 0;padding:0;list-style:none}.scenario-factors li{padding:4px 0 4px 16px;position:relative}.scenario-factors li:before{content:"→";color:#0d9488;position:absolute;left:0}.content-matrix-content{flex-direction:column;gap:16px;display:flex}.matrix-filters{background:#f5f5f5;border-radius:6px;flex-wrap:wrap;align-items:center;gap:12px;padding:12px;display:flex}.matrix-filters select{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:6px 12px;font-size:14px}.matrix-filters select:hover{border-color:#0d9488}.matrix-count{color:#666;margin-left:auto;font-size:13px;font-weight:500}.matrix-table-wrapper{border:1px solid #e0e0e0;border-radius:6px;overflow-x:auto}.matrix-table{border-collapse:collapse;width:100%;font-size:14px}.matrix-table thead{color:#fff;background:#1a1a2e}.matrix-table th{text-align:left;white-space:nowrap;padding:12px;font-size:13px;font-weight:600}.matrix-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .2s}.matrix-table tbody tr:hover{background:#fafafa}.matrix-table td{color:#555;vertical-align:top;padding:12px}.matrix-layer,.matrix-trigger,.matrix-module{color:#333;white-space:nowrap;font-weight:500}.matrix-expression{max-width:400px;line-height:1.6}.matrix-status{text-align:center}.status-badge{color:#fff;border-radius:12px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}@media (width<=768px){.motives-grid,.triggers-grid{grid-template-columns:1fr}.matrix-filters{flex-direction:column;align-items:stretch}.matrix-count{margin-left:0}.matrix-table-wrapper{overflow-x:scroll}.matrix-table{min-width:800px}}.ip-selector{align-items:center;margin-left:20px;display:flex}.ip-select{color:#fff;cursor:pointer;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;outline:none;min-height:44px;padding:6px 12px;font-size:14px;transition:all .2s}.ip-select:hover{background-color:#ffffff26;border-color:#ffffff4d}.ip-select:focus{border-color:#0d9488;box-shadow:0 0 0 2px #0d948833}.ip-select option{color:#fff;background-color:#1a1a2e}@media (width<=768px){.ip-selector{margin-left:8px}.ip-select{max-width:100px;padding:4px 8px;font-size:13px}.ip-platform{display:none}}.login-page{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container{background:#fff;border-radius:12px;width:100%;max-width:420px;padding:48px 40px;animation:.4s ease-out fadeIn;box-shadow:0 8px 32px #0000004d}.login-header{text-align:center;margin-bottom:40px}.login-header h1{color:#1a1a2e;letter-spacing:-.5px;margin:0 0 8px;font-size:32px;font-weight:700}.login-header p{color:#0d9488;text-transform:uppercase;letter-spacing:1px;margin:0;font-size:14px;font-weight:500}.login-form{flex-direction:column;gap:24px;display:flex}.login-error{color:#dc2626;text-align:center;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;padding:12px 16px;font-size:14px;animation:.3s ease-out shake}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.form-group{flex-direction:column;gap:8px;display:flex}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input{border:2px solid #e5e7eb;border-radius:8px;outline:none;padding:12px 16px;font-size:15px;transition:all .2s}.form-group input:focus{border-color:#0d9488;box-shadow:0 0 0 3px #0d94881a}.form-group input::placeholder{color:#9ca3af}.login-button{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:8px;margin-top:8px;padding:14px 24px;font-size:16px;font-weight:600;transition:all .2s}.login-button:hover:not(:disabled){background:#0b7c72;transform:translateY(-1px);box-shadow:0 4px 12px #0d94884d}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;background:#9ca3af;transform:none}.login-footer{text-align:center;border-top:1px solid #e5e7eb;margin-top:32px;padding-top:24px}.login-footer p{color:#6b7280;margin:0;font-size:13px}@media (width<=480px){.login-container{padding:32px 24px}.login-header h1{font-size:28px}.login-header p{font-size:12px}}.ip-management{max-width:1400px;margin:0 auto;padding:76px 20px 20px}.page-header h1{color:#1a1a2e;font-size:24px;font-weight:600}.ip-list{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;display:grid}.ip-card{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .2s}.ip-card:hover{border-color:#0d9488;box-shadow:0 4px 12px #0d94881a}.ip-card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.ip-card-header h3{color:#1a1a2e;font-size:18px;font-weight:600}.status-badge{border-radius:12px;padding:4px 12px;font-size:12px;font-weight:500}.ip-card-body{color:#6b7280}.ip-info{gap:10px;margin-bottom:10px;display:flex}.platform-tag{color:#374151;background:#f3f4f6;border-radius:6px;padding:4px 10px;font-size:13px}.faces-count{color:#92400e;background:#fef3c7;border-radius:6px;padding:4px 10px;font-size:13px}.ip-description{color:#6b7280;margin:0;font-size:14px;line-height:1.5}.ip-form{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-width:800px;padding:30px}.form-group label{color:#374151;margin-bottom:8px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid #d1d5db;border-radius:6px;width:100%;padding:10px;font-size:14px}.form-group textarea{font-family:Monaco,Menlo,Courier New,monospace;font-size:13px}.faces-list{flex-wrap:wrap;gap:8px;display:flex}.face-tag{background:#f3f4f6;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:14px;display:flex}.face-tag button{color:#6b7280;cursor:pointer;background:0 0;border:none;padding:0;font-size:18px;line-height:1}.btn-add-face{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:6px;padding:6px 12px;font-size:14px}.form-actions{gap:10px;margin-top:30px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#0d9488;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500}.btn-secondary{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500}.btn-secondary:hover{background:#f9fafb}.loading{text-align:center;color:#6b7280;padding:40px}@media (width<=768px){.ip-management{padding:60px 12px 12px}.page-header{flex-direction:column;gap:12px}.page-header h1{font-size:20px}.btn-primary{width:100%;min-height:48px;font-size:16px}.ip-list{gap:12px}.ip-card{padding:16px}.ip-card-header h3{font-size:16px}.ip-form{padding:16px}.form-group label{font-size:15px}.form-group input,.form-group select,.form-group textarea{min-height:48px;font-size:16px}.faces-list{gap:8px}.face-tag{padding:8px 12px;font-size:14px}.btn-add-face{min-height:44px;font-size:14px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;min-height:48px;font-size:16px}}.user-management{max-width:1400px;margin:0 auto;padding:76px 20px 20px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{color:#1a1a1a;margin:0;font-size:24px;font-weight:600}.user-table-container{background:#fff;border-radius:8px;overflow-x:auto;box-shadow:0 1px 3px #0000001a}.user-table{border-collapse:collapse;width:100%}.user-table thead{background:#f8f9fa}.user-table th{text-align:left;color:#495057;border-bottom:2px solid #dee2e6;padding:12px 16px;font-size:14px;font-weight:600}.user-table td{color:#212529;border-bottom:1px solid #e9ecef;padding:12px 16px;font-size:14px}.user-table tbody tr:hover{background:#f8f9fa}.user-table tbody tr.disabled-row{opacity:.6;background:#f8f9fa}.role-badge{border-radius:12px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.role-badge.admin{color:#1976d2;background:#e3f2fd}.role-badge.host{color:#7b1fa2;background:#f3e5f5}.role-badge.supply{color:#388e3c;background:#e8f5e9}.role-badge.service{color:#f57c00;background:#fff3e0}.status-badge{border-radius:12px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-block}.status-badge.active{color:#2e7d32;background:#e8f5e9}.status-badge.inactive{color:#c62828;background:#ffebee}.actions{gap:8px;display:flex}.actions button{cursor:pointer;border:none;border-radius:4px;padding:6px 12px;font-size:13px;transition:all .2s}.btn-edit{color:#1976d2;background:#e3f2fd}.btn-edit:hover{background:#bbdefb}.btn-toggle.disable{color:#c62828;background:#ffebee}.btn-toggle.disable:hover{background:#ffcdd2}.btn-toggle.enable{color:#2e7d32;background:#e8f5e9}.btn-toggle.enable:hover{background:#c8e6c9}.btn-reset{color:#f57c00;background:#fff3e0}.btn-reset:hover{background:#ffe0b2}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-header{border-bottom:1px solid #e9ecef;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:#1a1a1a;margin:0;font-size:20px;font-weight:600}.close-btn{color:#6c757d;cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:28px;display:flex}.close-btn:hover{color:#212529;background:#f8f9fa}.user-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#495057;margin-bottom:8px;font-size:14px;font-weight:500;display:block}.form-group input,.form-group select{border:1px solid #ced4da;border-radius:4px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.form-group input:focus,.form-group select:focus{border-color:#1976d2;outline:none}.form-group input:disabled{cursor:not-allowed;background:#e9ecef}.permissions-section{border-top:1px solid #e9ecef;margin-top:24px;padding-top:24px}.permissions-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:12px;display:grid}.permission-toggle{cursor:pointer;background:#f8f9fa;border-radius:4px;align-items:center;gap:8px;padding:8px 12px;transition:background .2s;display:flex}.permission-toggle:hover{background:#e9ecef}.permission-toggle input[type=checkbox]{cursor:pointer;width:auto}.toggle-label{color:#495057;-webkit-user-select:none;user-select:none;font-size:14px}.form-actions{border-top:1px solid #e9ecef;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;display:flex}.btn-primary{color:#fff;cursor:pointer;background:#1976d2;border:none;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:500;transition:background .2s}.btn-primary:hover{background:#1565c0}.btn-secondary{color:#495057;cursor:pointer;background:#fff;border:1px solid #ced4da;border-radius:4px;padding:10px 24px;font-size:14px;font-weight:500;transition:all .2s}.btn-secondary:hover{background:#f8f9fa;border-color:#adb5bd}.loading{color:#6c757d;justify-content:center;align-items:center;height:400px;font-size:16px;display:flex}@media (width<=768px){.user-management{min-height:100vh;padding:60px 12px 12px;overflow:auto}.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-header h1{font-size:20px}.btn-primary{width:100%;min-height:48px;font-size:16px}.user-table-container{overflow-x:auto}.user-table{min-width:600px}.user-table th,.user-table td{padding:10px 12px;font-size:13px}.actions{flex-direction:column;gap:4px}.actions button{width:100%;min-height:36px;font-size:12px}.modal-content{width:95%;max-height:95vh}.modal-header h2{font-size:18px}.form-group label{font-size:15px}.form-group input,.form-group select,.form-group textarea{min-height:48px;font-size:16px}.permissions-grid{grid-template-columns:1fr}.permission-toggle{min-height:48px;padding:12px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%;min-height:48px;font-size:16px}}
