.app{min-height:100vh;background:#f7f5f0;display:flex;flex-direction:column}.header{background:#1a1a2e;background-image:radial-gradient(ellipse at 20% 50%,rgba(0,90,120,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 50%,rgba(60,40,20,.12) 0%,transparent 60%);color:#e8e0d0;padding:36px 20px 28px;text-align:center;position:relative}.header-inner{position:relative;z-index:1}.header h1{margin:0;font-size:24px;font-weight:600;letter-spacing:6px;text-indent:6px;color:#d4c9a8}.header-divider{width:48px;height:1px;background:linear-gradient(90deg,transparent,#8a7d60,transparent);margin:16px auto}.mode-nav{display:flex;align-items:center;justify-content:center;gap:0}.mode-nav button{background:none;border:none;color:#7a7060;font-family:inherit;font-size:13px;letter-spacing:3px;text-indent:3px;padding:6px 20px;cursor:pointer;transition:all .2s;position:relative}.mode-nav button:hover{color:#c0b8a0}.mode-nav button.active{color:#d4c9a8}.mode-nav button.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:20px;height:1px;background:#8a7d60}.nav-sep{width:1px;height:14px;background:#3a3a4e}.container{max-width:1400px;margin:0 auto;padding:40px 24px;flex:1;width:100%}.content{display:flex;flex-direction:column;gap:36px}.error-message{background:#fdf2f0;border:1px solid #e8c4be;border-left:3px solid #c0392b;color:#8b2015;padding:16px 20px;border-radius:4px;font-size:14px}.error-message p{margin:0}@media (max-width: 768px){.header{padding:24px 16px 20px}.header h1{font-size:18px;letter-spacing:4px}.container{padding:24px 16px}}.uploader{border:1px dashed #c8bfa8;border-radius:8px;padding:48px 20px;text-align:center;cursor:pointer;transition:all .3s ease;background:#ffffff80}.uploader:hover{border-color:#8a7d60;background:#fffc}.uploader.active{border-color:#5a8a6a;background:#f0f8f099;transform:scale(1.01)}.uploader-content{display:flex;flex-direction:column;align-items:center;gap:12px}.uploader-icon{color:#a09880;margin-bottom:4px}.uploader-title{margin:0;font-size:17px;color:#4a4035;letter-spacing:2px}.uploader-hint{margin:0;color:#a09880;font-size:13px;letter-spacing:1px}.upload-button{display:inline-block;margin-top:8px;padding:10px 32px;background:#2c3e50;color:#e0d8c8;border-radius:4px;cursor:pointer;transition:all .2s;font-size:13px;letter-spacing:3px;text-indent:3px;font-family:inherit}.upload-button:hover{background:#1a2a38}.video-controls{background:#fff9;border:1px solid #e0d8cc;border-radius:6px;padding:20px}.control-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.control-label{font-size:13px;color:#6a6050;letter-spacing:2px;white-space:nowrap}.camera-select{flex:1;min-width:200px;padding:8px 12px;border:1px solid #d0c8b8;border-radius:4px;background:#fff;font-family:inherit;font-size:13px;color:#3a3028;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.camera-select:disabled{opacity:.6}.stream-btn{padding:8px 24px;border:none;border-radius:4px;font-family:inherit;font-size:13px;letter-spacing:2px;cursor:pointer;transition:all .2s;white-space:nowrap}.stream-btn.start{background:#2c3e50;color:#e0d8c8}.stream-btn.start:hover{background:#1a2a38}.stream-btn.start:disabled{opacity:.4;cursor:not-allowed}.stream-btn.stop{background:#8b3a3a;color:#f0e0d8}.stream-btn.stop:hover{background:#6b2a2a}.video-error{margin:12px 0 0;font-size:13px;color:#8b2015}.video-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}@media (max-width: 1024px){.video-layout{grid-template-columns:1fr}}.video-section{position:sticky;top:20px}.video-frame{position:relative;border-radius:6px;overflow:hidden;background:#1a1a2e;box-shadow:0 2px 20px #0000001f;border:1px solid #e0d8cc}.video-element{width:100%;display:block}.video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.video-overlay-label{position:absolute;top:12px;left:12px;background:#1a1a2ecc;color:#d4c9a8;padding:6px 16px;border-radius:3px;font-size:12px;letter-spacing:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.video-info{display:flex;gap:16px;font-size:12px;color:#a09880;letter-spacing:1px}.video-analysis{display:flex;flex-direction:column;gap:20px}.results-container{animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.results-layout{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}@media (max-width: 1024px){.results-layout{grid-template-columns:1fr}}.image-section{display:flex;flex-direction:column;gap:16px;position:sticky;top:20px}.image-frame{border-radius:6px;overflow:hidden;background:#fff;box-shadow:0 2px 20px #00000014;position:relative;border:1px solid #e0d8cc}.preview-image{width:100%;display:block;max-height:600px;object-fit:cover}.image-overlay-label{position:absolute;top:12px;left:12px;background:#1a1a2ecc;color:#d4c9a8;padding:6px 16px;border-radius:3px;font-size:12px;letter-spacing:2px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-info{background:#fff9;padding:14px 18px;border-radius:4px;font-size:13px;color:#8a7d60;border:1px solid #e8e0d4}.image-info p{margin:3px 0}.section-header{display:flex;justify-content:space-between;align-items:center}.section-header h2{margin:0;font-size:18px;color:#3a3028;letter-spacing:3px;font-weight:600}.format-toggle{display:flex;border:1px solid #d0c8b8;border-radius:4px;overflow:hidden}.format-toggle button{border:none;background:transparent;padding:5px 14px;font-size:11px;font-weight:600;cursor:pointer;color:#8a7d60;transition:all .15s ease;font-family:SF Mono,Menlo,monospace;letter-spacing:1px}.format-toggle button.active{background:#2c3e50;color:#e0d8c8}.format-toggle button:not(.active):hover{background:#0000000a}.analysis-section{display:flex;flex-direction:column;gap:20px}.color-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media (max-width: 768px){.color-grid{grid-template-columns:1fr}}.detail-view{display:flex;flex-direction:column;gap:12px;margin-top:4px}.color-detail{background:#ffffffb3;padding:24px;border-radius:6px;border:1px solid #e0d8cc}.color-detail h3{margin:0 0 16px;font-size:15px;color:#3a3028;letter-spacing:2px}.gradient-bar{display:flex;gap:16px}.gradient-item{flex:1;display:flex;flex-direction:column;gap:8px}.gradient-point{height:56px;border-radius:4px;box-shadow:0 2px 8px #0000001f;border:1px solid rgba(0,0,0,.06)}.gradient-label{display:flex;flex-direction:column;gap:4px}.label-name{font-size:11px;font-weight:600;color:#8a7d60;letter-spacing:2px}.color-value{font-family:SF Mono,Menlo,Monaco,monospace;font-size:11px;background:#0000000a;padding:4px 8px;border-radius:3px;color:#4a4035;word-break:break-all;border:1px solid rgba(0,0,0,.05)}.color-count{margin:14px 0 0;font-size:12px;color:#a09880;letter-spacing:1px}.color-category{background:#fff9;border:1px solid #e0d8cc;border-radius:6px;padding:16px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:10px}.color-category:hover:not(.empty){border-color:#a09880;box-shadow:0 4px 16px #0000000f;transform:translateY(-1px)}.color-category.selected{border-color:#5a8a6a;background:#f0f8f080;box-shadow:0 4px 16px #5a8a6a1f}.color-category.empty{opacity:.5;cursor:default}.category-header{display:flex;justify-content:space-between;align-items:center}.category-header h3{margin:0;font-size:15px;color:#3a3028;letter-spacing:2px}.count{background:#0000000d;color:#8a7d60;padding:3px 10px;border-radius:3px;font-size:11px;font-weight:600;font-family:SF Mono,Menlo,monospace}.color-category.selected .count{background:#5a8a6a;color:#fff}.color-preview{display:flex;flex-direction:column;gap:6px}.color-swatch{height:44px;border-radius:4px;box-shadow:inset 0 1px 3px #00000014;border:1px solid rgba(0,0,0,.08)}.swatch-value{font-family:SF Mono,Menlo,Monaco,monospace;font-size:11px;color:#6a6050;background:#00000008;padding:3px 8px;border-radius:3px;display:inline-block}.mini-gradient{display:flex;gap:8px}.mini-gradient-cell{flex:1;display:flex;flex-direction:column;gap:3px}.mini-gradient-item{height:18px;border-radius:3px;box-shadow:0 1px 3px #00000014;border:1px solid rgba(0,0,0,.06)}.mini-label{font-size:10px;color:#b0a898;text-align:center;letter-spacing:2px}.description{margin:0;font-size:11px;color:#b0a898;letter-spacing:1px}.distribution-bar-container{background:#ffffffb3;padding:24px;border-radius:6px;border:1px solid #e0d8cc}.distribution-bar-container h4{margin:0 0 20px;font-size:14px;color:#3a3028;letter-spacing:2px;font-weight:600}.distribution-bar{position:relative;padding-bottom:80px}.bar-track{position:relative;height:28px;background:#eae4d8;border-radius:4px;overflow:hidden;border:1px solid #d8d0c0}.bar-dot{position:absolute;top:0;width:3px;height:100%;transform:translate(-50%)}.bar-markers{position:relative;height:70px}.bar-marker{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translate(-50%);z-index:1}.bar-marker.left{transform:translate(0);align-items:flex-start}.bar-marker.right{transform:translate(-100%);align-items:flex-end}.marker-line{width:1px;height:10px;background:#6a6050}.marker-swatch{width:18px;height:18px;border-radius:3px;border:2px solid white;box-shadow:0 1px 4px #0003;margin:4px 0}.marker-info{display:flex;flex-direction:column;gap:2px}.marker-label{font-size:10px;font-weight:600;color:#8a7d60;white-space:nowrap;letter-spacing:2px}.marker-value{font-family:SF Mono,Menlo,Monaco,monospace;font-size:10px;background:#0000000a;padding:2px 6px;border-radius:3px;color:#4a4035;white-space:nowrap;border:1px solid rgba(0,0,0,.05)}.td-panel{background:#fff9;border:1px solid #e0d8cc;border-radius:6px;padding:24px;display:flex;flex-direction:column;gap:20px}.td-panel h3{margin:0;font-size:15px;color:#3a3028;letter-spacing:2px}.td-connection{display:flex;flex-direction:column;gap:12px}.td-inputs{display:flex;gap:10px;align-items:end;flex-wrap:wrap}.td-field{display:flex;flex-direction:column;gap:4px}.td-field label{font-size:11px;color:#8a7d60;letter-spacing:1px}.td-field input{padding:7px 12px;border:1px solid #d0c8b8;border-radius:4px;font-family:SF Mono,Menlo,monospace;font-size:13px;color:#3a3028;background:#fff;width:140px}.td-field input:disabled{opacity:.5}.td-btn{padding:7px 20px;border:1px solid #d0c8b8;border-radius:4px;background:#2c3e50;color:#e0d8c8;font-family:inherit;font-size:12px;letter-spacing:2px;cursor:pointer;transition:all .2s;white-space:nowrap}.td-btn:hover{background:#1a2a38}.td-btn.connected{background:#8b3a3a;border-color:#8b3a3a;color:#f0e0d8}.td-btn.connected:hover{background:#6b2a2a}.td-status{display:flex;align-items:center;gap:8px;font-size:12px;color:#8a7d60}.td-dot{width:8px;height:8px;border-radius:50%;background:#bbb}.td-status.connected .td-dot{background:#5a8a6a;box-shadow:0 0 6px #5a8a6a66}.td-status.error .td-dot{background:#c0392b}.td-last-sent{margin-left:auto;font-size:11px;color:#b0a898}.td-gradients{display:flex;flex-direction:column;gap:12px}.td-gradients h4{margin:0;font-size:13px;color:#6a6050;letter-spacing:1px}.td-gradient-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}@media (max-width: 600px){.td-gradient-grid{grid-template-columns:repeat(2,1fr)}}.td-gradient-item{display:flex;flex-direction:column;gap:6px}.td-gradient-preview{width:100%;aspect-ratio:1;border-radius:4px;border:1px solid #d8d0c0;display:block}.td-gradient-info{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#6a6050}.td-download-btn{border:1px solid #d0c8b8;background:transparent;padding:3px 10px;border-radius:3px;font-size:10px;color:#6a6050;cursor:pointer;font-family:inherit;letter-spacing:1px}.td-download-btn:hover{background:#0000000a}.td-help{border-top:1px solid #e8e0d4;padding-top:16px}.td-help summary{font-size:12px;color:#8a7d60;cursor:pointer;letter-spacing:1px}.td-help-content{margin-top:12px;font-size:12px;color:#6a6050;line-height:1.8}.td-help-content ol{padding-left:20px;margin:8px 0}.td-help-content code{font-family:SF Mono,Menlo,monospace;font-size:11px;background:#0000000d;padding:1px 6px;border-radius:3px}.td-help-content pre{background:#1a1a2e;color:#d4c9a8;padding:14px;border-radius:4px;font-size:11px;line-height:1.6;overflow-x:auto;margin:8px 0;font-family:SF Mono,Menlo,monospace}.td-help-content ul{padding-left:20px;margin:8px 0}.td-help-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #ece4d8}.td-help-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.td-help-section h5{margin:0 0 10px;font-size:13px;color:#3a3028;letter-spacing:1px}.td-help-tip{background:#5a8a6a14;border-left:3px solid #5a8a6a;padding:10px 14px;border-radius:0 4px 4px 0;margin:10px 0;font-size:12px;color:#3a5a40}.td-help-links{list-style:none;padding:0!important}.td-help-links li{margin:6px 0}.td-help-links a{color:#4a6a8a;text-decoration:none;border-bottom:1px solid rgba(74,106,138,.3);transition:border-color .2s}.td-help-links a:hover{border-color:#4a6a8a}
