@charset "UTF-8";:root{font-family:Plus Jakarta Sans,system-ui,sans-serif;line-height:1.5;font-synthesis:none;text-rendering:optimizeLegibility;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;font-weight:400;color:var(--text);--bg: #dde6ed;--surface: #eaf1f6;--surface-2: #f4f8fb;--border: rgba(82, 109, 130, .18);--accent: #27587a;--accent-2: #3a8fa8;--text: #1a2e3b;--text-muted: #526d82;line-height:1.6;background-color:var(--bg);color-scheme:light}body{display:flex;justify-content:center;align-items:center;height:100vh}h1{font-size:3.2em;line-height:1.1}#root{width:100%;max-width:1280px;height:100%}.inactive-link{pointer-events:none}.dual-video-player{margin:0;background:linear-gradient(160deg,var(--surface) 0%,var(--surface-2) 100%);border:1px solid var(--border);border-top:2px solid var(--accent-2);border-radius:16px;overflow:hidden;padding-top:14px;box-shadow:0 4px 24px #27587a1a}.dual-video-player .video-headers{display:grid;grid-template-columns:1fr 1fr;padding:0 0 8px}.dual-video-player .video-label{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);padding-left:16px}.dual-video-player .video-pair{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#27587a8c}.dual-video-player .video-slot{background-color:var(--surface)}.dual-video-player video{display:block;width:100%}.dual-video-player .video-controls{display:flex;align-items:center;gap:12px;padding:10px 20px;border-top:1px solid var(--border)}.dual-video-player .play-btn{background:none;border:1px solid var(--border);border-radius:8px;color:var(--accent);font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s,border-color .15s}.dual-video-player .play-btn:hover{background:var(--accent);border-color:var(--accent);color:#fff}.dual-video-player .seek-bar{flex:1;cursor:pointer;appearance:none;-webkit-appearance:none;height:30px;background:transparent}.dual-video-player .seek-bar::-webkit-slider-runnable-track{height:4px;background:var(--border);border-radius:2px}.dual-video-player .seek-bar::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent-2);margin-top:-5px;cursor:pointer}.dual-video-player .seek-bar::-moz-range-track{height:4px;background:var(--border);border-radius:2px}.dual-video-player .seek-bar::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent-2);border:none;cursor:pointer}.dual-video-player .time-display{font-family:Plus Jakarta Sans,sans-serif;font-size:.78rem;font-weight:500;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.image-process-buttons{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;height:80px;padding:0 50px}.image-process-buttons button{justify-self:center}.image-process-buttons button{height:42px;width:180px;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:600;letter-spacing:.03em;border-radius:8px;cursor:pointer;transition:background-color .15s ease,box-shadow .15s ease}.image-process-buttons button.image-process-buttons--capture{background-color:var(--accent);color:#fff;border:none}.image-process-buttons button.image-process-buttons--capture:hover{background-color:#1d4a66;box-shadow:0 2px 8px #27587a40}.image-process-buttons button.image-process-buttons--detect{background-color:var(--surface-2);color:var(--accent);border:1.5px solid var(--accent-2)}.image-process-buttons button.image-process-buttons--detect:hover{background-color:var(--surface);box-shadow:0 2px 8px #27587a26}.image-process-buttons button.image-process-buttons--detect:disabled{background-color:var(--surface-2);color:var(--text-muted);border-color:var(--border);cursor:not-allowed;box-shadow:none;opacity:.6}.project-link{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--project-accent);border-radius:12px;text-decoration:none;color:var(--text);box-shadow:0 2px 12px #27587a14;transition:box-shadow .15s ease,background-color .15s ease;width:fit-content}.project-link:hover{background-color:var(--surface-2);box-shadow:0 4px 18px #27587a24}.project-link--body{display:flex;flex-direction:column;gap:2px}.project-link--name{display:flex;align-items:center;gap:6px;font-weight:700;font-size:calc(.95rem + 1px);color:var(--project-accent);letter-spacing:.01em}.project-link--symbol{font-size:calc(1.3rem + 1px);color:var(--project-accent);line-height:1}.project-link--meta{font-size:calc(.8rem + 1px);color:var(--project-accent);opacity:.85}.project-link--description{font-size:calc(.85rem + 1px);color:var(--text)}.project-link--arrow{font-size:calc(1rem + 1px);color:var(--project-accent);margin-left:6px;flex-shrink:0;opacity:.7}#main-layout{display:flex;flex-direction:column;gap:30px;padding:50px}.section-label{font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}.sub-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:.9rem;color:var(--accent);letter-spacing:.05em;margin-bottom:10px}.title-section{display:flex;flex-direction:column;justify-content:center;align-items:center}.video-section{display:block;position:relative;z-index:1}@keyframes shine{0%{transform:translate(-100%) skew(-15deg)}15%,to{transform:translate(650%) skew(-15deg)}}.capture-btn{position:relative;overflow:hidden;background:var(--accent);border:1.5px solid rgba(0,0,0,.25);border-radius:14px;color:#fff;font-family:Plus Jakarta Sans,sans-serif;font-size:1rem;font-weight:700;letter-spacing:.06em;padding:14px 36px;min-width:190px;cursor:pointer;white-space:nowrap;transition:background .15s}.capture-btn:after{content:"";position:absolute;top:0;left:0;width:20%;height:100%;background:linear-gradient(105deg,transparent 0%,rgba(255,255,255,.2) 35%,rgba(255,255,255,0) 45%,rgba(255,255,255,.2) 55%,transparent 100%);animation:shine 10s ease-in-out infinite;pointer-events:none}.capture-btn.activated:after{animation:none;display:none}.capture-btn:hover{background:#1d4a66}.capture-btn:active{background:#163a52}.capture-btn:disabled{background:#8fafc0;color:#ffffffbf;border-color:transparent;cursor:not-allowed}.capture-btn:disabled:after{display:none}.video-capture-connector{position:relative;height:90px;display:flex;align-items:center}.video-capture-connector:before{content:"";position:absolute;left:25%;transform:translate(-50%);top:-35px;bottom:-35px;border-left:5px dashed var(--accent);opacity:.6}.video-capture-connector .capture-btn{position:absolute;left:25%;transform:translate(-50%);z-index:2}.image-process-section{position:relative;z-index:1;display:flex;flex-direction:column;min-height:250px;background:linear-gradient(160deg,var(--surface) 0%,var(--surface-2) 100%);border:1px solid var(--border);border-top:2px solid var(--accent-2);border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #27587a1a}.image-process-section .image-process-output{display:grid;grid-template-columns:1fr 1fr;gap:50px;padding:20px 50px 10px;border-top:1px solid var(--border);min-height:400px}.image-process-section .image-process-output .captured-frame-container .captured-frame-root{width:100%;height:295px}.image-process-section .image-process-output .captured-frame-container .image-placeholder{height:100%;background:var(--surface-2);border-radius:10px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:1rem;letter-spacing:.05em;flex-direction:column;gap:8px}.image-process-section .image-process-output .captured-frame-container .image-placeholder--icon{font-size:2.5rem}.image-process-section .image-process-output .prediction-container{display:flex;flex-direction:column;height:100%;width:100%}.image-process-section .image-process-output .prediction-container .prediction-placeholder--icon{font-size:2.5rem}.image-process-section .image-process-output .prediction-container .prediction-container-results{height:295px;background:var(--surface-2);border-radius:10px;border:1px solid var(--border);overflow:hidden;color:var(--text-muted);font-size:1rem;letter-spacing:.05em;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px}.image-process-section .image-process-output .prediction-container .prediction-container-results img{width:100%}.about-section{display:grid;grid-template-columns:1fr 1fr;gap:50px}.about-section .pending-list{display:flex;flex-direction:column;gap:5px;padding-left:20px}.about-section .pending-list li{display:flex;align-items:flex-start;gap:10px;font-size:1rem;color:var(--text-muted);padding:8px 12px;background:var(--surface-2);border-radius:8px;border:1px solid var(--border);line-height:1.5;box-shadow:0 4px 24px #27587a1a}.about-section .pending-list li:before{content:"○";color:var(--accent-2);font-size:.75rem;margin-top:2px;flex-shrink:0}.about-section .related-projects{margin-top:20px}.about-section .related-projects .project-link{margin-left:20px}.about-section .repo-info-list{display:flex;flex-direction:column;gap:5px}.about-section .repo-info{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px 15px;box-shadow:0 4px 24px #27587a1a}.about-section .repo-info a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.about-section .repo-header{display:flex;flex-direction:row;align-items:center;gap:12px;margin-bottom:5px}.about-section .repo-summary{flex:1}.about-section .repo-link{font-size:.78rem;font-weight:500;color:var(--accent);white-space:nowrap;padding:4px 10px;border:1px solid rgba(39,88,122,.25);border-radius:6px;text-decoration:none}.about-section .repo-summary--label{font-weight:600}.about-section .repo-description{font-size:1rem;background:var(--surface-2);border-radius:8px;border:1px solid var(--border);line-height:1.5;padding:8px 12px;margin:0}.architecture-section img{width:100%;background:var(--surface-2);border-radius:20px;border:1px solid var(--border);border-bottom:2px solid var(--accent-2);box-shadow:0 4px 24px #27587a1a}
