:root{--bg: oklch(98% .008 270);--text: oklch(20% .05 275);--muted: oklch(50% .06 270);--primary: oklch(56% .23 291);--primary-dark: oklch(40% .22 291);--border: oklch(90% .016 270);--font: "Inter", system-ui, sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font);background:linear-gradient(180deg,#f6f8fe,#ebeef8);color:var(--text);line-height:1.5;min-height:100vh}.header{text-align:center;padding:1.5rem 1rem .5rem}.header h1{margin:0;font-size:1.75rem;font-weight:800;letter-spacing:-.02em}.header p{margin:.35rem auto 0;max-width:42ch;color:var(--muted);font-size:.95rem}.layout{display:grid;gap:1.5rem;max-width:1100px;margin:0 auto;padding:1rem 1.25rem 2rem}@media(min-width:900px){.layout{grid-template-columns:minmax(240px,320px) 1fr;align-items:start}}.camera-panel{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1rem;box-shadow:0 2px 16px #7c4aed14}.webcam-wrap{text-align:center;width:100%}#video{width:100%;max-width:280px;border-radius:.75rem;background:#e2e4eb;border:1px solid var(--border);display:block;margin:0 auto}.hint{font-size:.75rem;color:var(--muted);margin:0;text-align:center}.controls-panel{background:#fff;border:1px solid var(--border);border-radius:1rem;padding:1rem;box-shadow:0 2px 16px #7c4aed14}.tabs{display:flex;gap:.35rem;margin-bottom:1rem}.tab{flex:1;border:1px solid var(--border);background:var(--bg);border-radius:999px;padding:.5rem 1rem;font-weight:600;font-size:.875rem;cursor:pointer;color:var(--muted)}.tab.is-active{background:var(--primary);border-color:var(--primary);color:#fff}.panel[hidden]{display:none}.status{font-size:.85rem;color:var(--muted);margin:0 0 .75rem}.field{margin-bottom:.85rem}.field label{display:block;font-size:.78rem;font-weight:600;margin-bottom:.3rem;color:var(--muted)}.field input,.field select{width:100%;padding:.5rem .65rem;border:1px solid var(--border);border-radius:.5rem;font:inherit}.row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.row input{flex:1;min-width:120px}.btn{border:none;border-radius:999px;padding:.55rem 1.1rem;font:inherit;font-weight:600;font-size:.875rem;cursor:pointer;transition:opacity .15s,transform .15s}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:not(:disabled):hover{transform:translateY(-1px)}.btn--primary{background:var(--primary);color:#fff}.btn--secondary{background:#eeecfb;color:var(--primary-dark);border:1px solid var(--border)}.btn--ghost{background:transparent;color:var(--muted)}.btn--danger{background:#cc272e;color:#fff}.file-btn{display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.video-training{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border)}.video-training summary{cursor:pointer;font-weight:600;font-size:.9rem;margin-bottom:.5rem}.video-preview-wrap{margin:.5rem 0 .75rem}.video-preview-wrap video{width:100%;max-width:280px;border-radius:.75rem;border:1px solid var(--border)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:.5rem}.field--compact label{font-size:.78rem}.hint--small{font-size:.7rem;margin-top:.5rem}.hint--small code{font-size:.68rem;background:#f1f1f8;padding:.1rem .35rem;border-radius:.25rem}.counts{font-size:.8rem;color:var(--muted);margin-bottom:.75rem;min-height:1.25rem}.counts ul{margin:0;padding-left:1.1rem}.result{background:#f5f4fc;border-radius:.75rem;padding:.75rem 1rem;margin-bottom:.75rem}.result__label{margin:0;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.result__value{margin:.15rem 0 0;font-size:1.25rem;font-weight:800}.result__conf{margin:.2rem 0 0;font-size:.85rem;color:var(--muted)}.training-gallery{margin-top:.75rem}.training-gallery__heading{font-size:.85rem;font-weight:600;margin:.25rem 0}.training-gallery__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;margin-top:.5rem}.sample-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--border);border-radius:.5rem;overflow:hidden;background:#fafcff}.sample-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.sample-card__num{font-size:.6rem;color:var(--muted);padding:.15rem .3rem;text-align:center}.sample-card__save{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:var(--primary);color:#fff;font-size:.65rem;font-weight:600;padding:.3rem .4rem;cursor:pointer;border-radius:0 0 .4rem .4rem;transition:opacity .15s}.sample-card__save:hover{opacity:.85}.my-room-gallery{min-height:4rem}.gallery-empty{font-size:.85rem;color:var(--muted);margin:0 0 .75rem;text-align:center;padding:.75rem;background:#f5f4fc;border-radius:.75rem}.my-room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;margin-bottom:.75rem}.my-room-card{position:relative;display:flex;flex-direction:column;align-items:stretch;border:1px solid var(--border);border-radius:.5rem;overflow:hidden;background:#fafcff}.my-room-card img{width:100%;aspect-ratio:1;object-fit:cover;display:block}.my-room-card__name{font-size:.7rem;font-weight:700;padding:.25rem .35rem 0}.my-room-card__date{font-size:.6rem;color:var(--muted);padding:0 .35rem .3rem}.my-room-card__delete{position:absolute;top:.2rem;right:.2rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:#00000080;color:#fff;width:1.25rem;height:1.25rem;border-radius:50%;font-size:.8rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.my-room-card:hover .my-room-card__delete{opacity:1}.my-room-card__delete:hover{background:#cc272e}.training-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;display:flex;align-items:center;justify-content:center;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.training-overlay[hidden]{display:none}.training-overlay__box{background:#fff;border-radius:1rem;padding:2rem 2.5rem;text-align:center;box-shadow:0 8px 32px #0003;max-width:360px}.training-overlay__title{margin:0 0 .3rem;font-size:1.15rem;font-weight:800}.training-overlay__sub{margin:0 0 1.25rem;font-size:.85rem;color:var(--muted)}.training-overlay__spinner{width:2.5rem;height:2.5rem;border:3px solid oklch(90% .016 270);border-top-color:var(--primary);border-radius:50%;animation:training-spin .8s linear infinite;margin:0 auto}@keyframes training-spin{to{transform:rotate(360deg)}}
