*{box-sizing:border-box}html,body{margin:0;height:100vh;overflow-x:auto;overflow-y:hidden;background:#0a0a0a;font-family:system-ui,-apple-system,sans-serif;color:#e5e5e5}#app{height:100vh;display:grid;grid-template-rows:auto 1fr;grid-template-columns:auto 1fr auto 320px;grid-template-areas:"stats debug camera info" "graph graph graph info";gap:16px;padding:16px;min-width:max-content}#stats{grid-area:stats;background:#171717;border-radius:8px;padding:20px;width:500px;max-width:500px;display:flex;flex-direction:column;gap:16px}.stats-row{display:flex;gap:12px}.stats-col{display:flex;flex-direction:column;gap:12px;flex:1}.stats-row .finger-card{display:flex;flex-direction:column;align-self:stretch;overflow:visible;flex:1;position:relative}.stats-row .finger-card .hands-container{flex:1;min-height:0;display:flex;justify-content:center;align-items:stretch;gap:12px}.stats-row .finger-card .hand-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;min-width:0}.stats-row .finger-card .hand-svg{flex:1;width:100%;height:auto;min-height:0}.stat-card{background:#222;border-radius:8px;padding:14px 16px;border-left:3px solid #444;transition:border-color .3s ease}.stat-card.highlight{border-left-color:#22c55e}.stat-card.warning{border-left-color:#f97316}.streak-card .stat-value{color:#4ade80}.stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#737373;margin-bottom:6px}.stat-value{font-size:28px;font-weight:700;color:#fafafa;font-variant-numeric:tabular-nums;line-height:1.1}.stat-value.large{font-size:36px}.stat-value .unit{font-size:14px;font-weight:500;color:#a3a3a3;margin-left:4px}.stat-subtext{font-size:12px;color:#737373;margin-top:4px}.stat-subtext.positive{color:#22c55e}.finger-badge{display:inline-block;background:#ef4444;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:12px;margin-top:2px}.finger-badge.none{background:#22c55e}.finger-card{padding-bottom:12px}.hands-container{display:flex;justify-content:center;gap:16px;margin-top:8px}.hand-wrapper{display:flex;flex-direction:column;align-items:center;gap:4px}.hand-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#525252}.hand-svg{width:90px;height:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.hand-svg.flipped{transform:scaleX(-1)}.hand-svg .hand-bg{fill:#2a2a2a;stroke:#1a1a1a;stroke-width:1px}.hand-svg .finger{stroke:#1a1a1a;stroke-width:1px;transition:fill .3s ease;cursor:pointer}.hand-svg .finger:hover{filter:brightness(1.2)}.finger-tooltip{position:absolute;background:#000000d9;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:4px;white-space:nowrap;pointer-events:none;z-index:100;opacity:0;transition:opacity .15s ease}.finger-tooltip.visible{opacity:1}.finger-summary{text-align:center;margin-top:8px;font-size:11px;color:#737373;min-height:16px}#cam-section{grid-area:camera;display:flex;flex-direction:column;gap:8px}#cam-container{position:relative;background:#171717;border-radius:8px;overflow:hidden}#video,#canvas{display:block;transform:scaleX(-1);width:480px;height:360px;background:#171717}#canvas{position:absolute;top:0;left:0}.cam-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#171717;z-index:10;gap:12px;text-align:center;padding:24px}.loading-spinner{width:40px;height:40px;border:3px solid #333;border-top-color:#22c55e;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#a3a3a3;font-size:14px}.permission-icon{font-size:48px;margin-bottom:8px}.permission-title{font-size:18px;font-weight:600;color:#fafafa}.permission-text{font-size:13px;color:#a3a3a3;max-width:320px;line-height:1.5}.permission-btn{margin-top:8px;padding:10px 24px;background:#22c55e;color:#000;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease}.permission-btn:hover{background:#16a34a}.cam-overlay-transparent{background:#000000b3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.no-detection-icon{font-size:36px;margin-bottom:4px;animation:look-around 2s ease-in-out infinite}@keyframes look-around{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.no-detection-text{font-size:14px;font-weight:500;color:#a3a3a3}#privacy-badge{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:6px;font-size:12px;color:#22c55e}.privacy-icon{font-size:14px}.privacy-text{font-weight:500}#graph-container{grid-area:graph;background:#171717;border-radius:8px;padding:16px;display:flex;flex-direction:column;min-height:0;overflow-x:auto}#graph-container h2{margin:0 0 12px;font-size:14px;font-weight:500;color:#a3a3a3}#graph-canvas{flex:1;min-width:600px;min-height:0}#debug-container{grid-area:debug;display:grid;grid-template-columns:1fr 1fr;gap:12px;background:#131313;border-radius:8px;padding:12px;font-family:SF Mono,Fira Code,JetBrains Mono,monospace;font-size:11px;min-width:400px;max-height:360px;overflow:hidden}#debug-log-section,#debug-summary-section{display:flex;flex-direction:column;min-height:0;overflow:hidden}.debug-section-header{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:#525252;padding-bottom:8px;border-bottom:1px solid #262626;margin-bottom:8px}#debug-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;min-height:0}#debug-log::-webkit-scrollbar{width:4px}#debug-log::-webkit-scrollbar-track{background:transparent}#debug-log::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.debug-log-entry{display:flex;gap:8px;padding:4px 6px;border-radius:4px;background:#1a1a1a}.debug-log-entry.debug-log-enter{background:#22c55e1a;border-left:2px solid #22c55e}.debug-log-entry.debug-log-exit{background:#ef44441a;border-left:2px solid #ef4444}.debug-log-entry.debug-log-info{border-left:2px solid #3b82f6}.debug-log-time{color:#525252;flex-shrink:0}.debug-log-message{color:#a3a3a3}#debug-summary{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px;min-height:0}#debug-summary::-webkit-scrollbar{width:4px}#debug-summary::-webkit-scrollbar-track{background:transparent}#debug-summary::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.debug-summary-item{display:grid;grid-template-columns:24px 1fr auto;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;background:#1a1a1a;transition:all .2s ease}.debug-summary-item.inactive{opacity:.4}.debug-summary-item.active{background:#1f2937;opacity:1}.debug-summary-item.pending{background:#fbbf2414;border:1px solid rgba(251,191,36,.2);opacity:.6;grid-template-columns:24px 1fr auto;grid-template-rows:auto auto}.debug-summary-item.confirmed{background:#ef444426;border:1px solid rgba(239,68,68,.3);opacity:1}.debug-summary-icon{font-size:14px;text-align:center}.debug-summary-label{color:#d4d4d4;font-weight:500}.debug-summary-status{color:#737373;font-size:10px;text-align:right}.debug-summary-item.confirmed .debug-summary-status{color:#ef4444;font-weight:600}.debug-summary-item.pending .debug-summary-status{color:#fbbf24}.debug-progress-bar{grid-column:1 / -1;height:3px;background:#fbbf2433;border-radius:2px;overflow:hidden;margin-top:4px}.debug-progress-fill{height:100%;background:linear-gradient(90deg,#fbbf24,#f59e0b);border-radius:2px;transition:width .05s linear}.debug-summary-divider{height:1px;background:#262626;margin:4px 0}.debug-summary-section-title{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#404040;margin-bottom:4px}.debug-presence-row{display:flex;justify-content:center;gap:8px;padding:6px 0}.debug-presence-item{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:20px;opacity:.25;transition:opacity .2s ease;padding:6px 10px;border-radius:6px;background:#1a1a1a}.debug-presence-item span{font-size:9px;font-weight:600;color:#525252}.debug-presence-item.active{opacity:1;background:#1f2937}.debug-presence-item.active span{color:#a3a3a3}#info-panel{grid-area:info;background:linear-gradient(180deg,#171717,#131313);border-radius:8px;padding:20px;display:flex;flex-direction:column;gap:14px;overflow:hidden;border-left:1px solid #262626}.info-header{text-align:center;padding-bottom:12px;border-bottom:1px solid #262626}.info-header h1{margin:0;font-size:22px;font-weight:700;color:#fafafa;letter-spacing:-.5px}.info-tagline{margin:6px 0 0;font-size:13px;color:#22c55e;font-weight:500}.video-container{position:relative;width:100%;padding-bottom:56.25%;border-radius:8px;overflow:hidden;background:#000}.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.info-section{display:flex;flex-direction:column;gap:6px}.info-section h2{margin:0;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#737373}.info-section p{margin:0;font-size:13px;line-height:1.5;color:#d4d4d4}.tips-list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}.tips-list li{font-size:12px;line-height:1.4;color:#a3a3a3;padding-left:14px;position:relative}.tips-list li:before{content:"→";position:absolute;left:0;color:#525252}.tips-list li strong{color:#e5e5e5;font-weight:600}.privacy-section{background:#22c55e0d;border:1px solid rgba(34,197,94,.15);border-radius:6px;padding:12px;margin:0 -4px}.privacy-section h2{color:#22c55e}.privacy-section p{color:#a3a3a3;font-size:12px}.info-footer{margin-top:auto;padding-top:12px;border-top:1px solid #262626;display:flex;flex-direction:column;gap:6px}.footer-label{font-size:14px;color:#e5e5e5;margin-top:6px;margin-bottom:4px}.info-link{display:flex;align-items:center;gap:12px;padding:8px 16px;border-radius:6px;text-decoration:none;font-size:16px;font-weight:500;transition:all .2s ease}.info-link span{font-size:20px}.link-email{background:#5a64f1;color:#fff}.link-email:hover{background:#4650dd;color:#fff}.link-coffee{background:#fd0;color:#000}.link-coffee:hover{background:#dbbe00;color:#000}.app-version{margin-top:16px;font-size:11px;color:#555;text-align:center}
