.class-player-overlay{position:fixed;inset:0;z-index:9999;background:var(--surface-0);color:var(--text-primary);display:flex;flex-direction:column;overflow:hidden;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.class-player-topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;flex-shrink:0}.class-player-topbar-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;max-width:60%}.class-player-topbar-counter,.class-player-topbar-title{font-size:14px;color:var(--text-muted);white-space:nowrap}.class-player-close-btn{background:none;border:none;color:var(--text-primary);font-size:24px;cursor:pointer;padding:4px 8px;line-height:1}.class-player-progress{display:flex;gap:4px;padding:0 16px 8px;flex-shrink:0}.class-player-progress-dot{flex:1 1;height:4px;border-radius:2px;background:var(--border-subtle);transition:background .2s}.class-player-progress-dot--done{background:#4caf50}.class-player-progress-dot--skipped{background:var(--text-muted)}.class-player-progress-dot--active{background:var(--warrior-red)}.class-player-card-area{flex:1 1;overflow-y:auto;padding:0 16px 16px;transition:transform .15s ease-out}.class-player-card{background:var(--surface-card);border:1px solid var(--surface-card-border);border-radius:var(--radius-md);padding:16px;display:flex;flex-direction:column;gap:12px}.class-player-card--done{opacity:.7}.class-player-card-title{font-size:20px;font-weight:700;margin:0}.class-player-card-category{display:inline-block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:4px;background:var(--surface-2);color:var(--text-muted)}.class-player-video-zone{border-radius:var(--radius-md);overflow:hidden;background:var(--taiko-black)}.class-player-video-placeholder{height:120px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.class-player-session-note{background:var(--surface-2);border-left:3px solid var(--warrior-red);padding:8px 12px;border-radius:0 var(--radius-md) var(--radius-md) 0;font-size:14px;color:var(--text-primary)}.class-player-session-note-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px}.class-player-note-block{background:var(--surface-2);padding:8px 12px;border-radius:var(--radius-md);font-size:14px;color:var(--text-primary)}.class-player-note-block-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px}.class-player-note-block-content{white-space:pre-wrap}.class-player-controls{justify-content:space-between;padding:12px 16px;gap:12px;border-top:1px solid var(--border-subtle)}.class-player-controls,.class-player-nav-btn{display:flex;align-items:center;flex-shrink:0}.class-player-nav-btn{background:var(--surface-2);border:1px solid var(--border-subtle);color:var(--text-primary);width:48px;height:48px;border-radius:50%;justify-content:center;cursor:pointer;font-size:18px}.class-player-nav-btn:disabled{opacity:.3;cursor:default}.class-player-done-btn{flex:1 1;max-width:200px;height:48px;border:none;border-radius:24px;font-size:16px;font-weight:700;cursor:pointer;transition:background .2s}.class-player-done-btn--mark{background:#4caf50;color:#fff}.class-player-done-btn--undo{background:var(--surface-2);color:var(--text-primary);border:1px solid var(--border-subtle)}.class-player-done-btn:disabled{opacity:.5;cursor:default}.class-player-action-pair{display:flex;flex:1 1;max-width:280px;gap:8px;justify-content:center}.class-player-skip-btn{flex:0 0 auto;height:48px;padding:0 20px;border:1px solid var(--border-subtle);border-radius:24px;background:var(--surface-2);color:var(--text-primary);font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.class-player-skip-btn:disabled{opacity:.5;cursor:default}@keyframes class-player-done-flash{0%{background:transparent}30%{background:rgba(76,175,80,.25)}to{background:transparent}}.class-player-done-flash{animation:class-player-done-flash .6s ease-out}.class-player-complete{flex:1 1;flex-direction:column;gap:24px;padding:32px;text-align:center}.class-player-complete,.class-player-complete-icon{display:flex;align-items:center;justify-content:center}.class-player-complete-icon{width:80px;height:80px;border-radius:50%;background:#4caf50;color:#fff;font-size:40px}.class-player-complete-title{font-size:24px;font-weight:700;margin:0}.class-player-complete-actions{display:flex;gap:12px}.class-player-fab{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));right:24px;width:56px;height:56px;border-radius:50%;background:var(--warrior-red);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 12px rgba(0,0,0,.4);z-index:101}@media (max-width:760px){.class-player-fab{bottom:calc(60px + 24px + env(safe-area-inset-bottom))}}.class-player-fab-badge{position:absolute;top:-4px;right:-4px;background:var(--surface-0);color:var(--text-primary);font-size:11px;font-weight:700;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--warrior-red)}@media (orientation:landscape) and (max-height:500px){.class-player-card-area{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}}:root{--state-encoding:var(--amber)}*{box-sizing:border-box}html{overflow-y:scroll;scroll-behavior:smooth}body,html{margin:0;padding:0;font-family:Avenir Next,Avenir,Segoe UI,sans-serif;background:var(--surface-0);color:var(--text-primary);background-image:radial-gradient(circle at 10% 0,rgba(160,53,47,.14),transparent 44%),radial-gradient(circle at 100% 10%,rgba(232,220,200,.08),transparent 35%),url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-width='0.4' opacity='0.04'%3E%3Crect width='40' height='40'/%3E%3Cpath d='M20 0v40M0 20h40'/%3E%3C/g%3E%3C/svg%3E")}a{color:inherit;text-decoration:none}.taiko-link{color:var(--dojo-cream);text-decoration:underline;-webkit-text-decoration-color:rgba(232,220,200,.55);text-decoration-color:rgba(232,220,200,.55);text-decoration-thickness:1.5px;text-underline-offset:2px;transition:color .14s ease,-webkit-text-decoration-color .14s ease;transition:color .14s ease,text-decoration-color .14s ease;transition:color .14s ease,text-decoration-color .14s ease,-webkit-text-decoration-color .14s ease}.taiko-link:focus-visible,.taiko-link:hover{color:var(--warrior-red);-webkit-text-decoration-color:var(--warrior-red);text-decoration-color:var(--warrior-red)}:root{--enter-duration:300ms;--enter-duration-fast:200ms;--enter-ease:cubic-bezier(0.16,1,0.3,1)}@keyframes enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes enter-fade{0%{opacity:0}to{opacity:1}}@keyframes enter-scale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes enter-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@media (hover:none) and (pointer:coarse){:root{--enter-duration:210ms;--enter-duration-fast:140ms}}@media (prefers-reduced-motion:reduce){.item-list>*,.lightbox-content,.lightbox-overlay,.page-header{animation:none!important}}main{width:min(1024px,100%);margin:0 auto;padding:2rem 1rem 2.5rem}.page-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid rgba(232,220,200,.12);animation:enter var(--enter-duration) var(--enter-ease) both}.page-title{margin:0;font-size:clamp(1.55rem,2.2vw,2rem);font-weight:800;letter-spacing:-.01em}.page-subtitle{margin:.35rem 0 0;color:var(--text-muted);font-size:.92rem}.app-topbar{margin-bottom:1.3rem}.nav-strip{display:flex;align-items:center;gap:0;flex:1 1 auto;min-width:0;background:transparent;border-radius:var(--radius-md)}.nav-strip:before{display:none}.nav-scroll{display:flex;align-items:center;flex:1 1 auto;min-width:0;overflow-x:auto;scrollbar-width:none;gap:.15rem}.nav-scroll:after{content:"";position:-webkit-sticky;position:sticky;right:0;flex-shrink:0;width:2rem;align-self:stretch;background:linear-gradient(90deg,transparent,rgba(17,17,17,.82));pointer-events:none}.nav-cluster{display:flex;align-items:center;gap:0}.nav-cluster+.nav-cluster{margin-left:.35rem;padding-left:.35rem;border-left:1px solid var(--surface-card-border)}.user-menu{position:relative;flex-shrink:0}.user-menu-avatar{width:2.2rem;height:2.2rem;border-radius:50%;border:1px solid var(--surface-card-border);background:var(--surface-card);color:var(--text-primary);font-weight:700;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .14s ease}.user-menu-avatar:hover{border-color:var(--warrior-red)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:180px;background:var(--surface-card);border:1px solid var(--surface-card-border);border-radius:var(--radius-md);padding:.5rem 0;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.4)}.user-menu-info{padding:.6rem 1rem;display:flex;flex-direction:column;gap:.15rem}.user-menu-username{color:var(--text-primary);font-weight:600;font-size:.88rem}.user-menu-divider{border:none;border-top:1px solid var(--surface-card-border);margin:.25rem 0}.user-menu-item{display:block;width:100%;padding:.5rem 1rem;background:transparent;border:none;color:var(--text-muted);font:inherit;font-size:.85rem;text-align:left;cursor:pointer;transition:background .1s ease,color .1s ease}.user-menu-item:hover{background:rgba(255,255,255,.05);color:var(--text-primary)}.mobile-nav{display:none}.stack{display:grid;grid-gap:1.1rem;gap:1.1rem;min-width:0}.stack>section+section{border-top:1px solid rgba(232,220,200,.07);padding-top:.5rem}.card{background:var(--surface-card);border:1px solid var(--surface-card-border);border-radius:14px;padding:1.05rem;min-width:0;box-shadow:0 0 0 1px rgba(232,220,200,.04),inset 0 1px 0 rgba(255,255,255,.03);transition:border-color .14s ease,box-shadow .14s ease}.card:hover{border-color:rgba(232,220,200,.12);box-shadow:0 0 0 1px rgba(160,53,47,.15),0 10px 22px rgba(0,0,0,.28),inset 0 1px 0 rgba(255,255,255,.03)}.card-compact{padding:.8rem}.card--active{border-left:3px solid var(--warrior-red)}.card-title{margin:0;font-size:1.03rem;font-weight:700;letter-spacing:-.005em}.card-subtitle{margin:.3rem 0 0;color:var(--text-muted);font-size:.9rem;line-height:1.4}.coach-notes-view{white-space:pre-wrap;background:rgba(255,255,255,.03);border:1px solid var(--border-subtle);border-radius:8px;padding:.65rem .85rem;font-size:.9rem;line-height:1.5;color:var(--text-primary);min-height:2.4rem}.form-grid{display:grid;grid-gap:.88rem;gap:.88rem;min-width:0}.field{display:grid;grid-gap:.35rem;gap:.35rem}.field-label{font-size:.82rem;color:var(--text-muted);letter-spacing:.03em}input:not([type=checkbox]):not([type=radio]),select,textarea{width:100%;border-radius:12px;border:1px solid #5a4f45;background:linear-gradient(180deg,#1b1a18,#141311);color:var(--text-primary);padding:.7rem .78rem;font:inherit;transition:border-color .12s ease,box-shadow .12s ease,background-color .12s ease}select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23b8a890' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .65rem center;padding-right:2.2rem}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer;opacity:.7}.select-compact{min-height:2.05rem;padding:.38rem .55rem;border-radius:9px;font-size:.9rem}.select-compact-tight{min-height:1.9rem;padding:.3rem .48rem;border-radius:8px;font-size:.86rem}input::placeholder,textarea::placeholder{color:#7a7060}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--focus-glow)}.tech-search-inline:focus,.tech-search-input:focus,.technique-search-field:focus,input[type=search]:focus{border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-glow)}label.field{position:relative}.form-grid .field-label{font-weight:600;letter-spacing:.06em}.form-hint{color:var(--text-muted);font-size:.78rem;line-height:1.35}.form-hint.danger{background:var(--warrior-red-dim);padding:.45rem .65rem;border-left:3px solid var(--warrior-red);border-radius:0 6px 6px 0}textarea{resize:vertical;min-height:90px}a.btn-muted,a.btn-primary,button{border:1px solid transparent;border-radius:10px;padding:.54rem 1rem;background:transparent;color:var(--text-primary);font:inherit;font-size:.88rem;font-weight:600;cursor:pointer;text-decoration:none;touch-action:manipulation;transition:background-color .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease,transform 60ms ease}button:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--warrior-red);border-color:var(--warrior-red);color:#fff5ef}.btn-primary:not(:disabled):hover{background:var(--warrior-red-light);border-color:var(--warrior-red-light);box-shadow:0 2px 8px rgba(160,53,47,.35)}.btn-muted{background:#272320;border-color:#4d443b}.btn-muted:not(:disabled):hover{border-color:var(--dojo-cream);color:var(--dojo-cream)}.btn-ghost{background:transparent;border:none;color:var(--text-muted)}.btn-ghost:not(:disabled):hover{text-decoration:underline;-webkit-text-decoration-color:var(--warrior-red);text-decoration-color:var(--warrior-red);color:var(--text-primary)}.btn-danger-ghost{background:transparent;border:none;color:var(--danger);font-size:.84rem}.btn-danger-ghost:not(:disabled):hover{text-decoration:underline;-webkit-text-decoration-color:var(--danger);text-decoration-color:var(--danger)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff5ef}.btn-danger:not(:disabled):hover{background:#d94438;border-color:#d94438;box-shadow:0 2px 8px rgba(192,57,43,.35)}a.btn-muted:active,a.btn-primary:active,button:not(:disabled):active{transform:scale(.97)}@media (hover:none) and (pointer:coarse){a.btn-muted:active,a.btn-primary:active,button:not(:disabled):active{transform:scale(.95)}}@media (prefers-reduced-motion:reduce){a.btn-muted:active,a.btn-primary:active,button:not(:disabled):active{transform:none}}a.btn-muted:focus-visible,a.btn-primary:focus-visible,button:focus-visible{outline:2px solid var(--warrior-red);outline-offset:2px}.btn-sm{padding:.2rem .6rem;font-size:.82rem}.ds-btn--danger.btn-toggle-active,.ds-btn--muted.btn-toggle-active{border-color:var(--warrior-red);color:var(--dojo-cream)}.ds-btn--muted.btn-option-active,.ds-btn--muted.btn-picker-selected{background:rgba(160,53,47,.15);border-color:var(--warrior-red);color:var(--dojo-cream)}.chips .ds-btn,.tech-search-categories .ds-btn{padding:.3rem .72rem;border-radius:var(--radius-pill);font-size:.8rem}.chips .ds-btn--muted,.tech-search-categories .ds-btn--muted{background:rgba(255,255,255,.04);border-color:var(--surface-card-border)}.action-row,.form-actions{display:flex;flex-wrap:wrap;gap:.55rem}.form-actions{justify-content:flex-end}.inline-grid{display:grid;grid-gap:.55rem;gap:.55rem;grid-template-columns:repeat(3,minmax(0,1fr))}.chips{display:flex;flex-wrap:wrap;gap:.45rem}.game-combo{position:relative}.game-combo-trigger{display:inline-flex;align-items:center;gap:.4rem;min-height:2.05rem;padding:.35rem .65rem;border-radius:9px;font-size:.85rem;font-weight:500;color:var(--text-primary);background:linear-gradient(180deg,#1b1a18,#141311);border:1px solid #5a4f45;cursor:pointer;transition:border-color .14s ease}.game-combo-trigger:hover{border-color:var(--dojo-cream)}.game-combo-chevron{transition:transform .2s ease;opacity:.6}.game-combo-chevron--open{transform:rotate(180deg)}.game-combo-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:50;min-width:240px;max-width:320px;max-height:340px;display:flex;flex-direction:column;background:var(--surface-1,#1e1c1a);border:1px solid var(--border-subtle,#3a3a3a);border-radius:10px;box-shadow:0 12px 32px rgba(0,0,0,.45);overflow:hidden}.game-combo-search{width:100%;min-height:2.1rem;padding:.4rem .65rem;font-size:.82rem;background:transparent;border:none;border-bottom:1px solid var(--border-subtle,#3a3a3a);color:var(--text-primary);outline:none}.game-combo-search::placeholder{color:var(--text-muted,#b8a890);opacity:.6}.game-combo-options{overflow-y:auto;overscroll-behavior:contain;padding:.25rem 0}.game-combo-group{padding:.15rem 0}.game-combo-group-label{display:block;padding:.3rem .65rem .15rem;font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted,#b8a890);opacity:.7}.game-combo-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.35rem .65rem;font-size:.82rem;color:var(--text-primary);background:transparent;border:none;cursor:pointer;text-align:left;transition:background 80ms ease}.game-combo-option:hover{background:rgba(232,220,200,.07)}.game-combo-option--active{color:var(--warrior-red);font-weight:600}.game-combo-option--active:before{content:"";display:inline-block;width:3px;height:.85em;margin-right:.4rem;background:var(--warrior-red);border-radius:2px;flex-shrink:0}.game-combo-count{font-size:.72rem;color:var(--text-muted,#b8a890);opacity:.6;margin-left:.5rem;flex-shrink:0}.game-combo-empty{padding:.6rem .65rem;font-size:.82rem;color:var(--text-muted,#b8a890);font-style:italic;margin:0}.filter-bar,.filter-group{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem}.filter-group+.filter-group:before{content:"\00B7";color:var(--text-muted);font-size:1.3rem;line-height:1;margin:0 .15rem}.filter-group-label{font-size:.8rem;color:var(--text-muted);margin-right:.1rem}.filter-clear{font-size:.78rem;color:var(--text-muted);background:none;border:none;cursor:pointer;padding:.2rem .4rem;text-decoration:underline;-webkit-text-decoration-color:rgba(232,220,200,.35);text-decoration-color:rgba(232,220,200,.35);text-underline-offset:2px;transition:color .14s ease;margin-left:auto}.filter-clear:hover{color:var(--dojo-cream)}.filter-bar-header{display:flex;align-items:center;gap:.5rem}.filter-toggle{display:inline-flex;align-items:center;gap:.35rem;background:none;border:none;color:var(--dojo-cream);font-size:.85rem;font-weight:500;cursor:pointer;padding:.3rem .1rem;transition:color .14s ease}.filter-toggle:hover{color:var(--text-primary)}.filter-toggle .expand-chevron{width:1.1rem;height:1.1rem}.filter-summary{color:var(--text-muted);font-size:.78rem;font-weight:400;margin-left:.3rem}.filter-sort{display:inline-flex;align-items:center;gap:.35rem}.filter-bar-header .filter-toggle{margin-left:.25rem}.filter-bar-header .filter-clear{margin-left:auto}.active-filter-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.1rem;margin-bottom:.25rem}.chip{display:inline-flex;align-items:center;border-radius:999px;border:1px solid #564b41;background:rgba(255,255,255,.04);padding:.2rem .58rem;font-size:.78rem;color:var(--text-muted)}.chip-dismiss{gap:.35rem;cursor:pointer;font:inherit;font-size:.78rem;line-height:1.1;color:var(--dojo-cream);transition:border-color .12s ease,color .12s ease}.chip-dismiss:hover{border-color:var(--warrior-red);color:var(--text-primary)}.chip-dismiss-x{font-size:.95rem;line-height:1;opacity:.8}.chip-dismiss:hover .chip-dismiss-x{opacity:1;color:var(--warrior-red)}.chip-link{text-decoration:none;color:inherit;max-width:14rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip-overflow{cursor:pointer;background:none;font:inherit}.chip-link:hover,.chip-overflow:hover{color:var(--text-primary);border-color:var(--warrior-red)}.item-list{display:grid;grid-gap:.75rem;gap:.75rem;min-width:0}.item-list>.card{box-shadow:0 6px 16px rgba(0,0,0,.18)}.item-list>*{animation:enter var(--enter-duration) var(--enter-ease) both}.item-list>:first-child{animation-delay:0s}.item-list>:nth-child(2){animation-delay:50ms}.item-list>:nth-child(3){animation-delay:.1s}.item-list>:nth-child(4){animation-delay:.15s}.item-list>:nth-child(5){animation-delay:.2s}.item-list>:nth-child(6){animation-delay:.25s}.item-list>:nth-child(7){animation-delay:.3s}.item-list>:nth-child(n+8){animation-delay:.35s}.badge{display:inline-block;padding:.1rem .45rem;font-size:.78rem;border-radius:.25rem;background:rgba(232,220,200,.18);border:1px solid rgba(160,53,47,.2)}.badge-personal{background:rgba(70,130,180,.15);border-color:rgba(70,130,180,.35);color:#4682b4}.pill{display:inline-block;padding:.3rem .75rem;font-size:.8rem;border-radius:999px;border:1px solid #4d443b;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.pill:hover{border-color:var(--dojo-cream)}.pill-active,.pill:hover{color:var(--dojo-cream)}.pill-active:hover{background:rgba(160,53,47,.25);border-color:var(--warrior-red-light)}.pill-badge-red{display:inline-block;padding:.08rem .4rem;font-size:.65rem;font-weight:800;letter-spacing:.06em;border-radius:var(--radius-sm);background:var(--warrior-red);color:var(--dojo-cream);text-transform:uppercase;line-height:1.4}.new-badge{margin-left:.35rem;vertical-align:middle;position:relative;top:-.08rem}.badge-inline{margin-left:.5rem;font-size:.6em;vertical-align:middle}.game-picker-row{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left}.game-picker-check{opacity:.5}.game-remove-btn{flex-shrink:0;padding:.1rem .4rem;font-size:1rem;line-height:1;color:var(--danger)}.worked-grouped{display:grid;grid-gap:1.25rem;gap:1.25rem}.game-category-group{display:grid;grid-gap:.5rem;gap:.5rem}.game-category-heading{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:.25rem 0;border-bottom:1px solid var(--surface-card-border);margin:0}.game-group{display:grid;grid-gap:.25rem;gap:.25rem;padding-left:1.25rem;border-left:2px solid rgba(232,220,200,.08)}.game-group .item-list{padding-left:.5rem}.game-group-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;padding:.35rem .25rem;cursor:pointer;color:var(--text-primary);font-size:.85rem;width:100%;text-align:left;border-radius:4px}.game-group-toggle:hover{background:rgba(255,255,255,.04)}.game-group-toggle .chevron{transition:transform .25s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;color:var(--text-muted)}.game-group-toggle .chevron-open{transform:rotate(90deg)}.game-group-heading{display:flex;align-items:center;gap:.5rem;padding:.35rem .25rem;font-size:.85rem;color:var(--text-primary)}.game-group-name{font-weight:500}.game-group-count{font-size:.75rem;color:var(--text-muted);background:rgba(255,255,255,.06);padding:.1rem .4rem;border-radius:8px}.sub-game-group{display:grid;grid-gap:.25rem;gap:.25rem;padding-left:1rem;border-left:2px solid rgba(232,220,200,.06)}.sub-game-group .item-list{padding-left:.5rem}.technique-sub-group{display:grid;grid-gap:.25rem;gap:.25rem;padding-left:1rem;border-left:2px solid rgba(232,220,200,.06);margin-top:.25rem;margin-bottom:.25rem}.sub-game-group-toggle{display:flex;align-items:center;gap:.5rem;background:none;border:none;padding:.3rem .25rem;cursor:pointer;color:var(--text-primary);font-size:.8rem;width:100%;text-align:left;border-radius:4px}.sub-game-group-toggle:hover{background:rgba(255,255,255,.04)}.sub-game-group-toggle .chevron{transition:transform .25s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;color:var(--text-muted)}.sub-game-group-toggle .chevron-open{transform:rotate(90deg)}.sub-game-divider{display:flex;align-items:center;gap:.75rem;margin:1rem 0 .5rem}.sub-game-rule{flex:1 1;border:none;border-top:1px solid rgba(232,220,200,.12)}.sub-game-label{display:flex;align-items:center;gap:.4rem;white-space:nowrap;font-size:.85rem;color:var(--text-primary)}.sub-game-count{color:var(--text-muted);font-size:.8rem}.sub-game-readonly-badge{font-size:.75rem;color:var(--text-muted);background:rgba(255,255,255,.06);padding:.1rem .4rem;border-radius:4px}.main-only-toggle{font-size:.8rem;padding:.2rem .6rem;border-radius:12px;border:1px solid rgba(232,220,200,.15);transition:background .15s,border-color .15s}.main-only-toggle--active{background:rgba(160,53,47,.2);border-color:rgba(160,53,47,.4)}.category-group{display:grid;grid-gap:.25rem;gap:.25rem}.category-group+.category-group{margin-top:1rem}.category-heading{font-size:1rem;font-weight:600;margin:0;padding:.25rem 0;border-bottom:1px solid var(--surface-card-border)}.category-heading-toggle{display:flex;align-items:center;gap:.4rem;width:100%;background:none;border:none;cursor:pointer;font-size:1rem;font-weight:600;color:inherit;padding:.4rem .25rem;border-bottom:1px solid var(--surface-card-border);text-align:left}.category-heading-toggle:hover{background:rgba(255,255,255,.04)}.category-heading-toggle .chevron{transition:transform .25s cubic-bezier(.34,1.56,.64,1);flex-shrink:0;margin-right:.15rem}.category-heading-toggle .chevron-open{transform:rotate(90deg)}.category-count{font-weight:400;color:var(--amber)}.curriculum-technique-list{margin:.25rem 0 0;padding-left:2.2rem;list-style:decimal}.curriculum-technique-list li{margin-bottom:.35rem;font-size:.95rem}.curriculum-technique-list li a{color:var(--text-primary);text-decoration:none}.curriculum-technique-list li a:hover{text-decoration:underline;color:var(--warrior-red)}.games-recent-section{padding-bottom:1rem;border-bottom:1px solid rgba(232,220,200,.1);margin-bottom:.5rem}.games-categories,.games-category-list{display:grid;grid-gap:.25rem;gap:.25rem}.games-category-list{padding-left:.5rem}.games-block{display:grid;grid-gap:0;gap:0}.games-block-row{padding:.15rem 0}.games-block-sub{padding:.5rem 0 .15rem .75rem;margin-top:.25rem;border-top:1px solid rgba(232,220,200,.06)}.games-tree-hint{font-size:.84rem;color:var(--text-muted);padding:.5rem .65rem;border-left:3px solid var(--warrior-red);border-radius:0 6px 6px 0;background:rgba(160,53,47,.06);line-height:1.45}.games-tree-node{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;border-radius:8px;border:2px solid transparent;cursor:-webkit-grab;cursor:grab;transition:opacity .15s ease,border-color .15s ease,background .15s ease;position:relative;-moz-user-select:none;user-select:none;-webkit-user-select:none;touch-action:pan-y}.games-tree-node:hover{background:rgba(255,255,255,.04)}.games-tree-node--child{padding-left:2rem}.games-tree-node--dragging{opacity:.3}.games-tree-node--drop-ready{border-color:rgba(160,53,47,.35);background:rgba(160,53,47,.04)}.games-tree-node--drop-active{border-color:var(--warrior-red);background:var(--warrior-red-dim);box-shadow:0 0 0 2px rgba(160,53,47,.25)}.category-heading-toggle--drop-ready{border:2px solid rgba(160,53,47,.35);background:rgba(160,53,47,.04);border-radius:6px;position:relative}.category-heading-toggle--drop-active{border:2px solid var(--warrior-red)!important;background:var(--warrior-red-dim)!important;border-radius:6px;position:relative}.games-tree-ghost{background:var(--surface-2);color:var(--text-primary);border:2px solid var(--warrior-red);border-radius:8px;padding:.35rem .75rem;font-size:.88rem;font-weight:600;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.4)}.games-tree-drag-handle,.games-tree-ghost{-webkit-user-select:none;-moz-user-select:none;user-select:none}.games-tree-drag-handle{color:var(--text-muted);font-size:1rem;line-height:1;cursor:-webkit-grab;cursor:grab;padding:.15rem .1rem;border-radius:4px;transition:color .12s ease,background .12s ease}.games-tree-drag-handle:hover{color:var(--text-primary);background:rgba(255,255,255,.08)}.games-tree-name{flex:1 1;font-size:.95rem;font-weight:500;min-width:0;overflow-wrap:anywhere}.games-tree-create-row{display:flex;gap:.5rem;align-items:center;padding:.35rem .6rem;margin-top:.25rem}.games-tree-create-row input{flex:1 1;min-height:2rem;padding:.35rem .55rem;border-radius:8px;font-size:.88rem}.games-tree-create-row .ds-btn--primary{padding:.35rem .75rem;font-size:.82rem}.week-divider{border:none;border-top:1px solid var(--surface-card-border);margin:.25rem 0}.tech-row-list,.tech-toolbar{display:grid;grid-gap:.55rem;gap:.55rem}.tech-search-inline{max-width:36rem}.tech-row{display:grid;grid-template-columns:7.5rem minmax(0,1fr) auto;align-items:center;grid-gap:1rem;gap:1rem;padding:.82rem .96rem;border:1px solid var(--border-subtle);border-radius:12px;background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.01));transition:border-color .12s ease,box-shadow .12s ease,transform .12s ease}.tech-row:hover{border-color:#5e5348;box-shadow:0 8px 18px rgba(0,0,0,.24);transform:translateY(-1px)}@media (hover:none){.tech-row:hover{transform:none}}.tech-row-thumb-wrap{display:flex;align-items:center}.tech-row-thumb{width:7rem;height:4.2rem;border-radius:10px;border:1px solid #564b41;object-fit:cover}.placeholder-thumb{--placeholder-accent:rgba(160,53,47,0.28);background:linear-gradient(145deg,var(--placeholder-accent),rgba(26,26,26,.92));color:var(--dojo-cream);display:flex;align-items:center;justify-content:center;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase;font-weight:700}.placeholder-thumb[data-category=guard]{--placeholder-accent:rgba(37,99,235,0.32)}.placeholder-thumb[data-category=pass]{--placeholder-accent:rgba(220,38,38,0.3)}.placeholder-thumb[data-category=attack]{--placeholder-accent:rgba(234,88,12,0.32)}.placeholder-thumb[data-category=position]{--placeholder-accent:rgba(124,58,237,0.32)}.placeholder-thumb[data-category=movement]{--placeholder-accent:rgba(5,150,105,0.3)}.placeholder-thumb[data-category=warm_up]{--placeholder-accent:rgba(202,138,4,0.32)}.placeholder-thumb[data-category=standing]{--placeholder-accent:rgba(8,145,178,0.32)}.placeholder-thumb[data-category=nogi]{--placeholder-accent:rgba(13,148,136,0.32)}.placeholder-thumb[data-category=other]{--placeholder-accent:rgba(107,114,128,0.28)}.tech-row-main{min-width:0;display:grid;grid-gap:.28rem;gap:.28rem}.game-pills{display:flex;flex-wrap:wrap;gap:.3rem}.game-pill{display:inline-block;padding:.12rem .5rem;font-size:.75rem;font-weight:600;border-radius:999px;background:rgba(160,53,47,.12);border:1px solid rgba(160,53,47,.3);color:var(--warrior-red-light);text-decoration:none;transition:background .14s ease,border-color .14s ease}.game-pill:hover{background:rgba(160,53,47,.22);border-color:var(--warrior-red);color:var(--dojo-cream)}.tech-row-title{margin:0;font-size:1rem;line-height:1.3;overflow-wrap:anywhere}.tech-row-title .taiko-link,.tech-row-title a{color:var(--warrior-red);font-weight:700;text-decoration:none;transition:color .14s ease}.tech-row-title .taiko-link:hover,.tech-row-title a:hover{color:var(--warrior-red-light);text-decoration:underline}.tech-row-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:.22rem .65rem;gap:.22rem .65rem}.tech-row-meta .card-subtitle{margin:0;overflow-wrap:anywhere}.tech-row-link{word-break:break-all}.tech-row-grid{display:grid;grid-template-columns:7.5rem minmax(0,1fr) auto;align-items:center;grid-gap:.8rem;gap:.8rem;position:relative}.tech-row-grid:hover{border-color:#4a403a;box-shadow:0 4px 12px rgba(0,0,0,.3),0 1px 3px rgba(0,0,0,.2),0 0 0 1px rgba(160,53,47,.15),inset 0 1px 0 rgba(255,255,255,.03)}.thin-game-dot{display:inline-block;width:.5rem;height:.5rem;border-radius:50%;margin-left:.45rem;vertical-align:middle;flex-shrink:0}.thin-game-dot--amber{background:var(--amber);box-shadow:0 0 6px var(--amber-glow)}.thin-game-dot--red{background:var(--danger);box-shadow:0 0 6px rgba(192,57,43,.35)}.tech-detail-head{display:flex;align-items:center}.breadcrumb{margin:0 0 1rem;font-size:.84rem;color:var(--text-muted)}.breadcrumb__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .35rem}.breadcrumb__item{display:inline-flex;align-items:center;gap:.35rem;min-width:0}.breadcrumb__link{color:var(--text-muted);text-decoration:none;transition:color .14s ease}.breadcrumb__current,.breadcrumb__link:hover{color:var(--text-primary)}.breadcrumb__current{font-weight:600;max-width:60ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.breadcrumb__separator{color:var(--text-muted);opacity:.7}.breadcrumb__collapsed{display:none;color:var(--text-muted);text-decoration:none}.breadcrumb__collapsed:hover{color:var(--text-primary)}@media (max-width:640px){.breadcrumb__list{display:none}.breadcrumb__collapsed{display:inline-flex;align-items:center;gap:.35rem}}.sticky-mini-header{position:fixed;top:0;left:0;right:0;height:40px;padding:0 1rem;display:flex;align-items:center;gap:.75rem;background:rgba(17,17,17,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(232,220,200,.08);transform:translateY(-100%);transition:transform .2s ease;z-index:60;pointer-events:none}.sticky-mini-header--visible{transform:translateY(0);pointer-events:auto}.sticky-mini-header__back{color:var(--text-muted);text-decoration:none;font-size:1.1rem;line-height:1;padding:.25rem .4rem;border-radius:var(--radius-sm);transition:color .14s ease,background .14s ease}.sticky-mini-header__back:hover{color:var(--text-primary);background:rgba(232,220,200,.08)}.sticky-mini-header__title{color:var(--text-primary);font-weight:700;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}@media (prefers-reduced-motion:reduce){.sticky-mini-header{transition:none}}.tech-meta-dl{display:grid;grid-template-columns:auto 1fr;grid-gap:.45rem 1rem;gap:.45rem 1rem;align-items:baseline;margin:0}.tech-meta-dl dt{color:var(--text-muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.tech-meta-dl dd{margin:0;font-size:.9rem;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.meta-separator{grid-column:1/-1;border-top:1px solid var(--surface-card-border);margin:.3rem 0}.tech-detail-actions{margin-top:.1rem}.tech-detail-actions-secondary{padding-top:.35rem;border-top:1px solid var(--surface-card-border)}.notes-list{gap:.6rem}.note-item{border-left:3px solid var(--warrior-red)}.note-meta{font-size:.82rem;letter-spacing:.01em}.note-content{color:var(--text-primary);line-height:1.5}.tech-row-actions{display:flex;align-items:center;justify-content:flex-end}.tech-row-actions-stack{display:grid;grid-gap:.45rem;gap:.45rem}.drill-toggle{padding:.3rem;line-height:1}.tech-row-footer{grid-column:1/-1}.tech-count{margin:0;color:var(--amber);font-size:.84rem}.section-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:.75rem;min-width:0}.section-title{margin:0;font-size:.95rem;letter-spacing:.03em;color:rgba(232,220,200,.55)}.empty-state{border:1px dashed rgba(100,90,80,.55);border-radius:10px;font-style:italic}.empty-state,.loading-state{margin:0;padding:.75rem .85rem;color:var(--text-muted);font-size:.92rem;text-align:center}.loading-state{animation:pulse 1.8s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-list{display:grid;grid-gap:.7rem;gap:.7rem}.skeleton-card{display:grid;grid-template-columns:88px 1fr;grid-gap:.85rem;gap:.85rem;padding:.85rem;border:1px solid var(--surface-card-border);border-radius:var(--radius-md);background:var(--surface-card)}.skeleton-bar,.skeleton-thumb{background:linear-gradient(90deg,rgba(232,220,200,.04),rgba(232,220,200,.1) 50%,rgba(232,220,200,.04));background-size:800px 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:6px}.skeleton-thumb{height:58px}.skeleton-bar{height:12px}.skeleton-bar--title{width:65%;height:14px;margin-bottom:.5rem}.skeleton-bar--sub{width:40%;height:10px}@media (prefers-reduced-motion:reduce){.skeleton-bar,.skeleton-thumb{animation:none}}.empty-state-polished{flex-direction:column;gap:.85rem;padding:2rem 1rem;text-align:center}.empty-state-polished,.empty-state-polished__text{display:flex;align-items:center;color:var(--text-muted)}.empty-state-polished__text{margin:0;gap:.75rem;font-size:.95rem}.empty-state-polished__text:after,.empty-state-polished__text:before{content:"";display:block;width:32px;height:1px;background:rgba(232,220,200,.18)}.muted{color:var(--text-muted)}.danger{color:var(--warrior-red)}.drag-over{outline:2px dashed var(--warrior-red);border-radius:8px;background:var(--warrior-red-dim)}.focus-card{display:flex;align-items:center;gap:1rem}.focus-card-link{flex:1 1;min-width:0;text-decoration:none;color:inherit;display:flex;align-items:baseline;flex-wrap:wrap;gap:.25rem .5rem}.focus-card-meta{display:inline-flex;gap:.5rem}.focus-edit-hint{cursor:pointer}.focus-edit-hint:after{content:" \270E";font-size:.7em;opacity:.35;transition:opacity .14s ease}.focus-edit-hint:hover{text-decoration:underline;-webkit-text-decoration-style:dashed;text-decoration-style:dashed;-webkit-text-decoration-color:var(--text-muted);text-decoration-color:var(--text-muted)}.focus-edit-hint:hover:after{opacity:.7}.technique-row{display:flex;align-items:flex-start;gap:.55rem;touch-action:pan-y}.drag-handle{touch-action:none;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:#6b5c51;font-size:1.1rem;flex-shrink:0;display:flex;align-items:center;padding:0 .25rem}.technique-row .ds-checkbox{margin-top:.6rem}.technique-row--selected{outline:2px solid rgba(192,57,43,.45);border-radius:8px}.technique-row>.card,.technique-row>.ds-card{flex:1 1;min-width:0}.bulk-action-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;padding:.55rem .75rem;background:#272320;border:1px solid #3d342b;border-radius:8px;position:-webkit-sticky;position:sticky;top:0;z-index:20}.bulk-action-count{font-size:.85rem;color:#8a7e72;margin-right:auto;white-space:nowrap}.bulk-move-panel{padding:.55rem 0}.bulk-new-game-panel{display:flex;flex-direction:column;gap:.55rem;padding:.75rem;background:#272320;border:1px solid #3d342b;border-radius:8px}.inline-actions{display:flex;align-items:center;gap:.25rem}.card-kebab-wrapper{position:relative;flex-shrink:0}.card-kebab-btn{font-size:1.2rem;padding:.2rem .5rem;line-height:1}.card-kebab-dropdown{position:absolute;right:0;top:100%;z-index:30;min-width:210px;background:#272320;border:1px solid #3d342b;border-radius:8px;padding:.35rem 0;box-shadow:0 4px 16px rgba(0,0,0,.5);display:flex;flex-direction:column}.card-kebab-dropdown .ds-btn--ghost-list{padding:.45rem .85rem;border-radius:0}.kebab-separator{border:none;border-top:1px solid #3d342b;margin:.25rem 0}.card-action-popover{margin-top:.5rem}.bulk-action-toast{position:fixed;top:1.25rem;right:1.25rem;background:#0f2318;color:#6ee7a0;border:1px solid rgba(39,174,96,.3);padding:.7rem 1.2rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;z-index:1000;pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,.6);max-width:420px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;transform:translateX(.75rem);transition:opacity .2s ease,transform .2s ease}.bulk-action-toast[data-visible=true]{opacity:1;transform:translateX(0)}@media (max-width:480px){.bulk-action-toast{top:auto;bottom:calc(1.25rem + env(safe-area-inset-bottom, 0px));right:1rem;left:1rem;max-width:none;white-space:normal;overflow:visible;text-overflow:clip;text-align:center;transform:translateY(.75rem)}.bulk-action-toast[data-visible=true]{transform:translateY(0)}}.expand-chevron{transition:transform .25s cubic-bezier(.34,1.56,.64,1);flex-shrink:0}.expand-chevron--open{transform:rotate(180deg)}.expand-spinner{display:inline-block;width:10px;height:10px;border:1.5px solid var(--text-muted);border-top:1.5px solid transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.teaching-notes-callout{margin-top:.35rem;padding:.4rem .6rem;border-left:3px solid var(--warrior-red);border-radius:var(--radius-sm);background:rgba(160,53,47,.06)}.teaching-notes-callout .field-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.04em}.teaching-notes-text{margin:.15rem 0 0;font-size:.88rem;color:var(--text-primary);white-space:pre-wrap;line-height:1.45}.technique-inline-list{list-style:none;margin:.6rem 0 0;padding:0;display:grid;grid-gap:.35rem;gap:.35rem}.technique-inline-item{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;padding:.3rem .55rem;border-radius:var(--radius-sm);background:rgba(255,255,255,.03);border-left:3px solid var(--border-subtle);font-size:.88rem}.technique-inline-item--done{border-left-color:#3a9a5c}.technique-inline-item--removed{border-left-color:var(--warrior-red);opacity:.6}.technique-inline-title{color:var(--text-primary);min-width:0;overflow-wrap:anywhere}.technique-inline-meta{color:var(--text-muted);font-size:.78rem;white-space:nowrap;flex-shrink:0}.entity-title{margin:0 0 1.25rem;font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:800;letter-spacing:-.01em;color:var(--text-primary);border-bottom:2px solid var(--warrior-red);padding-bottom:.6rem}.admin-actions{display:flex;flex-wrap:wrap;gap:.55rem}.admin-status-list{gap:.45rem}.admin-progress-list{margin-top:.4rem;display:grid;grid-gap:.2rem;gap:.2rem}.private-lessons-form{gap:.7rem}.private-lessons-form .field{gap:.25rem}.private-lessons-form .field-label{font-size:.76rem}.technique-search-field{position:relative}.tech-search-wide{grid-column:span 2}.tech-search-head{display:grid;grid-gap:.45rem;gap:.45rem;grid-template-columns:minmax(0,1fr)}.tech-search-categories{display:flex;flex-wrap:wrap;gap:.45rem}.tech-search-categories button{padding:.3rem .72rem;border-radius:var(--radius-pill);font-size:.8rem}.tech-search-input-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.tech-search-input-row>input{flex:1 1;min-width:0}.tech-search-input{min-height:2.35rem}.tech-search-dropdown{position:relative;margin-top:.35rem;padding:.65rem;background:#181614;border-color:#52483f;box-shadow:0 14px 28px rgba(0,0,0,.42)}.tech-search-list{display:grid;grid-gap:.45rem;gap:.45rem}.tech-search-scroll{max-height:18rem;overflow:auto}.tech-search-row{display:flex;align-items:center;justify-content:space-between;gap:.55rem;border:1px solid var(--border-subtle);border-radius:10px;padding:.5rem .6rem;background:rgba(255,255,255,.02)}.tech-search-meta{min-width:0}.tech-search-title{margin:0;font-size:.92rem;font-weight:600;line-height:1.3}.technique-results-panel{margin-top:.35rem;background:#181614;border-color:#52483f}.game-filter-toggle{display:flex;align-items:center}.game-combobox{display:flex;flex-direction:column;gap:.35rem}.game-suggestions{display:flex;flex-wrap:wrap;gap:.35rem}.data-table{width:100%;border-collapse:collapse;font-size:.92rem}.data-table td,.data-table th{padding:.55rem .8rem;text-align:left}.data-table th{color:var(--text-muted);font-weight:600;font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-subtle)}.data-table td{border-bottom:1px solid rgba(232,220,200,.05)}.data-table tr:last-child td{border-bottom:none}@media (max-width:760px){.nav-strip{display:none}.app-topbar{margin-bottom:.5rem}main{padding-bottom:calc(64px + env(safe-area-inset-bottom, 0px))}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:100;height:calc(60px + env(safe-area-inset-bottom, 0px));padding-bottom:env(safe-area-inset-bottom,0);background:rgba(17,17,17,.94);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--surface-card-border);align-items:flex-start;justify-content:space-around}.mobile-nav-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;flex:1 1;padding:.5rem .25rem .3rem;background:none;border:none;color:var(--text-muted);text-decoration:none;cursor:pointer;transition:color .14s ease;-webkit-tap-highlight-color:transparent}.mobile-nav-tab:hover{color:var(--text-primary)}.mobile-nav-tab[data-active=true]{color:var(--warrior-red)}.mobile-nav-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px}.mobile-nav-icon svg{width:22px;height:22px}.mobile-nav-label{font-size:.62rem;font-weight:600;letter-spacing:.02em;line-height:1}.inline-grid,.tech-row{grid-template-columns:1fr}.tech-row{align-items:start}.tech-row-grid,.tech-row-meta{grid-template-columns:1fr}.tech-row-actions,.tech-row-actions-stack{justify-content:flex-start}.tech-row-actions-stack{position:static;display:flex;flex-wrap:wrap;gap:.35rem}.page-title{line-height:1.2}.tech-search-head{grid-template-columns:1fr}.tech-search-wide{grid-column:span 1}.tech-row-thumb{max-width:100%}.section-head{gap:.5rem}.bulk-action-bar{flex-direction:column;align-items:stretch;gap:.35rem}.bulk-action-bar .btn-muted{text-align:center}.card-kebab-dropdown{position:fixed;right:1rem;left:1rem;top:auto;bottom:1rem;min-width:unset}.card[data-category]{border-left-width:3px;border-left-style:solid}.card[data-category=guard]{border-left-color:#2563eb}.card[data-category=pass]{border-left-color:#dc2626}.card[data-category=attack]{border-left-color:#ea580c}.card[data-category=position]{border-left-color:#7c3aed}.card[data-category=movement]{border-left-color:#059669}.card[data-category=warm_up]{border-left-color:#ca8a04}.card[data-category=standing]{border-left-color:#0891b2}.card[data-category=nogi]{border-left-color:#0d9488}.card[data-category=other]{border-left-color:#6b7280}}@media (max-width:480px){main{padding-left:.6rem;padding-right:.6rem}.card{padding:.7rem}.tech-row{padding:.6rem;gap:.6rem}.tech-row-thumb{width:5rem;height:3rem}.technique-row{gap:.35rem}.reorder-compact-row{gap:.3rem;padding:.25rem .35rem}.reorder-compact-actions{gap:.1rem}}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:1rem;gap:1rem}.media-card{display:flex;flex-direction:column;background:var(--surface-card);border:1px solid var(--surface-card-border);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;transition:border-color .15s}.media-card:hover{border-color:var(--warrior-red)}.media-card-thumb{width:100%;aspect-ratio:16/9;object-fit:cover;background:var(--surface-2)}.media-card-thumb-placeholder{display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.8rem}.media-card-info{padding:.6rem .75rem;display:flex;flex-direction:column;gap:.25rem}.media-card-title{font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.media-card-duration{font-size:.75rem;color:var(--text-muted)}.media-detail-layout{display:grid;grid-template-columns:1fr 320px;grid-gap:1.5rem;gap:1.5rem;align-items:start}.media-detail-main{min-width:0}.media-detail-sidebar{display:grid;grid-gap:.75rem;gap:.75rem}.media-detail-sidebar-heading{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0}.media-detail-sidebar-label{font-size:.82rem;color:var(--text-muted);margin:0}.state-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.15rem .55rem;font-size:.78rem;font-weight:500}.state-badge--encoding{background:var(--amber-dim);color:var(--amber);border:1px solid var(--amber-glow)}.state-badge--error{background:rgba(160,53,47,.15);color:var(--warrior-red-light);border:1px solid rgba(160,53,47,.3)}.student-context-panel{margin-top:1rem}.student-context-toggle{display:flex;align-items:center;gap:.5rem;width:100%;background:none;border:none;color:var(--text-primary);font-size:1rem;font-weight:600;padding:.75rem 0;cursor:pointer;min-height:44px}.context-section{margin-top:.75rem}.context-section-title{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.context-lesson-entry{padding:.5rem 0;border-bottom:1px solid var(--surface-card-border)}.context-lesson-entry:last-child{border-bottom:none}.context-lesson-date{font-size:.85rem;color:var(--text-muted)}.context-lesson-techniques{font-size:.9rem;color:var(--text-secondary,var(--text-primary));margin-top:.15rem}.context-status-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem 0;border-bottom:1px solid var(--surface-card-border);flex-wrap:wrap}.context-status-row:last-child{border-bottom:none}.context-technique-info{display:flex;align-items:center;gap:.5rem;min-width:0;flex:1 1}.context-technique-info a{color:var(--text-primary);text-decoration:none;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.context-technique-info a:hover{color:var(--warrior-red-light)}.context-status-buttons{display:flex;gap:.3rem;flex-shrink:0}.focus-area-links{display:flex;flex-wrap:wrap;gap:.4rem}.focus-area-links a{display:inline-flex;padding:.2rem .55rem;border-radius:var(--radius-pill);font-size:.8rem;background:rgba(255,255,255,.06);border:1px solid var(--surface-card-border);color:var(--text-primary);text-decoration:none;transition:all .14s ease}.focus-area-links a:hover{background:rgba(255,255,255,.1);border-color:var(--warrior-red);color:var(--warrior-red-light)}.context-empty{font-size:.85rem;color:var(--text-muted);font-style:italic}.btn-done-toggle{min-height:44px;min-width:44px;padding:.35rem .8rem;font-size:.82rem}@keyframes done-flash{0%{background-color:rgba(39,174,96,.25)}to{background-color:transparent}}.done-flash{animation:done-flash .6s ease-out}.filter-pills{display:flex;gap:.35rem;flex-wrap:wrap;margin-bottom:.5rem}.pill-active,.pill-inactive{background:var(--surface-2);border:1px solid var(--surface-card-border);border-radius:999px;padding:.3rem .75rem;font-size:.82rem;font-weight:500;cursor:pointer;color:var(--text-muted);transition:background .12s ease,color .12s ease,border-color .12s ease}.pill-active{background:rgba(160,53,47,.15);border-color:var(--warrior-red);color:var(--text-primary)}.pill-inactive:hover{border-color:var(--text-muted);color:var(--text-primary)}.pill-count{font-weight:400;margin-left:.2rem;opacity:.7}.history-timeline{display:grid;grid-gap:1rem;gap:1rem}.history-date-group{display:grid;grid-gap:.25rem;gap:.25rem}.history-date-heading{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.2rem 0;border-bottom:1px solid var(--surface-card-border);margin:0}.history-entry{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;padding:.4rem .6rem;border-left:2px solid var(--border-subtle);margin-left:.25rem;font-size:.88rem}.history-entry-title{color:var(--text-primary);font-weight:500;min-width:0;overflow-wrap:anywhere}.history-entry-meta{color:var(--text-muted);font-size:.78rem;white-space:nowrap;flex-shrink:0}@media (max-width:480px){.history-entry{flex-direction:column;gap:.1rem}}@media (max-width:760px){.media-detail-layout{grid-template-columns:1fr}}.carousel-controls,.video-carousel{display:flex;flex-direction:column;gap:.5rem}.carousel-nav{display:flex;align-items:center;justify-content:center;gap:.75rem}.carousel-arrow{font-size:1.5rem;line-height:1;padding:.15rem .5rem;min-width:2rem;text-align:center}.carousel-counter{font-size:.85rem;color:var(--text-muted);min-width:3rem;text-align:center}.carousel-thumbnails{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem 0}.carousel-thumb-wrapper{position:relative;flex-shrink:0}.carousel-thumb{display:block;width:5rem;height:3.5rem;border-radius:var(--radius-sm);border:2px solid transparent;overflow:hidden;cursor:pointer;padding:0;background:var(--surface-card);transition:border-color .15s,box-shadow .15s}.carousel-thumb:hover{border-color:var(--text-muted)}.carousel-thumb-active{border-color:var(--warrior-red);box-shadow:0 0 0 2px var(--warrior-red)}.carousel-thumb-img{width:100%;height:100%;object-fit:cover}.carousel-thumb-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;width:100%;height:100%;font-size:.9rem;color:var(--text-muted);background:var(--surface-2)}.carousel-thumb-badge{font-size:.6rem;letter-spacing:.03em}.carousel-badge,.carousel-thumb-badge{font-weight:700;color:var(--warrior-red)}.carousel-badge{font-size:.7rem;margin-right:.15rem}.carousel-label{font-size:.8rem;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block;vertical-align:middle}@media (max-width:640px){.carousel-label{max-width:10rem}}.carousel-thumb-delete{position:absolute;top:-.35rem;right:-.35rem;width:1.25rem;height:1.25rem;border-radius:50%;border:none;background:var(--danger);color:#fff;font-size:.75rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.carousel-thumb-wrapper:hover .carousel-thumb-delete{opacity:1}@media (hover:none){.carousel-thumb-delete{opacity:1}}.class-quick-add-popover{position:absolute;right:0;top:100%;z-index:50;min-width:220px;max-width:300px;padding:.5rem;box-shadow:0 4px 12px rgba(0,0,0,.15);display:flex;flex-direction:column;gap:.35rem}.class-quick-add-list{display:flex;flex-direction:column;gap:.25rem}.class-quick-add-create{display:flex;flex-direction:column;gap:.4rem}.class-quick-add-added-marker{margin-left:.3rem;opacity:.6}@media (max-width:760px){.class-quick-add-popover{position:fixed;left:1rem;right:1rem;top:auto;bottom:1rem;min-width:unset;max-width:unset;box-shadow:0 -4px 20px rgba(0,0,0,.25)}}.reorder-compact-list{display:flex;flex-direction:column;gap:.15rem}.reorder-compact-row{display:flex;align-items:center;gap:.5rem;padding:.3rem .5rem;border-radius:4px;background:var(--surface-card,#fff);border:1px solid var(--border,#e0e0e0);min-height:2.5rem;cursor:-webkit-grab;cursor:grab;transition:border-color .15s,box-shadow .15s}.reorder-compact-row:active{cursor:-webkit-grabbing;cursor:grabbing}.reorder-compact-row--drag-over{border-color:var(--warrior-red,#c53030);box-shadow:0 0 0 2px rgba(197,48,48,.2)}.reorder-compact-handle{font-size:.8rem;color:var(--text-muted,#888);cursor:-webkit-grab;cursor:grab;flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.reorder-compact-thumb{width:2rem;height:2rem;object-fit:cover;border-radius:3px;flex-shrink:0;background:var(--surface-2,#f0f0f0)}.reorder-compact-index{font-size:.72rem;color:var(--text-muted,#888);min-width:1.2rem;text-align:right;flex-shrink:0}.reorder-compact-title{flex:1 1;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reorder-compact-actions{display:flex;gap:.15rem;flex-shrink:0}.image-gallery{display:flex;flex-direction:column;gap:.75rem}.image-gallery-main{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--surface-card)}.image-gallery-main img{width:100%;max-height:500px;object-fit:contain;display:block}.image-gallery-note{padding:.5rem .75rem;font-size:.85rem;color:var(--text-muted);background:var(--surface-2);border-top:1px solid var(--border)}.image-gallery-nav{display:flex;align-items:center;justify-content:center;gap:.5rem}.image-gallery-counter{font-size:.8rem;color:var(--text-muted)}.lightbox-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;animation:enter-fade var(--enter-duration-fast) ease both}.lightbox-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:.75rem;animation:enter-scale var(--enter-duration-fast) var(--enter-ease) both}@media (max-width:768px){.lightbox-content{animation:enter-slide-up var(--enter-duration-fast) var(--enter-ease) both}}.lightbox-content img{max-width:90vw;max-height:75vh;object-fit:contain;border-radius:var(--radius)}.lightbox-close{top:-2rem;right:-1rem;background:none;font-size:1.5rem;padding:.25rem .5rem}.lightbox-arrow,.lightbox-close{position:absolute;border:none;color:#fff;cursor:pointer}.lightbox-arrow{top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);font-size:2rem;padding:.5rem;border-radius:var(--radius-sm)}.lightbox-arrow:hover{background:rgba(255,255,255,.25)}.lightbox-arrow-prev{left:-3.5rem}.lightbox-arrow-next{right:-3.5rem}.lightbox-note{color:#eee;font-size:.9rem;text-align:center;max-width:600px}.lightbox-note-edit{display:flex;flex-direction:column;gap:.5rem;width:100%;max-width:600px}.lightbox-note-edit textarea{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:var(--radius-sm);padding:.5rem;font-size:.85rem;resize:vertical;min-height:3rem}.lightbox-note-actions{display:flex;gap:.5rem;justify-content:flex-end}.focus-captures-section{margin-top:1rem;padding:.75rem .75rem .5rem;background:linear-gradient(180deg,rgba(160,53,47,.06) 0,var(--surface-1) 40%);border:1px solid var(--border-subtle);border-left:3px solid var(--warrior-red);border-radius:var(--radius-sm);overflow:hidden;min-width:0}.focus-captures-header{display:flex;align-items:flex-start;gap:.5rem}.focus-captures-header .carousel-thumbnails{flex:1 1;min-width:0;padding-bottom:.5rem}.focus-captures-header .btn-muted{flex-shrink:0;white-space:nowrap;margin-top:.25rem}.capture-number-badge-inline{flex-shrink:0;min-width:1.4rem;height:1.4rem;font-size:.75rem;padding:0 .25rem}.capture-number-badge,.capture-number-badge-inline{display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;background:var(--warrior-red);border-radius:var(--radius-sm);line-height:1}.capture-number-badge{position:absolute;bottom:2px;left:2px;min-width:1.1rem;height:1.1rem;font-size:.65rem;padding:0 .2rem;pointer-events:none}.focus-capture-detail{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.5rem;animation:focus-fade-in .2s ease-out}@keyframes focus-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.focus-capture-detail .image-gallery-main{position:relative;border-radius:var(--radius-sm);border:1px solid var(--border-subtle);overflow:hidden;max-width:100%}.focus-capture-detail+.focus-capture-detail{margin-top:.75rem;padding-top:.75rem}.focus-capture-detail .image-gallery-main img{max-height:400px;max-width:100%}.focus-capture-note-row{display:flex;gap:.5rem;align-items:center}.focus-capture-detail input{font-size:.85rem;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);padding:.4rem .6rem;transition:border-color .15s ease}.focus-capture-detail input:focus{outline:none;border-color:var(--warrior-red);box-shadow:0 0 0 2px var(--focus-glow)}.focus-capture-detail input::placeholder{color:var(--text-muted);font-style:italic}.focus-notes-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.focus-notes-list{display:flex;flex-direction:column;gap:.5rem}.focus-note-add{margin-bottom:.75rem;padding:.75rem;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--radius-sm)}.focus-note-add textarea{width:100%}.focus-note-card{padding:.6rem .75rem;background:var(--surface-card);border:1px solid var(--surface-card-border);border-radius:var(--radius-sm);transition:border-color .15s ease}.focus-note-card:hover{border-color:var(--border-subtle)}.focus-note-text{margin:0 0 .35rem;font-size:.9rem;line-height:1.5;white-space:pre-wrap;color:var(--text-primary)}.focus-note-meta{display:flex;align-items:center;gap:.5rem}.focus-note-date{font-size:.75rem;color:var(--text-muted)}.focus-note-action{font-size:.75rem;opacity:0;transition:opacity .15s ease}.focus-note-card:hover .focus-note-action{opacity:1}@media (hover:none){.focus-note-action{opacity:1}}.focus-images-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-subtle);position:relative}.focus-section-label{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.focus-section-label:after{content:"";flex:1 1;height:1px;background:var(--border-subtle)}.focus-capture-btn{margin-top:.5rem;display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.82rem;font-weight:600;background:rgba(160,53,47,.12);border:1px solid rgba(160,53,47,.35);border-radius:var(--radius-sm);color:var(--warrior-red-light);cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.focus-capture-btn:not(:disabled):hover{background:rgba(160,53,47,.22);border-color:var(--warrior-red);box-shadow:0 1px 6px rgba(160,53,47,.2)}.focus-capture-btn:disabled{opacity:.5;cursor:not-allowed}.focus-tech-row-expand,.focus-tech-row-header{display:flex;align-items:center;gap:.75rem}.focus-tech-row-expand{flex:1 1;min-width:0;cursor:pointer;border-radius:var(--radius-sm);padding:.15rem .25rem;margin:-.15rem -.25rem;transition:background .12s ease}.focus-tech-row-expand:hover{background:rgba(255,255,255,.04)}.focus-tech-row-expand:focus-visible{outline:2px solid var(--warrior-red);outline-offset:2px}.focus-video-controls{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.card iframe,.card video{max-width:100%;box-sizing:border-box}@media (max-width:760px){.focus-captures-header{flex-direction:column;align-items:stretch}.focus-captures-header .btn-muted{align-self:flex-start}.focus-tech-row-expand{gap:.5rem}.focus-video-controls{flex-wrap:wrap}}@media (max-width:480px){.focus-captures-section{padding:.5rem .5rem .35rem}.focus-tech-row-header{flex-wrap:wrap;gap:.5rem}.focus-capture-note-row{flex-direction:column;align-items:stretch}.focus-capture-note-row .btn-primary{align-self:flex-start}.focus-notes-header{flex-wrap:wrap}.focus-video-controls{gap:.5rem}.focus-captures-section .carousel-thumb{width:4rem;height:2.75rem}.focus-captures-section .carousel-thumb-delete{width:1.5rem;height:1.5rem;font-size:.85rem}.focus-capture-detail .image-gallery-main img{max-height:60vh}}