@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#090d16;--bg-secondary:#121824;--glass-bg:#161e31a6;--glass-border:#ffffff14;--primary:#6366f1;--primary-hover:#4f46e5;--accent:#10b981;--accent-danger:#ef4444;--accent-warning:#f59e0b;--text-primary:#f8fafc;--text-secondary:#94a3b8;--text-muted:#64748b;--shadow-premium:0 8px 32px 0 #0000005e;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1);--font-family:"Inter", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);-webkit-font-smoothing:antialiased;background-image:radial-gradient(at 0 0,#100f15 0,#0000 50%),radial-gradient(at 50% 0,#13192b 0,#0000 50%),radial-gradient(at 100% 0,#21153726 0,#0000 40%);min-height:100vh;overflow-x:hidden}.app-container{border-left:1px solid var(--glass-border);border-right:1px solid var(--glass-border);background:#090d16d9;flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex;position:relative}@media (width>=768px){.app-container{max-width:960px}}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--glass-border);z-index:50;background:#121824b3;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.header-brand{align-items:center;gap:10px;display:flex}.logo-badge{filter:drop-shadow(0 0 8px var(--primary));font-size:22px}.app-header h1{letter-spacing:.5px;background:linear-gradient(135deg, #fff 0%, var(--text-secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:16px;font-weight:700}.history-toggle-btn{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);border-radius:20px;align-items:center;padding:8px 12px;font-size:13px;font-weight:500;display:flex}.history-toggle-btn:hover{background:#6366f126;border-color:#6366f166}.app-main{flex-direction:column;flex:1;justify-content:center;padding:20px;display:flex}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--shadow-premium);border-radius:24px;padding:24px}.loading-container{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:40px 24px;display:flex}.spinner{color:var(--primary);filter:drop-shadow(0 0 8px #6366f180);animation:1s linear infinite spin}.progress-text{color:var(--text-secondary);font-size:14px}.tips-card{color:var(--text-muted);text-align:left;background:#ffffff08;border:1px solid #ffffff05;border-radius:16px;gap:12px;padding:16px;font-size:12px;line-height:1.5;display:flex}.tip-icon{color:var(--primary);flex-shrink:0}.camera-container{aspect-ratio:3/4;width:100%;box-shadow:var(--shadow-premium);border:1px solid var(--glass-border);background:#000;border-radius:24px;position:relative;overflow:hidden}.video-wrapper{width:100%;height:100%;position:relative}.video-wrapper video{object-fit:cover;width:100%;height:100%}.video-wrapper video.mirrored{transform:scaleX(-1)}.camera-guide{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0 0 80px}.guide-box{border:1px dashed #ffffff40;justify-content:center;align-items:flex-end;width:75%;height:65%;padding-bottom:20px;display:flex;position:relative}.guide-text{color:#fff9;text-shadow:0 2px 4px #000c;background:#0006;border-radius:12px;padding:4px 10px;font-size:12px}.corner{border:3px solid var(--primary);width:20px;height:20px;filter:drop-shadow(0 0 6px var(--primary));position:absolute}.top-left{border-bottom:none;border-right:none;top:-2px;left:-2px}.top-right{border-bottom:none;border-left:none;top:-2px;right:-2px}.bottom-left{border-top:none;border-right:none;bottom:-2px;left:-2px}.bottom-right{border-top:none;border-left:none;bottom:-2px;right:-2px}.camera-controls{background:linear-gradient(#0000 0%,#000000e6 100%);justify-content:space-around;align-items:center;height:90px;padding:0 30px;display:flex;position:absolute;bottom:0;left:0;right:0}.control-btn{cursor:pointer;transition:var(--transition-smooth);border:none;justify-content:center;align-items:center;display:flex}.capture-btn{background:#fff3;border-radius:50%;width:64px;height:64px;padding:4px}.capture-inner{background:var(--text-primary);width:100%;height:100%;color:var(--bg-primary);border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 0 15px #ffffff80}.capture-btn:active .capture-inner{transform:scale(.9)}.secondary-btn{width:44px;height:44px;color:var(--text-primary);background:#ffffff1a;border:1px solid #ffffff0d;border-radius:50%}.secondary-btn:hover{background:#fff3}.fallback-wrapper{text-align:center;height:100%;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:40px 24px;display:flex}.fallback-icon{color:var(--accent-warning);filter:drop-shadow(0 0 10px #f59e0b66);margin-bottom:16px}.fallback-wrapper h3{color:var(--text-primary);margin-bottom:8px}.fallback-desc{margin-bottom:24px;font-size:13px;line-height:1.5}.upload-fallback-btn{background:var(--primary);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:20px;justify-content:center;align-items:center;padding:12px 24px;font-size:14px;font-weight:600;display:flex;box-shadow:0 4px 14px #6366f166}.upload-fallback-btn:hover{background:var(--primary-hover);transform:translateY(-2px)}.analysis-layout{flex-direction:column;gap:20px;display:flex}@media (width>=768px){.analysis-layout{grid-template-columns:1.2fr .8fr;align-items:start;display:grid}}.viewer-panel{justify-content:center;align-items:center;width:100%;padding:10px;display:flex;position:relative;overflow:hidden}.pill-overlay-container{justify-content:center;align-items:center;width:100%;display:flex;position:relative}.source-image{border-radius:16px;max-width:100%;max-height:50vh;display:block}.overlay-canvas{cursor:crosshair;max-width:100%;max-height:50vh;display:block;position:absolute;top:0;left:50%;transform:translate(-50%)}.overlay-canvas.tool-add{cursor:cell}.overlay-canvas.tool-delete{cursor:no-drop}.inference-loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#090d16bf;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.control-panel-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:var(--shadow-premium);border-radius:24px;flex-direction:column;gap:20px;padding:24px;display:flex}.stats-board{background:#ffffff05;border:1px solid #ffffff0a;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex}.count-display{align-items:baseline;gap:4px;display:flex}.count-number{color:var(--accent);text-shadow:0 0 15px #10b9814d;font-size:48px;font-weight:800}.count-unit{color:var(--text-secondary);font-size:16px;font-weight:600}.pill-type-input-group{width:100%}.pill-type-input{border:1px solid var(--glass-border);width:100%;color:var(--text-primary);text-align:center;transition:var(--transition-smooth);background:#0000004d;border-radius:12px;padding:10px 14px;font-size:14px}.pill-type-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 10px #6366f133}.tool-section{flex-direction:column;gap:8px;display:flex}.section-title{color:var(--text-muted);letter-spacing:.5px;justify-content:space-between;font-size:12px;font-weight:600;display:flex}.info-icon{cursor:help}.tool-buttons{grid-template-columns:1fr 1fr;gap:10px;display:grid}.tool-btn{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:#ffffff05;border-radius:14px;justify-content:center;align-items:center;gap:6px;padding:12px;font-size:13px;font-weight:600;display:flex}.tool-btn:hover{color:var(--text-primary);background:#ffffff0d}.tool-btn.active.add{color:#4ade80;background:#22c55e26;border-color:#22c55e80;box-shadow:0 0 12px #22c55e1a}.tool-btn.active.delete{color:#f87171;background:#ef444426;border-color:#ef444480;box-shadow:0 0 12px #ef44441a}.action-row{gap:10px;display:flex}.action-btn{border:1px solid var(--glass-border);color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:#ffffff05;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:4px;padding:10px;font-size:12px;font-weight:500;display:flex}.action-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.action-btn:disabled{opacity:.3;cursor:not-allowed}.slider-section{flex-direction:column;gap:8px;display:flex}.slider-header{color:var(--text-secondary);align-items:center;font-size:12px;font-weight:500;display:flex}.confidence-slider{-webkit-appearance:none;cursor:pointer;background:#ffffff1a;border-radius:3px;outline:none;width:100%;height:6px}.confidence-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);border-radius:50%;width:16px;height:16px;box-shadow:0 0 8px #6366f199}.slider-labels{color:var(--text-muted);justify-content:space-between;font-size:10px;display:flex}.submit-section{gap:10px;margin-top:8px;display:flex}.cancel-btn,.confirm-btn{cursor:pointer;transition:var(--transition-smooth);border:none;border-radius:16px;flex:1;justify-content:center;align-items:center;padding:14px;font-size:14px;font-weight:600;display:flex}.cancel-btn{color:var(--text-secondary);border:1px solid var(--glass-border);background:#ffffff08}.cancel-btn:hover{color:var(--text-primary);background:#ffffff14}.confirm-btn{background:var(--primary);color:#fff;box-shadow:0 4px 15px #6366f159}.confirm-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-btn.success{background:var(--accent);box-shadow:0 4px 15px #10b98159}.detail-breakdown{color:var(--text-muted);justify-content:center;gap:10px;font-size:11px;display:flex}.history-drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:flex-end;display:flex;position:fixed;inset:0}.history-drawer{background:var(--bg-secondary);border-left:1px solid var(--glass-border);flex-direction:column;width:100%;max-width:400px;height:100%;animation:.3s ease-out slideIn;display:flex;box-shadow:-8px 0 32px #00000080}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:20px;display:flex}.drawer-header h2{align-items:center;font-size:18px;font-weight:700;display:flex}.close-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none}.close-btn:hover{color:var(--text-primary)}.drawer-body{flex:1;padding:20px;overflow-y:auto}.empty-placeholder{height:200px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.empty-icon{opacity:.2}.loading-placeholder{text-align:center;color:var(--text-secondary);padding:20px}.record-list{flex-direction:column;gap:12px;display:flex}.record-card{background:var(--glass-bg);border:1px solid var(--glass-border);cursor:pointer;transition:var(--transition-smooth);border-radius:16px;justify-content:space-between;padding:16px;display:flex}.record-card:hover{background:#ffffff05;border-color:#ffffff26;transform:translateY(-1px)}.record-card-info{flex-direction:column;gap:4px;display:flex}.record-title{font-size:14px;font-weight:600}.record-time{color:var(--text-muted);font-size:11px}.record-details{color:var(--text-muted);gap:6px;margin-top:4px;font-size:10px;display:flex}.record-card-right{flex-direction:column;justify-content:space-between;align-items:flex-end;display:flex}.record-count{color:var(--accent);font-size:20px;font-weight:700}.record-count span{color:var(--text-secondary);font-size:11px}.delete-icon-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:4px;padding:4px}.delete-icon-btn:hover{color:var(--accent-danger);background:#ef44441a}.detail-modal-overlay{z-index:110;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.detail-modal{background:var(--bg-secondary);border:1px solid var(--glass-border);border-radius:24px;width:100%;max-width:480px;animation:.25s cubic-bezier(.34,1.56,.64,1) modalZoom;overflow:hidden;box-shadow:0 12px 48px #000c}@keyframes modalZoom{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid var(--glass-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-body{flex-direction:column;gap:16px;padding:20px;display:flex}.modal-image-wrapper{aspect-ratio:4/3;border:1px solid var(--glass-border);background:#000;border-radius:12px;width:100%;overflow:hidden}.modal-image-wrapper img{object-fit:contain;width:100%;height:100%}.modal-info-panel{background:#ffffff05;border-radius:14px;flex-direction:column;gap:10px;padding:14px;display:flex}.modal-info-item{justify-content:space-between;font-size:13px;display:flex}.modal-info-item .label{color:var(--text-muted)}.modal-info-item .value{color:var(--text-primary);font-weight:550}.modal-info-item .value.highlight{color:var(--accent);font-weight:700}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.camera-error-toast{background:var(--accent-danger);color:#fff;text-align:center;border-radius:12px;padding:10px 16px;font-size:12px;font-weight:600;animation:.3s ease-out slideDown;position:absolute;top:20px;left:20px;right:20px;box-shadow:0 4px 15px #ef44444d}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.camera-select-overlay{z-index:10;width:85%;max-width:320px;position:absolute;top:15px;left:50%;transform:translate(-50%)}.camera-selector-dropdown{-webkit-backdrop-filter:blur(12px);width:100%;color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);background:#121824bf;border:1px solid #ffffff26;border-radius:14px;outline:none;padding:10px 14px;font-size:13px;font-weight:550;box-shadow:0 4px 12px #0000004d}.camera-selector-dropdown:focus{border-color:var(--primary);box-shadow:0 0 10px #6366f14d}.camera-selector-dropdown option{background:var(--bg-secondary);color:var(--text-primary);padding:10px}.camera-workspace{flex-direction:column;gap:15px;width:100%;display:flex}.coco-model-notice{color:#fbbf24;background:#f59e0b14;border:1px solid #f59e0b33;border-radius:16px;padding:12px 16px;font-size:11px;line-height:1.5;display:flex}
