@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/_astro/inter-latin-400-normal.C38fXH4l.woff2) format("woff2"),url(/_astro/inter-latin-400-normal.CyCys3Eg.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:500;src:url(/_astro/inter-latin-500-normal.Cerq10X2.woff2) format("woff2"),url(/_astro/inter-latin-500-normal.BL9OpVg8.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:600;src:url(/_astro/inter-latin-600-normal.LgqL8muc.woff2) format("woff2"),url(/_astro/inter-latin-600-normal.CiBQ2DWP.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:700;src:url(/_astro/inter-latin-700-normal.Yt3aPRUw.woff2) format("woff2"),url(/_astro/inter-latin-700-normal.BLAVimhd.woff) format("woff")}*,*:before,*:after{box-sizing:border-box;font-family:inherit}body{margin:0;font-family:Inter,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}body.admin-booting .top,body.admin-booting .layout,body.admin-booting #flash-msg{visibility:hidden}.admin-loading-overlay{position:fixed;inset:0;z-index:180;display:grid;place-items:center;background:color-mix(in srgb,var(--bg) 82%,#fff 18%);transition:opacity .22s ease,visibility .22s ease}.admin-loading-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}.admin-loading-card{min-width:220px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow);padding:14px 16px;display:flex;align-items:center;gap:10px;color:var(--text);font-weight:600;font-size:.92rem}.admin-loading-spinner{width:18px;height:18px;border-radius:999px;border:2px solid color-mix(in srgb,var(--primary) 28%,var(--border));border-top-color:var(--primary);animation:admin-spin .8s linear infinite;flex:0 0 18px}@keyframes admin-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.top{position:sticky;top:0;z-index:40;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--surface);border-bottom:1px solid var(--border)}.title{margin:0;font-size:1.1rem}.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.icon-only-btn{width:34px;height:34px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.icon-only-btn svg{width:16px;height:16px;display:block}.ui-svg{display:inline-flex;align-items:center;justify-content:center;line-height:0}.ui-svg svg{width:16px;height:16px;display:block;fill:currentColor}.btn{border:1px solid #00000000;background:var(--surface);color:var(--muted);border-radius:5px;padding:8px 10px;text-decoration:none;cursor:pointer;font-size:.8rem;font-weight:600;box-shadow:0 2px 2px #2254}.btn:hover{box-shadow:0 2px 2px #2254,inset 0 -5px 30px 1px #dde7;border:solid 1px #0000000a;transition:box-shadow .2s ease}.btn.primary{border:1px solid transparent;background:var(--primary);color:#fff;box-shadow:0 2px 2px #2254}.btn.primary:hover{background:color-mix(in srgb,var(--primary) 88%,#000 12%)}.btn.ghost{border-color:var(--primary);color:var(--primary);background:transparent}.btn.danger{border-color:var(--danger);color:var(--danger);background:transparent}.btn.danger-solid{border-color:#7f1d1d;background:#7f1d1d;color:#fff}.btn.danger-solid:hover{border-color:#991b1b;background:#991b1b}.layout{max-width:1500px;margin:0 auto;padding:14px;display:grid;grid-template-columns:1.1fr 1.4fr;gap:14px;min-height:calc(100vh - 70px);height:calc(100vh - 70px)}body[data-app-scope=backend] .layout{grid-template-columns:1fr;max-width:1100px}body[data-app-scope=backend] #students-card,body[data-app-scope=backend] #routines-card,body[data-app-scope=backend] #elements-card,body[data-app-scope=backend] #tools-card,body[data-app-scope=backend] #invite-student,body[data-app-scope=profesor] #import-bunny-audios-reset,body[data-app-scope=profesor] #import-bunny-audios-add{display:none!important}body[data-app-scope=profesor] #au-bunny-divider{display:none}body[data-app-scope=backend] #import-default-au-add{display:none!important}.col{display:flex;flex-direction:column;gap:14px;min-height:0;overflow:hidden}.admin-tabs{display:flex;gap:8px;padding:5px;border:1px solid color-mix(in srgb,var(--border) 88%,transparent);border-radius:10px;background:color-mix(in srgb,var(--surface-2) 82%,var(--surface));box-shadow:0 5px 12px #11182714;overflow-x:auto}.admin-tab-btn{border:1px solid transparent;background:transparent;color:var(--muted);border-radius:8px;padding:7px 13px;font-size:.75rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;cursor:pointer;box-shadow:none;transition:transform .22s cubic-bezier(.2,.7,.2,1),background-color .22s ease,border-color .22s ease,color .22s ease,box-shadow .22s ease}.admin-tab-btn:hover{transform:translateY(-.5px);color:var(--text)}.admin-tab-btn.active{border-color:color-mix(in srgb,var(--border) 80%,transparent);background:var(--surface);color:var(--text);transform:translateY(-1.5px);box-shadow:0 2px 2px #4443}.admin-tab-btn:focus-visible,.student-editor-tab:focus-visible{outline:none}.tab-panel-hidden{display:none!important}.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);padding:12px;min-height:0;display:flex;flex-direction:column;flex:1}body[data-theme=light] .card{background:#ddeef4}.card h2{margin:0;font-size:.95rem}#elements-card>div.card-head>h2{margin-top:7px}.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:8px;flex-wrap:wrap;min-height:26px}.scroll{max-height:none;overflow:auto;padding-right:0;min-height:0;flex:1}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}label{font-size:.75rem;color:var(--muted)}input,textarea,select{width:100%;border:1px solid color-mix(in srgb,var(--border) 84%,transparent);background:color-mix(in srgb,var(--surface-2) 88%,#f2f2f2);color:var(--text);border-radius:5px;padding:8px;font-size:.82rem;margin-top:3px}textarea{min-height:76px;resize:vertical}.category{border:1px solid var(--border);border-radius:7px;margin-bottom:4px;overflow:hidden;background:var(--surface)}.category-head{display:flex;gap:10px;align-items:center;padding:12px;background:var(--surface-2);border-bottom:1px solid var(--border);cursor:pointer;user-select:none;font-size:14px}.category-head-main{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.category-handle{width:20px;min-width:20px;height:24px;border-radius:6px;border:1px dashed var(--border);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:grab;background:var(--surface);font-size:12px;line-height:1}.catalog-scope-section{margin-bottom:14px}.catalog-scope-title{margin:10px 0 8px;font-size:.95rem;font-weight:800;letter-spacing:.02em;color:var(--text)}.category-handle:active{cursor:grabbing}.category-title{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.category-title[contenteditable=true]{background:color-mix(in srgb,#ffffff 80%,#dbeafe);border:1px solid color-mix(in srgb,var(--border) 80%,transparent);border-radius:6px;padding:3px 6px;outline:none}.cat-inline-btn{border:none;background:transparent;color:#374151;font-size:.86rem;padding:2px 4px;cursor:pointer;box-shadow:none}.cat-inline-btn .ui-svg svg{width:14px;height:14px;display:block;fill:currentColor}.cat-inline-btn.danger{color:#4b5563;font-weight:700}.items{padding:8px;display:flex;flex-direction:column;gap:4px;min-height:56px}.items.collapsed{display:none}.category.is-drag-over{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 22%,transparent)}.item{border:1px solid var(--border);border-radius:7px;padding:7px;background:var(--surface);box-shadow:-1px 2px 5px -3px #7777}.item:hover{box-shadow:-1px 2px 5px -3px #7777,inset 0 -5px 30px 1px #dde7;transition:box-shadow .2s ease}.item.student-line:hover{box-shadow:-1px 2px 5px -3px #7777}.item.draggable-item{cursor:grab}.item.dragging{opacity:.5}.line-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.line-row[data-student-row-toggle]{cursor:pointer}.line-actions{display:inline-flex;gap:6px}.student-expand-hint{width:20px;height:20px;color:color-mix(in srgb,var(--muted) 78%,var(--text) 22%);display:inline-flex;align-items:center;justify-content:center;opacity:.75}.student-expand-hint svg{width:15px;height:15px;display:block}.line-row strong{font-weight:400}.audio-title-with-chip{display:inline-flex;align-items:center;gap:6px}.audio-scale-chip{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:16px;padding:0 6px;border:1px solid color-mix(in srgb,var(--border) 85%,#0000 15%);border-radius:999px;color:color-mix(in srgb,var(--muted) 88%,#cfd6e4 12%);font-size:.62rem;font-weight:700;letter-spacing:.03em;text-transform:lowercase;background:color-mix(in srgb,var(--surface) 92%,#f8fafc 8%)}.student-line .line-row strong{font-weight:700}.student-line{padding:12px 15px;margin-bottom:4px;box-shadow:0 2px 5px #aaa3;cursor:grab}.student-line.drag-over{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:color-mix(in srgb,var(--primary) 8%,var(--surface))}.student-title-row{display:inline-flex;align-items:center;gap:9px}.student-title-row strong{font-size:.96rem;letter-spacing:.01em}.student-title-name{cursor:help}.student-title-row .mini{padding-left:9px;border-left:1px solid var(--border);font-size:.72rem}.student-editor-tabs{display:inline-flex;gap:6px;margin:8px 0 10px;padding:4px;border:1px solid var(--border);border-radius:10px;background:color-mix(in srgb,var(--surface-2) 82%,var(--surface));box-shadow:0 4px 10px #11182714}.student-editor-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:8px 0 10px;flex-wrap:wrap}.student-editor-head-main{display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap}.student-head-actions{display:inline-flex;gap:6px;align-items:center;margin-left:auto}.student-head-actions-inline{margin-left:8px}.student-head-actions-danger{margin-left:auto;display:flex;justify-content:flex-end;width:64px}.student-icon-btn{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center}.student-icon-btn svg{width:18px;height:18px;display:block;fill:currentColor}.student-editor-tab{border:1px solid transparent;background:transparent;color:var(--muted);border-radius:8px;padding:6px 10px;font-size:.72rem;font-weight:700;cursor:pointer;transition:transform .14s ease,color .14s ease,background-color .14s ease,box-shadow .14s ease,border-color .14s ease}.student-editor-tab:hover{color:var(--text);transform:translateY(-.5px)}.student-editor-tab.active{border-color:color-mix(in srgb,var(--border) 80%,transparent);color:var(--text);background:var(--surface);transform:translateY(-1px);box-shadow:0 2px 2px #4443}.tab-icon-btn{width:56px;height:56px;padding:4px;justify-content:center}.tab-icon-btn svg{width:40px;height:40px;display:block;fill:currentColor}.student-editor-tabs .tab-icon-btn{width:38px;height:32px;padding:6px}.student-editor-tabs .tab-icon-btn svg{width:16px;height:16px}.student-editor-panel{display:none}.student-editor-panel.active{display:grid;gap:5px}.slug-input-row{display:grid;grid-template-columns:24px 1fr;gap:6px;align-items:center}.slug-prefix{height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--muted);display:inline-flex;align-items:center;justify-content:center;font-weight:700}.student-divider{border-top:1px solid var(--border);margin:10px 0}.color-control{display:grid;gap:6px;margin-top:2px}.swatch-row{display:flex;gap:6px;flex-wrap:wrap}.swatch-input-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.swatch-input-row input{width:140px;flex:0 0 140px}.swatch-custom-picker{width:22px!important;height:22px;flex:0 0 22px!important;padding:0;border-radius:999px;background:transparent;border:none;cursor:pointer;overflow:hidden}.swatch-custom-picker::-webkit-color-swatch-wrapper{padding:0}.swatch-custom-picker::-webkit-color-swatch{border:1px solid color-mix(in srgb,var(--border) 82%,transparent);border-radius:999px}.swatch-custom-picker::-moz-color-swatch{border:1px solid color-mix(in srgb,var(--border) 82%,transparent);border-radius:999px}.swatch-hex-input{width:100%!important;flex:0 0 130px!important;text-transform:uppercase;letter-spacing:.02em}.design-divider{margin:12px 0 2px;border-top-color:color-mix(in srgb,var(--border) 82%,transparent)}.swatch-btn{width:22px;height:22px;border-radius:6px;border:1px solid color-mix(in srgb,var(--border) 82%,transparent);cursor:pointer;box-shadow:0 2px 6px #1118271f}.swatch-btn.active{outline:2px solid #111;outline-offset:1px}.admin-tooltip{position:fixed;z-index:210;max-width:320px;pointer-events:none;padding:7px 9px;border-radius:8px;border:1px solid color-mix(in srgb,var(--primary) 26%,var(--border) 74%);background:color-mix(in srgb,var(--surface) 92%,var(--primary-soft) 8%);color:var(--text);font-size:.72rem;line-height:1.3;box-shadow:0 8px 22px #00000029;opacity:0;transform:translateY(3px);transition:opacity .12s ease,transform .12s ease;display:none;white-space:normal}.admin-tooltip.show{display:block;opacity:1;transform:translateY(0)}.wave-control{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.logo-mode-btn{border:1px solid var(--border);background:#fff;color:var(--text);border-radius:8px;min-width:36px;min-height:30px;padding:0 8px;cursor:pointer;box-shadow:0 2px 2px #4443}.logo-mode-btn.active{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:color-mix(in srgb,#fff 85%,var(--primary) 15%);color:color-mix(in srgb,var(--primary) 70%,#1f2937 30%)}.routine-cards-list{display:grid;gap:5px;margin-bottom:10px}.routine-open-card{width:100%;border:1px solid #dddd;background:color-mix(in srgb,var(--surface-2) 84%,var(--surface));color:var(--text);border-radius:7px;padding:8px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;box-shadow:-1px 2px 5px -3px #7777;position:relative}.routine-open-card-line{position:absolute;left:10px;right:10px;top:4px;height:2px;border-radius:999px;background:color-mix(in srgb,var(--muted) 35%,transparent);cursor:grab;touch-action:none}.routine-open-card-line:active{cursor:grabbing}.routine-open-card.active{border-color:#99e5;background:color-mix(in srgb,var(--primary-soft) 16%,var(--surface));box-shadow:-1px 2px 5px -3px #7777}.routine-open-card.drag-over{border-color:color-mix(in srgb,var(--primary) 65%,var(--border));box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 24%,transparent)}.routine-open-card:hover{transform:translateY(-1px)}.routine-open-card-title{font-weight:700;font-size:.82rem;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.routine-open-card-meta{color:var(--muted);font-size:.55rem;text-transform:uppercase;letter-spacing:.02em;font-weight:600;border:1px solid #99a2;padding:5px;border-radius:7px;background:#aae1}.routine-new-btn{width:100%;border:1px dashed color-mix(in srgb,var(--border) 86%,transparent);background:color-mix(in srgb,var(--surface-2) 78%,var(--surface));color:var(--muted);border-radius:10px;min-height:34px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:700;font-size:.78rem;margin-bottom:10px}.routine-new-btn .ui-svg svg{width:13px;height:13px}.routine-new-btn:hover{color:var(--text);border-color:color-mix(in srgb,var(--primary) 30%,var(--border));background:color-mix(in srgb,var(--surface-2) 65%,var(--surface))}#routines-card{position:relative;overflow:hidden}#routine-students{min-height:0;flex:1}#routine-editor{position:absolute;inset:40px 10px 10px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 12px 28px #11182733;padding:10px;transform:translate(105%);opacity:0;pointer-events:none;transition:transform .24s cubic-bezier(.2,.7,.2,1),opacity .24s ease;display:flex;flex-direction:column;gap:8px;min-height:0;overflow-y:auto;z-index:30}#routines-card.editor-open #routine-editor{transform:translate(0);opacity:1;pointer-events:auto}#routine-name{flex:1 1 220px;max-width:420px;min-height:42px}#delete-routine-current{border:1px solid #00000000;border-radius:5px;margin-left:20%;margin-right:3px;cursor:pointer;box-shadow:0 2px 2px #2254;width:40px;height:40px;background:var(--danger);color:#fff}#delete-routine-current:hover{box-shadow:0 2px 2px #2254,inset 0 -5px 30px 1px #dde7;border:solid 1px #0000000a;transition:box-shadow .2s ease}#delete-routine-current>span>svg{width:30px;height:30px;fill:none}#delete-routine-current>span>svg *{fill:none;stroke:currentColor}.routine-editor-top{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:0 20px}.routine-template-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.routine-editor-back-row{display:flex;justify-content:flex-start}.routine-back-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;min-width:44px;height:40px;min-height:40px;padding:0}.routine-back-btn svg{width:18px;height:18px;display:block}.routine-template-btn{width:38px;min-height:34px;min-width:38px;border-radius:10px;padding:0;display:inline-flex;align-items:center;justify-content:center}.routine-template-btn svg{width:18px;height:18px;display:block}.app-icon-mode-group{display:flex;gap:6px;flex-wrap:wrap}.app-icon-upload-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}.app-icon-upload-name{color:var(--muted);font-size:.82rem}.routine-actions-bottom{display:flex;justify-content:center;gap:8px;padding-top:6px}#new-routine.icon-btn{border:none;background:transparent;color:var(--text);border-radius:0;box-shadow:none;width:35px;height:35px;min-width:35px;padding:0}#new-routine.icon-btn:hover{box-shadow:none;border:none;color:var(--muted);transform:none}#routine-save-row{display:flex;justify-content:center;gap:8px;margin-bottom:6px}.prof-access-grid{display:grid;gap:8px}.prof-access-row{border:1px solid var(--border);border-radius:10px;padding:8px;background:var(--surface);display:grid;gap:8px}.prof-access-head{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;width:100%;border:none;background:transparent;padding:0;cursor:pointer;text-align:left;color:inherit}.prof-access-row.open .student-expand-hint{transform:rotate(180deg);transition:transform .15s ease}.prof-access-detail{display:grid;gap:8px}.prof-access-title{display:grid;gap:2px;min-width:0}.prof-access-title strong{font-size:.86rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prof-access-email{color:var(--muted);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prof-access-pill{border:1px solid var(--border);border-radius:999px;padding:3px 8px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.02em}.prof-access-pill.ok{border-color:color-mix(in srgb,var(--ok) 62%,var(--border) 38%);color:#0d6840;background:color-mix(in srgb,var(--ok) 16%,#fff 84%)}.prof-access-pill.warn{border-color:color-mix(in srgb,#b08900 62%,var(--border) 38%);color:#7b5b00;background:color-mix(in srgb,#facc15 16%,#fff 84%)}.prof-access-pill.err{border-color:color-mix(in srgb,var(--danger) 62%,var(--border) 38%);color:#8b1d1d;background:color-mix(in srgb,var(--danger) 14%,#fff 86%)}.prof-access-form{display:grid;grid-template-columns:1fr 88px 1fr;gap:8px;align-items:end}.prof-access-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}@media(max-width:720px){.prof-access-form{grid-template-columns:1fr}}#save-routine,[data-save-student],[data-cancel-student],[data-save-teacher-profile],[data-cancel-teacher-profile]{width:60px;height:40px;min-width:60px;min-height:40px;padding:0}.item .line-row strong,#tools-list .item,#elements-list .item,#ex-categories .item,#au-categories .item{font-size:14px}#tools-list .item,#elements-list .item{background:var(--surface)}#tools-list .item .line-row strong,#elements-list .item .line-row strong{font-weight:700}input[type=file]::file-selector-button{border:1px solid color-mix(in srgb,var(--border) 80%,transparent);background:var(--surface);color:var(--text);border-radius:8px;padding:6px 10px;margin-right:8px;box-shadow:0 2px 5px #1118271f;cursor:pointer}.catalog-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}.catalog-search{flex:1 1 240px;min-width:180px;max-width:460px}.toolbar-spacer{margin-left:auto}.menu-wrap{position:relative}.menu-toggle{width:34px;height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center}.menu-wrap.open .menu-toggle{border-color:color-mix(in srgb,var(--primary) 45%,var(--border));background:color-mix(in srgb,var(--primary) 11%,var(--surface))}.menu-panel{position:absolute;top:calc(100% + 6px);right:0;min-width:230px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:var(--shadow);padding:6px;display:none;z-index:120}.menu-wrap.open .menu-panel{display:block}.menu-item{width:100%;border:0;border-radius:8px;background:transparent;color:var(--text);text-align:left;font-size:.82rem;padding:8px 10px;cursor:pointer}.menu-item:hover{background:color-mix(in srgb,var(--primary) 10%,var(--surface))}.menu-item.danger-item{color:var(--danger)}.menu-divider{height:1px;background:var(--border);margin:4px 0}.filter-group{display:inline-flex;align-items:center;gap:4px;padding:4px;border:1px solid color-mix(in srgb,var(--border) 88%,transparent);border-radius:10px;background:color-mix(in srgb,var(--surface-2) 82%,var(--surface));box-shadow:inset 0 1px 1px #11182712}.toggle-btn{border:1px solid transparent;background:transparent;color:var(--muted);border-radius:8px;padding:5px 9px;font-size:.72rem;cursor:pointer;line-height:1;transition:transform .2s cubic-bezier(.2,.7,.2,1),background-color .2s ease,color .2s ease,box-shadow .2s ease}.toggle-icon-btn{border:1px solid transparent;background:transparent;color:var(--muted);border-radius:10px;padding:10px;width:42px;height:42px;cursor:pointer;line-height:1;transition:transform .14s ease,background-color .14s ease;display:inline-flex;align-items:center;justify-content:center}.toggle-icon-btn svg{width:20px;height:20px;display:block}.routine-toggle-group{display:inline-flex;align-items:center;gap:8px;padding:0;border:none;background:transparent;box-shadow:none;min-height:42px}.routine-toggle-flat-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;color:var(--text);line-height:0}.routine-toggle-flat-icon .ui-svg svg{width:18px;height:18px;fill:currentColor;display:block}.routine-dual-toggle{position:relative;width:65px;height:35px;border:1px solid color-mix(in srgb,var(--border) 78%,#0000 22%);border-radius:999px;background:#fff;box-shadow:inset 0 1px 2px #00000014,0 2px 4px #1118272e;cursor:pointer;padding:0;transition:background-color .2s ease,box-shadow .2s ease,border-color .2s ease}.routine-dual-toggle.is-on-right{background:linear-gradient(180deg,#5ea1ff,#2e76de);border-color:color-mix(in srgb,var(--primary) 55%,#1e40af 45%);box-shadow:inset 0 1px 2px #fff3,0 3px 7px #1e40af47}.routine-dual-knob{position:absolute;top:4px;left:5px;width:25px;height:25px;z-index:100;border-radius:999px;background:#fff;box-shadow:0 2px 5px #00000038;transition:transform .22s cubic-bezier(.2,.7,.2,1)}.routine-dual-toggle.is-on-right .routine-dual-knob{transform:translate(27px)}.routine-dual-icon{position:absolute;top:50%;transform:translateY(-50%);color:#111;opacity:.9;transition:opacity .18s ease;display:inline-flex;align-items:center;justify-content:center;line-height:0;pointer-events:none}.routine-dual-icon svg{width:18px;height:18px;fill:currentColor;display:block}.routine-dual-icon-left{left:10px}.routine-dual-icon-right{right:10px}.routine-dual-toggle.is-on-right .routine-dual-icon{color:#fffffff2}.student-head-actions-danger .student-icon-btn{padding:0;background:var(--danger);color:var(--surface);border:1px solid color-mix(in srgb,var(--border) 86%,#0000 14%);box-shadow:0 2px 3px #11182724}.student-head-actions-danger .student-icon-btn svg{width:25px;height:25px;fill:currentColor;color:currentColor;display:block}#new-routine .ui-svg svg{width:30px;height:30px;fill:currentColor;display:block}.toggle-btn:hover,.toggle-icon-btn:hover{transform:translateY(-.5px);background:transparent;color:var(--text)}.toggle-btn.active,.toggle-icon-btn.active{border-color:color-mix(in srgb,var(--border) 80%,transparent);background:var(--surface);color:var(--text);transform:translateY(-1px);box-shadow:0 3px 8px #11182724}.streak-switch{position:relative;border:2px solid color-mix(in srgb,var(--border) 78%,transparent);border-radius:999px;width:52px;height:26px;background:var(--surface-2);color:color-mix(in srgb,var(--muted) 75%,#111 25%);cursor:pointer;display:inline-flex;align-items:center;justify-content:flex-start;padding:0;transition:background-color .2s ease,border-color .2s ease}.streak-switch-track{display:none}.streak-switch-knob{position:absolute;left:3px;top:3px;width:16px;height:16px;border-radius:999px;background:linear-gradient(160deg,#f5f7fb,#d8dee7);box-shadow:0 1px 2px #00000047;transition:transform .2s ease}.streak-switch.active{background:var(--primary);border-color:color-mix(in srgb,var(--primary) 80%,#000 20%);color:#f2f7ff}.streak-switch.active:hover{background:color-mix(in srgb,var(--primary) 90%,#000 10%)}.streak-switch.active .streak-switch-knob{transform:translate(26px);background:linear-gradient(160deg,#fff,#ecf3ff)}.streak-config-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:end}.streak-stepper{display:grid;grid-template-columns:34px 1fr 34px;align-items:center;border:1px solid color-mix(in srgb,var(--border) 82%,transparent);border-radius:10px;background:color-mix(in srgb,var(--surface-2) 88%,var(--surface));overflow:hidden;min-height:36px}.streak-step-btn{border:0;background:transparent;color:var(--text);cursor:pointer;font-weight:800;font-size:1rem;height:100%}.streak-step-btn:hover{background:color-mix(in srgb,var(--surface) 74%,var(--surface-2))}.streak-step-value{text-align:center;font-size:.8rem;color:var(--text);font-weight:700}.logo-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;align-items:stretch}.logo-editor-left,.logo-editor-right{display:grid;gap:8px;min-width:0}.logo-current-panel{grid-template-rows:auto 1fr;min-height:100%}.logo-current-box{border:1px solid var(--border);border-radius:10px;background:var(--surface-2);padding:8px;min-height:180px;display:flex;align-items:center;justify-content:center}.toggle-chip-btn{border:1px solid transparent;background:transparent;color:var(--muted);border-radius:8px;padding:5px 10px;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;line-height:1.1;transition:transform .2s cubic-bezier(.2,.7,.2,1),background-color .2s ease,border-color .2s ease,color .2s ease,box-shadow .2s ease;min-width:34px;min-height:30px;display:inline-flex;align-items:center;justify-content:center}.toggle-chip-btn .ui-svg svg{width:16px;height:16px}.toggle-chip-btn:hover{transform:translateY(-.5px);color:var(--text)}.toggle-chip-btn.active{border-color:color-mix(in srgb,var(--border) 80%,transparent);background:var(--surface);color:var(--text);transform:translateY(-1px);box-shadow:0 3px 8px #11182724}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;white-space:nowrap}.audio-tags{display:inline-flex;gap:5px;flex-wrap:wrap;margin-top:4px}.audio-tag{border:1px solid var(--border);border-radius:999px;padding:1px 6px;font-size:.68rem;color:var(--muted);background:var(--surface-2);text-transform:uppercase}.icon-btn{width:28px;height:28px;border-radius:8px;border:none;background:#dee;color:#333;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;box-shadow:0 2px 3px #0000003d;transition:transform .14s ease,background-color .14s ease,box-shadow .14s ease}.icon-btn svg{width:14px;height:14px;display:block;fill:currentColor}.icon-btn:hover{transform:translateY(-1px);background:#dfe;color:#111;box-shadow:0 2px 3px #0000003d}.icon-btn.danger{color:#4b5563}.icon-btn.active{background:#dfe;color:#111}.icon-btn.add-seq-btn{background:var(--primary);color:#fff;border:1px solid transparent;box-shadow:0 2px 2px #2254;padding:4px}.icon-btn.add-seq-btn svg{fill:#fff;stroke:#fff}.icon-btn.add-seq-btn:hover{background:color-mix(in srgb,var(--primary) 88%,#000 12%);color:#fff;border:1px solid transparent;box-shadow:0 2px 2px #2254;transform:none}.icon-btn.preview-btn{background:var(--surface-2);color:var(--text);border:1px solid #00000000;box-shadow:0 2px 2px #2254}.icon-btn.preview-btn:hover{box-shadow:0 2px 2px #2254,inset 0 -5px 30px 1px #dde7;border:solid 1px #0000000a;color:var(--text);transform:none;background:var(--surface-2)}.icon-btn.flat-action-btn,.icon-btn.flat-action-btn:hover,.icon-btn.flat-action-btn:focus-visible{background:transparent;border:none;box-shadow:none;transform:none;color:var(--muted);padding:5px}.icon-btn.flat-action-btn.danger,.icon-btn.flat-action-btn.danger:hover,.icon-btn.flat-action-btn.danger:focus-visible{color:#4b5563}.color-select option{padding:6px}.logo-drop{margin-top:6px;border:1px dashed var(--border);border-radius:10px;background:var(--surface-2);padding:9px;text-align:center;font-size:.75rem;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:8px}.logo-file-input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.logo-upload-btn{width:40px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center}.logo-upload-btn svg{width:18px;height:18px;display:block;fill:currentColor}.action-icon-btn{min-width:42px;min-height:34px;padding:0;display:inline-flex;align-items:center;justify-content:center}.action-icon-btn svg{width:18px;height:18px;display:block;fill:currentColor}.logo-drop.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 15%,var(--surface-2))}.logo-preview{margin-top:6px;width:64px;height:64px;object-fit:cover;border-radius:10px;border:1px solid var(--border);background:#fff;display:none}.logo-preview-large{margin-top:0;width:100%;height:100%;min-height:164px;object-fit:contain;border-radius:10px;background:#fff}.logo-gallery{margin-top:8px;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.logo-tile{border:1px solid var(--border);border-radius:8px;background:var(--surface-2);padding:4px;position:relative;cursor:pointer}.logo-tile.active{outline:2px solid var(--primary)}.logo-tile img{width:100%;aspect-ratio:1 / 1;object-fit:contain;display:block;border-radius:6px;background:#fff}.logo-del{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--danger);font-size:11px;line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:transform .14s ease,background-color .14s ease}.logo-del:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--danger) 10%,var(--surface))}.home-mini{margin-top:10px;border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--surface)}.home-preview-full{width:100%;margin-left:auto;margin-right:auto;border-radius:10px;border-width:2px;box-shadow:0 10px 24px #11182724;height:auto;display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;flex-grow:1}.design-layout{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch;margin:auto}.design-left{display:grid;gap:10px}.design-right{display:flex;gap:8px;padding:5px 30px;flex-direction:column}.design-font-field{display:grid;gap:10px}.design-font-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:end}.design-font-main{display:grid;gap:6px;min-width:0}.font-picker{position:relative}.font-picker-toggle{width:100%;min-height:38px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--text);padding:0 10px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;box-shadow:0 2px 4px #11182714}.font-picker-preview{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.93rem;text-align:left}.font-picker-caret{color:var(--muted);font-size:.82rem;flex-shrink:0}.font-picker-menu{display:none;position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:12;border:1px solid var(--border);border-radius:10px;background:#fff;box-shadow:0 12px 22px #11182726;padding:6px;max-height:220px;overflow-y:auto}.font-picker.open .font-picker-menu{display:grid;gap:4px}.font-picker-option{border:1px solid transparent;border-radius:8px;background:#fff;color:var(--text);padding:8px 10px;text-align:left;cursor:pointer;font-size:.92rem}.font-picker-option:hover,.font-picker-option.active{border-color:color-mix(in srgb,var(--primary) 32%,var(--border) 68%);background:color-mix(in srgb,var(--surface) 84%,var(--primary-soft) 16%)}.design-font-size-group{display:flex;gap:6px;align-items:center;justify-content:flex-end}.font-size-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 3px #11182714}.font-size-btn.active{border-color:color-mix(in srgb,var(--primary) 42%,var(--border));background:color-mix(in srgb,#fff 82%,var(--primary) 18%);color:var(--text)}.font-size-icon{font-family:var(--font-ui, "Inter", sans-serif);font-weight:800;line-height:1;display:inline-flex;align-items:center;justify-content:center}.font-size-icon-sm{font-size:.66rem}.font-size-icon-md{font-size:.84rem}.font-size-icon-lg{font-size:1.02rem}.routine-mini{border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:12px;box-shadow:0 8px 18px #1118271f;height:auto;display:flex;flex-direction:column;justify-content:center}.routine-mini h2{margin:0 0 8px;font-size:1.05rem;font-weight:700}.routine-mini h3{margin:0 0 6px;font-size:.92rem;font-weight:700}.routine-mini p{margin:0;font-size:.82rem;line-height:1.45;color:#4b5563}.home-preview-full .home-mini-top{font-size:.84rem;line-height:1.35;padding:20px 12px;display:flex;flex-direction:column;justify-content:center;border:none}.home-preview-full .home-mini-actions{padding:20px 12px}.home-preview-full .home-mini-btn{width:min(240px,100%);font-size:.78rem;padding:9px 10px}.home-preview-full .home-mini-footer{font-size:.78rem;padding:9px}.home-mini-top{padding:8px;text-align:center;font-size:.72rem;border-bottom:1px solid var(--border)}.home-mini-actions{padding:8px;display:flex;flex-direction:column;gap:6px;align-items:center}.home-mini-btn{width:88%;border:none;border-radius:999px;color:#fff;font-size:.7rem;font-weight:700;padding:6px 8px}.home-mini-footer{text-align:center;font-size:.7rem;font-weight:700;color:#fff;padding:6px}.editor-panel{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border);display:none}.editor-panel.open{display:block}.item-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;gap:8px}.mini{font-size:.72rem;color:var(--muted)}.pill{padding:2px 8px;border-radius:999px;border:1px solid var(--border);font-size:.72rem}.pill.pub{border-color:var(--ok);color:var(--ok)}.pill.draft{border-color:#b08900;color:#b08900}.row{display:flex;gap:8px;align-items:center}.routine-items{border:1px dashed var(--border);border-radius:10px;padding:8px;max-height:380px;overflow:auto;display:flex;flex-direction:column;gap:6px;background:var(--surface-2)}.drop-wrap{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}.drop-zone{border:2px dashed var(--border);border-radius:10px;background:var(--surface-2);min-height:120px;padding:8px;overflow-y:auto;min-height:0}.drop-zone.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary) 15%,var(--surface-2))}.routine-item{padding:7px 8px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);display:block;font-size:.8rem;cursor:pointer}.routine-item-audio,.routine-item-tool{background:var(--surface)}.routine-item-ejercicio,.routine-item-element{background:var(--surface-2)}.routine-item-body{display:flex;justify-content:space-between;align-items:center;gap:8px}.routine-item-main{display:flex;align-items:center;gap:8px;min-width:0;flex:1}.routine-item-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center;gap:6px}.routine-kind-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;line-height:0}.routine-kind-icon svg{width:17px;height:17px;fill:currentColor;display:block}.routine-kind-icon-ejercicio{color:#355a9a}.routine-kind-icon-audio{color:#0e6d62}.routine-kind-icon-tool{color:#6d4a9a}.routine-kind-icon-element{color:#7b4d1b}.routine-item.icon-btn{background:var(--surface-2);color:var(--muted);border-radius:5px;padding:8px 10px;cursor:pointer;font-size:.8rem;font-weight:600}.routine-drag-handle{width:20px;min-width:20px;height:24px;border-radius:6px;border:1px dashed var(--border);display:inline-flex;align-items:center;justify-content:center;color:var(--muted);background:var(--surface-2);cursor:grab;user-select:none;line-height:1;font-size:12px}.routine-drag-handle:active{cursor:grabbing}.routine-item.drag-over{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 18%,transparent)}.routine-item-element{border-color:color-mix(in srgb,var(--primary) 18%,var(--border));background:var(--surface-2)}.routine-element-editor{margin-top:8px;border-top:1px dashed color-mix(in srgb,var(--primary) 26%,var(--border));padding-top:8px;display:grid;gap:6px}.routine-tool-title-editor,.routine-exercise-editor{display:none}.routine-exercise-editor.open,.routine-tool-title-editor.open{display:grid}.routine-element-title-input{width:100%;border:1px solid color-mix(in srgb,var(--primary) 28%,var(--border));border-radius:10px;background:color-mix(in srgb,var(--primary) 6%,var(--surface));color:color-mix(in srgb,var(--primary) 62%,var(--text));font-family:Inter,sans-serif;font-weight:700;font-size:1.05rem;line-height:1.3;padding:10px 12px}.routine-element-toolbar{display:inline-flex;gap:6px;flex-wrap:wrap}.routine-element-toolbar .btn{min-height:28px;padding:4px 9px;font-size:.74rem;border-radius:8px}.routine-element-textarea{width:100%;min-height:92px;border:1px solid color-mix(in srgb,var(--primary) 24%,var(--border));border-radius:10px;background:color-mix(in srgb,var(--primary) 3%,var(--surface));color:var(--text);font-family:Inter,sans-serif;font-size:.88rem;line-height:1.45;padding:10px 12px;resize:vertical}.routine-element-separator-preview{margin-top:8px;border-top:1px solid color-mix(in srgb,var(--primary) 32%,var(--border));opacity:.85}.routine-line{border:1px solid var(--border);border-radius:10px;padding:8px;background:var(--surface);display:flex;align-items:center;justify-content:space-between;gap:8px}.routine-line.selected{border-color:var(--primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--primary) 20%,transparent)}.routine-line-title{display:flex;align-items:center;gap:8px;min-width:0}.routine-line-title strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px;display:inline-block}.exports{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:8px}@media(max-width:1180px){.layout{grid-template-columns:1fr}.scroll{max-height:none}.exports{grid-template-columns:1fr 1fr}.layout{height:auto}}@media(max-width:760px){.toolbar-spacer{margin-left:0}.catalog-search{max-width:none}}.auth-overlay{position:fixed;inset:0;background:#0b12208c;backdrop-filter:blur(2px);z-index:200;display:flex;align-items:center;justify-content:center;padding:16px}.auth-card{width:100%;max-width:380px;border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow);padding:16px}.auth-title{margin:0 0 6px;font-size:1.05rem}.auth-msg{margin:0 0 12px;color:var(--muted);font-size:.82rem}.auth-error{display:none;margin-bottom:10px;border:1px solid var(--danger);color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,var(--surface));border-radius:10px;padding:8px;font-size:.8rem}.auth-link{margin-top:8px;border:none;background:transparent;color:var(--primary);font-size:.82rem;text-decoration:underline;cursor:pointer;padding:0}body.locked{overflow:hidden}body.locked .layout,body.locked .top{filter:blur(1px);pointer-events:none;user-select:none}#account-menu-wrap{display:inline-flex}.flash{position:fixed;right:14px;bottom:14px;border-radius:10px;border:1px solid #86efac;background:#f0fdf4;color:#166534;padding:9px 11px;font-size:.82rem;box-shadow:0 10px 24px #0000002e;z-index:260;display:none;max-width:min(420px,calc(100vw - 28px))}.flash.err{border-color:var(--danger);background:color-mix(in srgb,var(--danger) 10%,var(--surface));color:var(--danger)}.user-modal{position:fixed;inset:0;background:#0b122080;backdrop-filter:blur(2px);display:none;align-items:center;justify-content:center;z-index:300;padding:14px}.user-modal.open{display:flex}.user-card{width:min(520px,100%);border:1px solid var(--border);border-radius:14px;background:var(--surface);box-shadow:var(--shadow);padding:14px}.user-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.password-field{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}.password-toggle{width:34px;height:34px;border:1px solid var(--border);background:var(--surface);color:var(--muted);border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 5px #1118271a}.confirm-card{width:min(420px,100%)}.confirm-msg{margin:0;color:var(--text);font-size:.9rem;line-height:1.4}.routine-template-card{width:min(520px,100%);max-height:min(70vh,560px);display:flex;flex-direction:column;gap:10px}.routine-template-list{display:flex;flex-direction:column;gap:8px;overflow:auto;padding-right:2px}.routine-template-item{width:100%;position:relative}.routine-template-main{width:100%;border:1px solid var(--border);border-radius:12px;background:color-mix(in srgb,var(--surface) 84%,var(--primary-soft) 16%);color:var(--text);padding:12px 14px;text-align:left;cursor:pointer;display:grid;gap:4px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.routine-template-main:hover,.routine-template-main:focus-visible{border-color:color-mix(in srgb,var(--primary) 38%,var(--border) 62%);box-shadow:0 8px 18px #11182714;transform:translateY(-1px)}.routine-template-delete{position:absolute;top:8px;right:8px;width:28px;min-width:28px;height:28px;border:none;box-shadow:none;background:transparent;color:var(--muted);padding:0;font-weight:800;line-height:1}.routine-template-delete:hover,.routine-template-delete:focus-visible{background:color-mix(in srgb,var(--danger-soft) 55%,transparent);color:var(--danger);box-shadow:none}.routine-template-item-title{font-weight:800;font-size:.98rem}.routine-template-item-meta{color:var(--muted);font-size:.82rem}:root{--bg: #f4f6fb;--surface: #fcfdfe;--surface-2: #eef2f9;--text: #111827;--muted: #6b7280;--border: #dbe2ee;--primary: #6d6ffa;--primary-soft: #dbeafe;--danger: #dc2626;--ok: #059669;--shadow: 0 10px 24px rgba(17, 24, 39, .08)}body[data-theme=dark]{--bg: #0b1220;--surface: #121a2b;--surface-2: #0f1728;--text: #e5e7eb;--muted: #9ca3af;--border: #253247;--primary: #60a5fa;--primary-soft: #1b2a45;--danger: #f87171;--ok: #34d399;--shadow: 0 12px 28px rgba(0, 0, 0, .45)}
