.app{min-height:100vh;background:#0b1020;color:#e9edf7;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px clamp(16px,4vw,28px);border-bottom:1px solid #1b2744}.header h1{font-size:1.8rem;font-weight:600;background:linear-gradient(135deg,#00bcd4,#ff5722);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.status-indicator{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border:1px solid #223359;border-radius:999px;background:#0f162b}.status-light{width:10px;height:10px;border-radius:50%}.status-light.recording{background:#ff5252;box-shadow:0 0 10px #ff525280}.status-light.idle{background:#29e68c;box-shadow:0 0 10px #29e68c66}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#090c1899;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:40}.loading-container{text-align:center}.loading-spinner{width:36px;height:36px;border-radius:50%;border:3px solid #294070;border-top-color:#5aa6ff;animation:spin .8s linear infinite;margin:0 auto 12px}@keyframes spin{to{transform:rotate(360deg)}}.main-content{display:grid;grid-template-columns:360px 1fr;gap:16px;padding:16px clamp(16px,4vw,28px) 28px}@media (max-width: 1200px){.main-content{grid-template-columns:320px 1fr}}@media (max-width: 900px){.main-content{grid-template-columns:1fr}}.left-panel{display:grid;gap:16px}.video-section,.controls-section,.sessions-section{background:#101725;border:1px solid #1b2744;border-radius:12px;box-shadow:0 4px 14px #00000040}.video-section{padding:12px}.video-container{position:relative;width:100%;aspect-ratio:4 / 3;background:#000;border:1px solid #232b3f;border-radius:10px;overflow:hidden}.video-container video,.video-container canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block}.emotion-overlay{position:absolute;top:10px;right:12px;background:#0b1020a6;border:1px solid #24345a;border-radius:10px;padding:6px 10px;font-size:13px}.current-emotion{display:grid;gap:2px}.record-count{color:#39c5ff}.controls-section{padding:14px}.session-controls{display:grid;gap:12px}.input-group{display:grid;gap:6px}.input-group label{font-size:12px;color:#a9b3c6}.input-group input{background:#0b1224;color:#fff;border:1px solid #223359;border-radius:8px;padding:8px 10px;outline:none}.button-group{display:flex;gap:8px;flex-wrap:wrap}.btn{padding:8px 12px;border-radius:8px;border:1px solid #223359;background:#182243;color:#fff;cursor:pointer}.btn:hover{background:#1e2b56}.btn-primary{background:#2f6fed;border-color:#2f6fed}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger{background:#eb4d4b;border-color:#eb4d4b}.btn-small{padding:6px 10px;font-size:13px}.sessions-section{padding:14px}.sessions-section h3{margin:0 0 10px;font-size:16px}.sessions-list{display:grid;gap:10px;max-height:260px;overflow:auto}.session-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;background:#0b1224;border:1px solid #1b2744;border-radius:10px}.session-info{display:grid;gap:2px;font-size:13px}.right-panel{min-width:0}.charts-container{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:1fr;gap:16px}@media (max-width: 1200px){.charts-container{grid-template-columns:1fr}}.chart-section{background:#101725;border:1px solid #1b2744;border-radius:12px;box-shadow:0 4px 14px #00000040;padding:10px;position:relative;aspect-ratio:16 / 9;overflow:hidden}.chart-section canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.webcam-controls{position:absolute;top:8px;left:8px;z-index:5;display:flex;gap:8px}.btn-icon{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #223359;background:#0f162b;color:#e9edf7;border-radius:8px;padding:6px 8px;line-height:1;font-size:14px;cursor:pointer}.btn-icon:hover{background:#1b2744}.video-container.fullscreen{position:fixed!important;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000;border:none;border-radius:0;width:100vw;height:auto;aspect-ratio:4 / 3;margin:0 auto;box-shadow:none;overflow:hidden}.video-container.fullscreen video,.video-container.fullscreen canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.video-container.fullscreen .emotion-overlay{top:16px;right:18px;transform:none}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.block{display:block}.grid{display:grid}.hidden{display:none}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}
