:root {
    color-scheme: dark;
    --bg: #07090d;
    --bg-soft: #10141c;
    --panel: #10151d;
    --panel-2: #171d27;
    --text: #f4f7fb;
    --muted: #8f9aaa;
    --line: rgba(255, 255, 255, .1);
    --surface-glass: rgba(255, 255, 255, .055);
    --field-bg: rgba(4, 8, 14, .86);
    --page-gradient: radial-gradient(circle at top left, rgba(24, 168, 255, .2), transparent 34rem), linear-gradient(145deg, #05070a 0%, #10141c 46%, #07090d 100%);
    --login-gradient: radial-gradient(circle at 50% -10%, rgba(24, 168, 255, .28), transparent 24rem), linear-gradient(145deg, #05070a 0%, #121721 54%, #05070a 100%);
    --blue: #18a8ff;
    --green: #45f0b7;
    --orange-light: #f6d365;
    --red-dark: #7f1028;
    --danger: #ff5570;
    --shadow: rgba(0, 0, 0, .44);
}

:root[data-theme="light"] {
    color-scheme: light;
    --bg: #eef3f8;
    --bg-soft: #f8fbff;
    --panel: #ffffff;
    --panel-2: #f4f8fc;
    --text: #101722;
    --muted: #627083;
    --line: rgba(17, 24, 39, .12);
    --surface-glass: rgba(255, 255, 255, .78);
    --field-bg: rgba(255, 255, 255, .92);
    --page-gradient: radial-gradient(circle at top left, rgba(24, 168, 255, .18), transparent 32rem), linear-gradient(145deg, #f8fbff 0%, #eef4fa 52%, #e6edf5 100%);
    --login-gradient: radial-gradient(circle at 50% -10%, rgba(24, 168, 255, .24), transparent 23rem), linear-gradient(145deg, #f8fbff 0%, #edf4fb 54%, #e5edf6 100%);
    --blue: #0878d8;
    --green: #0d9f73;
    --orange-light: #d6a92f;
    --red-dark: #8b1028;
    --danger: #d9314f;
    --shadow: rgba(31, 45, 61, .16);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    min-height: 100vh;
    font-family: Inter, "Segoe UI", Arial, sans-serif;
    background: var(--page-gradient);
    color: var(--text);
}

button,
input,
select,
textarea {
    font: inherit;
}

button,
.icon-button,
.submit-button,
.action-button,
.day-tab,
.folder-actions button,
.forgot-button,
.selected-exercise-row button {
    font-weight: 400;
}

.app-shell {
    width: min(1120px, 100%);
    margin: 0 auto;
    padding: 20px clamp(14px, 4vw, 32px) 48px;
}

.topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 20px 0 14px;
}

.programs-page .topbar,
.academies-page .topbar,
.report-page .topbar,
.admin-page .topbar,
.profile-page .topbar,
.help-page .topbar {
    padding-top: 42px;
}

.topbar-actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.programs-page .topbar-actions {
    margin-top: 32px;
}

.user-chip {
    position: fixed;
    top: max(12px, env(safe-area-inset-top));
    right: calc(max(12px, env(safe-area-inset-right)) + 54px);
    z-index: 40;
    height: 44px;
    max-width: 132px;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 12px 0 4px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-glass);
    color: var(--muted);
    font-size: 13px;
    text-decoration: none;
    box-shadow: 0 14px 34px var(--shadow);
    backdrop-filter: blur(12px);
    cursor: pointer;
    transition: border-color .18s ease, color .18s ease, transform .18s ease;
}

.user-chip:hover,
.user-chip:focus-visible {
    border-color: rgba(69, 240, 183, .45);
    color: var(--text);
    outline: 0;
    transform: translateY(-1px);
}

.user-chip img {
    width: 40px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
}

.user-chip span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.user-level-badge {
    position: fixed;
    top: calc(max(12px, env(safe-area-inset-top)) + 48px);
    right: calc(max(12px, env(safe-area-inset-right)) + 60px);
    z-index: 39;
    min-width: 72px;
    max-width: 120px;
    overflow: hidden;
    padding: 0;
    font-size: 9px;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0;
    text-align: center;
    text-overflow: ellipsis;
    white-space: nowrap;
    pointer-events: none;
    transition: opacity .18s ease, visibility .18s ease;
}

.user-level-badge.is-hidden-after-idle {
    opacity: 0;
    visibility: hidden;
}

.user-level-badge.level-professor,
.profile-level-badge.level-professor {
    color: var(--green);
}

.user-level-badge.level-aluno,
.profile-level-badge.level-aluno {
    color: var(--orange-light);
}

.user-level-badge.level-administrador,
.profile-level-badge.level-administrador {
    color: var(--blue);
}

.user-level-badge.level-marombeiro,
.profile-level-badge.level-marombeiro {
    color: var(--red-dark);
}

.theme-toggle {
    position: fixed;
    top: max(12px, env(safe-area-inset-top));
    right: max(12px, env(safe-area-inset-right));
    z-index: 40;
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border: 1px solid var(--line);
    border-radius: 15px;
    background: var(--panel);
    color: var(--text);
    box-shadow: 0 14px 34px var(--shadow);
    cursor: pointer;
    backdrop-filter: blur(12px);
}

.theme-toggle span {
    font-size: 20px;
    line-height: 1;
}

.new-users-fab {
    position: fixed;
    right: max(14px, env(safe-area-inset-right));
    bottom: max(18px, env(safe-area-inset-bottom));
    z-index: 45;
    display: inline-grid;
    place-items: center;
    width: 52px;
    height: 52px;
    border: 1px solid rgba(22, 151, 218, .28);
    border-radius: 17px;
    background: linear-gradient(145deg, rgba(15, 126, 211, .42), rgba(29, 197, 146, .42));
    color: #061018;
    box-shadow: 0 18px 42px var(--shadow);
    backdrop-filter: blur(12px);
    cursor: pointer;
}

.new-users-fab-icon {
    font-size: 28px;
    font-weight: 800;
    line-height: 1;
}

.new-users-fab-count {
    position: absolute;
    top: -8px;
    right: -8px;
    display: grid;
    place-items: center;
    min-width: 25px;
    height: 25px;
    padding: 0 7px;
    border: 2px solid var(--panel);
    border-radius: 999px;
    background: var(--danger);
    color: #fff;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

.new-users-fab:not(.has-alert) {
    background: color-mix(in srgb, var(--panel) 36%, transparent);
    color: var(--muted);
    border-color: rgba(255, 255, 255, .08);
    backdrop-filter: blur(12px);
}

.new-users-fab:not(.has-alert) .new-users-fab-count {
    background: var(--panel-2);
    color: var(--muted);
}

.menu-toggle {
    position: fixed;
    top: max(12px, env(safe-area-inset-top));
    left: max(12px, env(safe-area-inset-left));
    z-index: 40;
    min-width: 58px;
    height: 44px;
    border: 1px solid var(--line);
    border-radius: 15px;
    background: var(--panel);
    color: var(--text);
    box-shadow: 0 14px 34px var(--shadow);
    cursor: pointer;
}

.help-fab {
    position: fixed;
    top: calc(max(12px, env(safe-area-inset-top)) + 5px);
    left: calc(max(12px, env(safe-area-inset-left)) + 64px);
    z-index: 40;
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid rgba(143, 154, 170, .22);
    border-radius: 999px;
    background: color-mix(in srgb, var(--panel) 34%, transparent);
    color: var(--muted);
    font-size: 18px;
    font-weight: 700;
    line-height: 1;
    text-decoration: none;
    box-shadow: 0 14px 34px var(--shadow);
    backdrop-filter: blur(12px);
    opacity: .62;
    transition: opacity .18s ease, transform .18s ease, border-color .18s ease;
}

.help-fab:hover,
.help-fab:focus-visible {
    opacity: .9;
    border-color: rgba(143, 154, 170, .42);
    outline: 0;
    transform: translateY(-1px);
}

.side-menu {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 70;
    display: flex;
    flex-direction: column;
    width: min(300px, 86vw);
    max-height: 100vh;
    max-height: 100dvh;
    padding: 38px 18px 18px;
    border-right: 1px solid var(--line);
    background: var(--panel);
    box-shadow: 24px 0 58px var(--shadow);
    overflow: hidden;
    transform: translateX(-105%);
    transition: transform .2s ease;
}

body.menu-open .side-menu {
    transform: translateX(0);
}

.menu-backdrop {
    position: fixed;
    inset: 0;
    z-index: 60;
    display: none;
    background: rgba(0, 0, 0, .48);
}

body.menu-open .menu-backdrop {
    display: block;
}

.side-menu-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--line);
}

.side-menu-head strong {
    font-size: 22px;
}

.side-menu-nav {
    display: flex;
    flex-direction: column;
    gap: 8px;
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    overscroll-behavior: contain;
    margin-top: 16px;
    margin-right: -18px;
    padding-right: 12px;
    padding-bottom: 6px;
    scrollbar-color: rgba(143, 154, 170, .44) transparent;
    scrollbar-width: thin;
}

.side-menu-nav::-webkit-scrollbar {
    width: 6px;
}

.side-menu-nav::-webkit-scrollbar-track {
    background: transparent;
}

.side-menu-nav::-webkit-scrollbar-thumb {
    border-radius: 999px;
    background: rgba(143, 154, 170, .32);
}

.side-menu-nav::-webkit-scrollbar-thumb:hover {
    background: rgba(143, 154, 170, .52);
}

.side-menu-nav a,
.side-menu-logout {
    flex: 0 0 44px;
    height: 44px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    box-sizing: border-box;
    color: var(--text);
    text-decoration: none;
    background: var(--surface-glass);
}

.side-menu-nav a.active {
    border-color: rgba(24, 168, 255, .42);
    color: var(--blue);
}

.side-menu-nav a.professor-link {
    border-color: rgba(69, 240, 183, .22);
    background: rgba(69, 240, 183, .065);
}

.side-menu-nav a.professor-link.active {
    border-color: rgba(69, 240, 183, .38);
    color: var(--green);
}

.side-menu-nav a.admin-link {
    border-color: rgba(24, 168, 255, .26);
    background: rgba(24, 168, 255, .075);
}

.side-menu-nav a.admin-link.active {
    border-color: rgba(24, 168, 255, .46);
    color: var(--blue);
}

.side-menu-separator {
    height: 1px;
    margin: 6px 2px;
    background: var(--line);
    opacity: .72;
}

.side-menu-nav .side-menu-logout {
    position: sticky;
    bottom: 0;
    z-index: 1;
    margin-top: auto;
    border-color: rgba(255, 85, 112, .28);
    background: rgba(255, 85, 112, .075);
    color: color-mix(in srgb, var(--danger) 82%, var(--muted) 18%);
}

.side-menu-nav .side-menu-logout:hover,
.side-menu-nav .side-menu-logout:focus-visible {
    border-color: rgba(255, 85, 112, .42);
    background: rgba(255, 85, 112, .12);
    color: var(--danger);
}

.eyebrow {
    display: inline-flex;
    color: var(--green);
    font-size: 13px;
    font-weight: 800;
}

h1,
h2,
p {
    margin: 0;
}

h1 {
    margin-top: 4px;
    font-size: clamp(34px, 7vw, 48px);
    line-height: .95;
}

.topbar p,
.gym-note,
.folder-note,
.exercise-row span {
    color: var(--muted);
}

.topbar p {
    color: color-mix(in srgb, var(--muted) 82%, #000 18%);
    font-size: 14px;
}

.icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 46px;
    height: 46px;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface-glass);
    color: var(--text);
    font-size: 26px;
    line-height: 1;
    text-align: center;
    cursor: pointer;
}

.icon-button.primary {
    background: linear-gradient(145deg, var(--blue), #256dff);
    border: 0;
    box-shadow: 0 16px 34px rgba(24, 168, 255, .24);
}

.topbar-actions .icon-button.primary {
    width: 48px;
    height: 48px;
    font-size: 30px;
}

.logout-button {
    text-decoration: none;
    color: var(--danger);
    font-size: 22px;
    font-weight: 400;
}

.close-button {
    width: 28px;
    height: 28px;
    border-radius: 9px;
    font-size: 15px;
    font-weight: 400;
}

.alert {
    margin: 10px 0 16px;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid var(--line);
    background: var(--surface-glass);
}

.alert.success {
    border-color: rgba(69, 240, 183, .35);
}

.alert.danger {
    border-color: rgba(255, 85, 112, .45);
}

.quick-actions,
.day-tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 8px 0;
    scrollbar-width: none;
}

.quick-actions::-webkit-scrollbar,
.day-tabs::-webkit-scrollbar {
    display: none;
}

.action-button,
.day-tab,
.folder-actions button {
    min-height: 40px;
    border: 1px solid var(--line);
    border-radius: 999px;
    padding: 0 14px;
    background: var(--surface-glass);
    color: var(--text);
    white-space: nowrap;
    cursor: pointer;
}

.action-button.active,
.day-tab.active {
    background: var(--text);
    color: var(--bg);
}

.action-button.ghost {
    color: var(--green);
}

.academy-editor {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 14px;
    margin-top: 12px;
}

.academy-editor > .full {
    grid-column: 1 / -1;
}

.academy-card {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.academy-card-new {
    border-color: rgba(69, 240, 183, .3);
    background: linear-gradient(145deg, rgba(69, 240, 183, .08), var(--panel));
}

.academy-card-shared {
    border-color: rgba(69, 240, 183, .26);
    background: linear-gradient(145deg, rgba(69, 240, 183, .08), var(--panel));
}

.academy-card .full {
    grid-column: 1 / -1;
}

.academy-shared-badge {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 4px 9px;
    border: 1px solid rgba(69, 240, 183, .34);
    border-radius: 999px;
    background: rgba(69, 240, 183, .12);
    color: var(--green);
    font-size: 12px;
    font-weight: 800;
}

.academy-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.academy-logo-field {
    position: relative;
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.academy-logo-trigger,
.academy-logo-options button {
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    width: 100%;
    min-height: 62px;
    padding: 7px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--field-bg);
    color: var(--text);
    text-align: left;
    cursor: pointer;
}

.academy-logo-trigger:disabled {
    cursor: not-allowed;
    opacity: .65;
}

.academy-logo-trigger img,
.academy-logo-options img,
.academy-logo-thumb {
    width: 50px;
    height: 50px;
    border-radius: 10px;
    object-fit: contain;
    background: var(--surface-glass);
}

.academy-logo-thumb {
    display: grid;
    place-items: center;
    border: 1px dashed var(--line);
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.academy-logo-trigger strong,
.academy-logo-options strong {
    min-width: 0;
    overflow: hidden;
    color: var(--text);
    font-size: 14px;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.academy-logo-options {
    position: absolute;
    inset: calc(100% + 6px) 0 auto;
    z-index: 20;
    display: grid;
    gap: 6px;
    max-height: 320px;
    overflow-y: auto;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.academy-logo-options[hidden] {
    display: none;
}

.academy-logo-options button:hover,
.academy-logo-options button:focus-visible,
.academy-logo-trigger:focus-visible {
    border-color: rgba(24, 168, 255, .55);
    outline: 0;
}

.academy-bulk-footer {
    display: grid;
}

.academy-bulk-button {
    width: 100%;
}

.help-guide {
    display: grid;
    gap: 16px;
    max-width: 920px;
    margin-top: 12px;
}

.help-intro,
.help-steps,
.help-finish > div {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.help-intro {
    display: grid;
    gap: 9px;
    padding: 22px;
    background:
        linear-gradient(145deg, rgba(24, 168, 255, .1), rgba(69, 240, 183, .055)),
        var(--panel);
}

.help-kicker,
.help-finish span {
    color: var(--green);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.help-intro h2 {
    font-size: clamp(26px, 4vw, 36px);
    line-height: 1;
}

.help-intro p,
.help-steps p,
.help-finish p {
    color: var(--muted);
    line-height: 1.55;
}

.help-demo {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.help-demo-scene {
    display: grid;
    gap: 10px;
    min-width: 0;
}

.help-demo-caption {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 10px;
}

.help-demo-caption span {
    color: var(--green);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.help-demo-caption strong {
    color: var(--text);
    font-size: 16px;
}

.help-demo-app {
    position: relative;
    min-height: 430px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background:
        linear-gradient(145deg, rgba(255, 255, 255, .045), rgba(24, 168, 255, .045)),
        var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
    overflow: hidden;
}

.help-demo-app::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, transparent 0 56px, rgba(255, 255, 255, .035) 56px 57px, transparent 57px),
        linear-gradient(180deg, rgba(24, 168, 255, .075), transparent 105px);
    pointer-events: none;
}

.help-demo-home,
.help-demo-created-plan {
    position: absolute;
    inset: 16px;
    display: grid;
    align-content: start;
    gap: 12px;
}

.help-demo-admin-bar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 32px 38px;
    gap: 8px;
    align-items: center;
    min-height: 36px;
}

.help-demo-admin-bar span,
.help-demo-admin-bar i,
.help-demo-admin-bar b {
    display: grid;
    place-items: center;
    min-height: 32px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface-glass);
    color: var(--muted);
    font-size: 11px;
    font-style: normal;
}

.help-demo-admin-bar span {
    justify-content: start;
    padding: 0 11px;
    color: var(--blue);
    font-weight: 800;
    text-transform: uppercase;
}

.help-demo-admin-bar b {
    border-color: rgba(24, 168, 255, .36);
    background: rgba(24, 168, 255, .13);
    color: var(--blue);
    font-size: 18px;
    font-weight: 700;
}

.help-demo-home-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding-bottom: 8px;
}

.help-demo-home-top span {
    display: block;
    color: var(--green);
    font-size: 10px;
    font-weight: 800;
}

.help-demo-home-top strong {
    display: block;
    margin-top: 3px;
    font-size: 24px;
    line-height: .95;
}

.help-demo-plus {
    display: grid;
    place-items: center;
    width: 46px;
    height: 46px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(145deg, var(--blue), #256dff);
    color: #fff;
    font-size: 29px;
    cursor: default;
    animation: helpDemoButtonPulse 14s ease-in-out infinite;
}

.help-demo-filter-row {
    display: flex;
    gap: 7px;
    overflow: hidden;
}

.help-demo-filter-row span {
    flex: 0 0 auto;
    min-height: 32px;
    padding: 8px 11px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--surface-glass);
    color: var(--muted);
    font-size: 12px;
}

.help-demo-empty-card,
.help-demo-plan-card {
    border: 1px solid var(--line);
    border-top: 4px solid var(--blue);
    border-radius: 16px;
    background: var(--panel);
    box-shadow: 0 18px 38px var(--shadow);
}

.help-demo-empty-card {
    display: grid;
    gap: 5px;
    min-height: 118px;
    align-content: center;
    padding: 16px;
    color: var(--muted);
}

.help-demo-empty-card strong {
    color: var(--text);
}

.help-demo-modal,
.help-demo-viewer {
    position: absolute;
    inset: 28px 16px 16px;
    z-index: 2;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 30px 70px rgba(0, 0, 0, .5);
    overflow: hidden;
    opacity: 0;
    transform: translateY(26px) scale(.96);
}

.help-demo-modal {
    animation: helpDemoModal 14s ease-in-out infinite;
}

.help-demo-modal-head,
.help-demo-viewer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 48px;
    padding: 0 14px;
    border-bottom: 1px solid var(--line);
}

.help-demo-modal-head > span,
.help-demo-viewer-head > span {
    display: grid;
    place-items: center;
    width: 26px;
    height: 26px;
    border: 1px solid var(--line);
    border-radius: 9px;
    color: var(--muted);
}

.help-demo-viewer-title {
    position: relative;
    display: block;
    min-width: 155px;
    min-height: 20px;
}

.help-demo-viewer-title span {
    position: absolute;
    inset: 0 auto auto 0;
    width: max-content;
    max-width: 100%;
    height: auto;
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: var(--text);
    font-size: 15px;
}

.help-demo-viewer-title-second {
    opacity: 0;
    animation: helpDemoViewerTitleSecond 11s ease-in-out infinite;
}

.help-demo-viewer-title-first {
    animation: helpDemoViewerTitleFirst 11s ease-in-out infinite;
}

.help-demo-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    padding: 12px;
    animation: helpDemoFormScroll 14s ease-in-out infinite;
}

.help-demo-field,
.help-demo-selected span {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    min-height: 36px;
    padding: 7px 10px;
    border: 1px solid var(--line);
    border-radius: 11px;
    background: var(--field-bg);
    color: var(--muted);
    font-size: 11px;
    overflow: hidden;
    white-space: nowrap;
}

.help-demo-field small {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
}

.help-demo-field b {
    max-width: 100%;
    margin-top: 4px;
    overflow: hidden;
    color: inherit;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.1;
    text-overflow: ellipsis;
}

.help-demo-field {
    opacity: .28;
    transform: translateY(7px);
    animation: helpDemoFill 14s ease-in-out infinite;
}

.help-demo-academia { animation-delay: 1.7s; }
.help-demo-dia { animation-delay: 2.2s; }
.help-demo-titulo { animation-delay: 2.7s; }
.help-demo-status { animation-delay: 3.2s; }
.help-demo-grupo { animation-delay: 3.7s; }
.help-demo-exercicio { animation-delay: 4.2s; }

.help-demo-series,
.help-demo-add,
.help-demo-save,
.help-demo-selected {
    grid-column: 1 / -1;
}

.help-demo-series { animation-delay: 4.7s; }

.help-demo-builder {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface-glass);
}

.help-demo-add,
.help-demo-save {
    min-height: 36px;
    border: 0;
    border-radius: 12px;
    padding: 0 13px;
    color: #fff;
    font-size: 12px;
    cursor: default;
}

.help-demo-add {
    justify-self: start;
    border: 1px solid var(--line);
    background: var(--panel-2);
    color: var(--text);
    animation: helpDemoPress 14s ease-in-out infinite;
}

.help-demo-selected {
    display: grid;
    gap: 7px;
    opacity: 0;
    transform: translateY(10px);
    animation: helpDemoSelected 14s ease-in-out infinite;
}

.help-demo-selected span {
    flex-direction: row;
    justify-content: flex-start;
    border-left: 4px solid var(--blue);
    color: var(--text);
}

.help-demo-save {
    background: linear-gradient(145deg, var(--blue), #2a6cff);
    animation: helpDemoSavePress 14s ease-in-out infinite;
}

.help-demo-plan-card {
    position: relative;
    min-height: 132px;
    overflow: hidden;
    animation: helpDemoPlanExpand 11s ease-in-out infinite;
}

.help-demo-plan-head {
    display: grid;
    gap: 4px;
    padding: 14px;
}

.help-demo-plan-head span {
    color: var(--blue);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.help-demo-plan-head strong {
    font-size: 19px;
}

.help-demo-plan-head small,
.help-demo-exercise-row small {
    color: var(--muted);
}

.help-demo-plan-body {
    display: grid;
    gap: 8px;
    padding: 0 12px 12px;
    opacity: 0;
    transform: translateY(12px);
    animation: helpDemoPlanBody 11s ease-in-out infinite;
}

.help-demo-exercise-row {
    position: relative;
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    padding: 9px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel-2);
}

.help-demo-exercise-row:nth-child(1) {
    animation: helpDemoExerciseFocusFirst 11s ease-in-out infinite;
}

.help-demo-exercise-row:nth-child(2) {
    animation: helpDemoExerciseFocusSecond 11s ease-in-out infinite;
}

.help-demo-exercise-row strong,
.help-demo-exercise-row small {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.help-demo-thumb,
.help-demo-viewer-image {
    display: block;
    border: 1px solid var(--line);
    border-radius: 12px;
    object-fit: contain;
    background:
        linear-gradient(135deg, rgba(24, 168, 255, .24), rgba(69, 240, 183, .1)),
        var(--field-bg);
}

.help-demo-thumb {
    width: 50px;
    height: 50px;
    animation: helpDemoThumbFocus 11s ease-in-out infinite;
}

.help-demo-thumb-second {
    animation-name: helpDemoThumbFocusSecond;
}

.help-demo-viewer {
    animation: helpDemoViewer 11s ease-in-out infinite;
}

.help-demo-viewer-body {
    display: grid;
    gap: 12px;
    padding: 14px;
}

.help-demo-viewer-stage {
    position: relative;
    width: 100%;
    height: 128px;
}

.help-demo-viewer-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 128px;
}

.help-demo-viewer-image-first {
    animation: helpDemoViewerImageFirst 11s ease-in-out infinite;
}

.help-demo-viewer-image-second {
    opacity: 0;
    animation: helpDemoViewerImageSecond 11s ease-in-out infinite;
}

.help-demo-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.help-demo-stats span {
    min-height: 34px;
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: 11px;
    background: var(--surface-glass);
    color: var(--text);
    font-size: 11px;
}

.help-demo-cursor {
    position: absolute;
    z-index: 5;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: rgba(24, 168, 255, .16);
    box-shadow: 0 0 0 7px rgba(24, 168, 255, .08), 0 12px 28px rgba(0, 0, 0, .35);
    transform: translate(-8px, -10px) rotate(-12deg);
}

.help-demo-cursor::after {
    content: "\261D";
    position: absolute;
    left: 4px;
    top: -9px;
    color: #f4f7fb;
    font-size: 34px;
    line-height: 1;
    text-shadow: 0 3px 12px rgba(0, 0, 0, .58);
}

.help-demo-cursor::before {
    content: "";
    position: absolute;
    inset: 5px;
    border: 1px solid rgba(24, 168, 255, .72);
    border-radius: 50%;
    opacity: 0;
    animation: helpDemoTouchRipple 1.25s ease-out infinite;
}

.help-demo-cursor-create {
    animation: helpDemoCursorCreate 14s ease-in-out infinite;
}

.help-demo-cursor-use {
    animation: helpDemoCursorUse 11s ease-in-out infinite;
}

@keyframes helpDemoCursorCreate {
    0%, 8% { left: 82%; top: 78px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
    11% { transform: translate(-8px, -10px) rotate(-12deg) scale(.82); }
    19% { left: 23%; top: 154px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
    30% { left: 70%; top: 114px; }
    42% { left: 29%; top: 234px; }
    54% { left: 57%; top: 306px; }
    58% { transform: translate(-8px, -10px) rotate(-12deg) scale(.82); }
    69% { left: 53%; top: 356px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
    84% { left: 52%; top: 330px; transform: translate(-8px, -10px) rotate(-12deg) scale(.82); }
    100% { left: 82%; top: 78px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
}

@keyframes helpDemoCursorUse {
    0%, 11% { left: 31%; top: 100px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
    16% { transform: translate(-8px, -10px) rotate(-12deg) scale(.82); }
    31% { left: 28%; top: 222px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
    48% { left: 24%; top: 218px; transform: translate(-8px, -10px) rotate(-12deg) scale(.82); }
    67% { left: 52%; top: 226px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
    79% { left: 28%; top: 282px; transform: translate(-8px, -10px) rotate(-12deg) scale(.82); }
    100% { left: 31%; top: 100px; transform: translate(-8px, -10px) rotate(-12deg) scale(1); }
}

@keyframes helpDemoTouchRipple {
    0%, 45% { opacity: 0; transform: scale(.75); }
    55% { opacity: .9; transform: scale(.9); }
    100% { opacity: 0; transform: scale(1.7); }
}

@keyframes helpDemoButtonPulse {
    0%, 8%, 14%, 100% { transform: scale(1); filter: none; }
    11% { transform: scale(.94); filter: brightness(1.16); }
}

@keyframes helpDemoModal {
    0%, 12% { opacity: 0; transform: translateY(26px) scale(.96); }
    18%, 88% { opacity: 1; transform: translateY(0) scale(1); }
    100% { opacity: 0; transform: translateY(26px) scale(.96); }
}

@keyframes helpDemoFormScroll {
    0%, 57% { transform: translateY(0); }
    68%, 86% { transform: translateY(-118px); }
    100% { transform: translateY(0); }
}

@keyframes helpDemoFormScrollMobile {
    0%, 52% { transform: translateY(0); }
    64%, 86% { transform: translateY(-224px); }
    100% { transform: translateY(0); }
}

@keyframes helpDemoFill {
    0%, 13% {
        opacity: .28;
        transform: translateY(7px);
        color: var(--muted);
        border-color: var(--line);
        box-shadow: none;
    }
    17%, 23% {
        opacity: 1;
        transform: translateY(0);
        color: var(--text);
        border-color: rgba(24, 168, 255, .78);
        box-shadow: 0 0 0 3px rgba(24, 168, 255, .18), 0 0 24px rgba(24, 168, 255, .28);
    }
    31%, 88% {
        opacity: 1;
        transform: translateY(0);
        color: var(--text);
        border-color: rgba(24, 168, 255, .34);
        box-shadow: none;
    }
    100% {
        opacity: .28;
        transform: translateY(7px);
        color: var(--muted);
        border-color: var(--line);
        box-shadow: none;
    }
}

@keyframes helpDemoPress {
    0%, 54%, 62%, 100% { transform: scale(1); filter: none; }
    58% { transform: scale(.97); filter: brightness(1.18); }
}

@keyframes helpDemoSavePress {
    0%, 78%, 86%, 100% { transform: scale(1); filter: none; }
    82% { transform: scale(.98); filter: brightness(1.2); }
}

@keyframes helpDemoSelected {
    0%, 57% { opacity: 0; transform: translateY(10px); }
    64%, 90% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(10px); }
}

@keyframes helpDemoPlanExpand {
    0%, 20% { min-height: 132px; transform: scale(1); }
    27%, 82% { min-height: 318px; transform: scale(1.01); }
    100% { min-height: 132px; transform: scale(1); }
}

@keyframes helpDemoPlanBody {
    0%, 24% { opacity: 0; transform: translateY(12px); }
    32%, 82% { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(12px); }
}

@keyframes helpDemoThumbFocus {
    0%, 39%, 55%, 100% { transform: scale(1); border-color: var(--line); box-shadow: none; }
    47% { transform: scale(.94); border-color: rgba(24, 168, 255, .7); box-shadow: 0 0 0 3px rgba(24, 168, 255, .16); }
}

@keyframes helpDemoThumbFocusSecond {
    0%, 58%, 76%, 100% { transform: scale(1); border-color: var(--line); box-shadow: none; }
    67% { transform: scale(.94); border-color: rgba(24, 168, 255, .7); box-shadow: 0 0 0 3px rgba(24, 168, 255, .16); }
}

@keyframes helpDemoExerciseFocusFirst {
    0%, 39%, 56%, 100% { border-color: var(--line); background: var(--panel-2); }
    47% { border-color: rgba(24, 168, 255, .52); background: rgba(24, 168, 255, .09); }
}

@keyframes helpDemoExerciseFocusSecond {
    0%, 58%, 76%, 100% { border-color: var(--line); background: var(--panel-2); }
    67% { border-color: rgba(24, 168, 255, .52); background: rgba(24, 168, 255, .09); }
}

@keyframes helpDemoViewer {
    0%, 50% { opacity: 0; transform: translateY(26px) scale(.96); }
    58%, 88% { opacity: 1; transform: translateY(0) scale(1); }
    100% { opacity: 0; transform: translateY(26px) scale(.96); }
}

@keyframes helpDemoViewerImageFirst {
    0%, 63% { opacity: 1; }
    71%, 100% { opacity: 0; }
}

@keyframes helpDemoViewerImageSecond {
    0%, 63% { opacity: 0; }
    71%, 100% { opacity: 1; }
}

@keyframes helpDemoViewerTitleFirst {
    0%, 63% { opacity: 1; transform: translateY(0); }
    71%, 100% { opacity: 0; transform: translateY(-5px); }
}

@keyframes helpDemoViewerTitleSecond {
    0%, 63% { opacity: 0; transform: translateY(5px); }
    71%, 100% { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
    .help-demo-plus,
    .help-demo-modal,
    .help-demo-form,
    .help-demo-field,
    .help-demo-add,
    .help-demo-save,
    .help-demo-selected,
    .help-demo-plan-card,
    .help-demo-plan-body,
    .help-demo-exercise-row,
    .help-demo-thumb,
    .help-demo-viewer,
    .help-demo-viewer-image-first,
    .help-demo-viewer-image-second,
    .help-demo-viewer-title-first,
    .help-demo-viewer-title-second,
    .help-demo-cursor {
        animation: none;
    }

    .help-demo-modal,
    .help-demo-viewer,
    .help-demo-field,
    .help-demo-selected,
    .help-demo-plan-body {
        opacity: 1;
        transform: none;
    }

    .help-demo-plan-card {
        min-height: 318px;
    }
}

.help-steps {
    display: grid;
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    overflow: hidden;
}

.help-steps li {
    display: grid;
    grid-template-columns: 44px minmax(0, 1fr);
    gap: 14px;
    padding: 18px;
    border-bottom: 1px solid var(--line);
}

.help-steps li:last-child {
    border-bottom: 0;
}

.help-step-number {
    display: grid;
    place-items: center;
    width: 38px;
    height: 38px;
    border: 1px solid rgba(24, 168, 255, .32);
    border-radius: 14px;
    background: rgba(24, 168, 255, .12);
    color: var(--blue);
    font-size: 16px;
    font-weight: 800;
}

.help-steps h3,
.help-finish h3 {
    margin: 0 0 6px;
    font-size: 18px;
}

.help-steps strong {
    color: var(--text);
}

.help-finish {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
}

.help-finish > div {
    position: relative;
    display: grid;
    gap: 7px;
    padding: 18px;
}

.help-recommendation-card {
    padding-right: 54px;
}

.help-recommendation-card span {
    color: var(--blue);
}

.help-recommendation-card h3 {
    color: var(--text);
}

.help-recommendation-icon {
    position: absolute;
    top: 16px;
    right: 16px;
    display: grid;
    place-items: center;
    width: 32px;
    height: 32px;
    border: 1px solid rgba(24, 168, 255, .34);
    border-radius: 50%;
    background: rgba(24, 168, 255, .12);
    color: var(--blue);
    font-size: 20px;
    font-weight: 900;
    line-height: 1;
}

.help-back-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    justify-self: start;
    min-height: 44px;
    padding: 0 18px;
    text-decoration: none;
}

.profile-editor {
    display: grid;
    max-width: 760px;
    margin-top: 12px;
}

.profile-card {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.profile-card label {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.profile-card .full {
    grid-column: 1 / -1;
}

.profile-card .profile-wide {
    grid-column: 1 / -1;
}

.profile-level-display .profile-level-badge {
    display: flex;
    align-items: center;
    width: 100%;
    max-width: none;
    height: 32px;
    min-height: 0;
    max-height: 32px;
    margin-top: 1px;
    padding: 0 9px;
    border-radius: 6px;
    border-color: color-mix(in srgb, currentColor 34%, transparent);
    background: color-mix(in srgb, currentColor 8%, var(--surface-glass));
    font-size: 11px;
    line-height: 1;
}

.profile-measure-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.imc-card {
    display: grid;
    gap: 4px;
    align-content: center;
    min-height: 86px;
    padding: 14px;
    border: 1px solid rgba(142, 154, 176, .34);
    border-radius: 14px;
    background: var(--surface-glass);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .04);
}

.imc-card span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.imc-card strong {
    color: var(--text);
    font-size: 28px;
    line-height: 1;
}

.imc-card small {
    color: var(--muted);
    font-size: 13px;
    font-weight: 700;
}

.imc-card.low {
    border-color: rgba(24, 168, 255, .38);
    background: rgba(24, 168, 255, .09);
}

.imc-card.normal {
    border-color: rgba(69, 240, 183, .42);
    background: rgba(69, 240, 183, .10);
}

.imc-card.high {
    border-color: rgba(255, 199, 107, .45);
    background: rgba(255, 199, 107, .10);
}

.imc-card.critical {
    border-color: rgba(255, 91, 91, .42);
    background: rgba(255, 91, 91, .10);
}

.student-lookup-label {
    display: flex;
    align-items: center;
    width: 100%;
    min-height: 42px;
    padding: 11px 12px;
    border: 1px solid rgba(24, 168, 255, .38);
    border-radius: 12px;
    background: linear-gradient(145deg, rgba(24, 168, 255, .12), var(--field-bg));
    color: var(--blue);
    font-size: 14px;
    font-weight: 800;
    text-align: left;
}

.student-lookup-label.is-found {
    border-color: rgba(69, 240, 183, .34);
    background: linear-gradient(145deg, rgba(69, 240, 183, .14), var(--field-bg));
    color: var(--green);
}

.student-picker-field {
    position: relative;
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.student-picker-list {
    position: absolute;
    inset: calc(100% + 8px) 0 auto 0;
    z-index: 92;
    display: grid;
    gap: 6px;
    max-height: 260px;
    overflow: auto;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--panel);
    box-shadow: 0 22px 48px var(--shadow);
}

.student-picker-list[hidden] {
    display: none;
}

.student-picker-row {
    display: grid !important;
    grid-template-columns: 20px auto minmax(0, 1fr);
    align-items: center;
    gap: 9px !important;
    min-height: 38px;
    padding: 8px 10px;
    border: 1px solid transparent;
    border-radius: 1px;
    color: var(--text) !important;
    cursor: pointer;
}

.student-picker-row:hover {
    border-color: rgba(69, 240, 183, .32);
    background: rgba(69, 240, 183, .075);
}

.student-picker-row input {
    width: 16px;
    height: 16px;
}

.student-picker-row span {
    color: var(--blue);
    font-size: 12px;
    font-weight: 900;
}

.student-picker-row strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.student-picker-empty {
    padding: 8px 10px;
    color: var(--muted);
    font-size: 13px;
}

.student-manager {
    display: grid;
    gap: 14px;
    margin-top: 12px;
}

.student-link-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(180px, .55fr) auto;
    align-items: end;
    gap: 12px;
    padding: 18px;
    border: 1px solid rgba(69, 240, 183, .28);
    border-radius: 18px;
    background: linear-gradient(145deg, rgba(69, 240, 183, .08), var(--panel));
    box-shadow: 0 20px 48px var(--shadow);
}

.student-link-card label {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.student-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 14px;
}

.student-card {
    display: grid;
    gap: 12px;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.student-card.is-overdue {
    border-color: rgba(255, 85, 112, .48);
    box-shadow: 0 16px 34px rgba(255, 85, 112, .12);
}

.student-card h2 {
    margin: 4px 0;
    font-size: 20px;
}

.student-card p,
.student-card small {
    display: block;
    margin: 0;
    color: var(--muted);
}

.student-id {
    color: var(--blue);
    font-size: 12px;
    font-weight: 800;
}

.student-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.student-card-meta span {
    padding: 5px 9px;
    border: 1px solid rgba(24, 168, 255, .28);
    border-radius: 999px;
    color: var(--blue);
    font-size: 12px;
    font-weight: 700;
}

.professor-list .empty-state {
    grid-column: 1 / -1;
}

.professor-card {
    align-content: start;
}

.professor-card-head {
    padding-bottom: 0;
    border-bottom: 0;
}

.professor-level-card {
    justify-self: start;
}

.professor-payment-status {
    justify-self: start;
    margin-top: 2px;
}

.professor-phone-inline {
    display: block;
    margin-top: 2px;
    color: var(--muted);
    font-weight: 400;
    text-decoration: none;
}

.professor-group-highlight {
    display: grid;
    gap: 4px;
    padding: 12px;
    border: 1px solid rgba(69, 240, 183, .36);
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(69, 240, 183, .16), rgba(24, 168, 255, .08));
    box-shadow: 0 12px 28px rgba(69, 240, 183, .08);
}

.professor-group-highlight span {
    color: var(--muted);
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
}

.professor-group-highlight strong {
    color: var(--green);
    font-size: 18px;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.student-payment-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 13px;
    background: var(--surface-glass);
    color: var(--muted);
    font-size: 12px;
}

.student-payment-overview {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.student-payment-overview span {
    padding: 8px 11px;
    border: 1px solid rgba(69, 240, 183, .28);
    border-radius: 999px;
    background: rgba(69, 240, 183, .08);
    color: var(--green);
    font-size: 13px;
    font-weight: 700;
}

.student-payment-overview span.is-danger {
    border-color: rgba(255, 85, 112, .38);
    background: rgba(255, 85, 112, .12);
    color: var(--danger);
}

.student-payment-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.student-payment-form label {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: 12px;
}

.student-payment-form .submit-button {
    grid-column: 1 / -1;
    min-height: 38px;
}

.student-payment-form .student-payment-status-field,
.student-payment-form .student-comorbidity-field {
    grid-column: 1 / -1;
}

.student-payment-form textarea {
    min-height: 74px;
    resize: vertical;
}

.student-danger-actions {
    display: grid;
}

.student-danger-actions .submit-button {
    width: 100%;
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 12px;
}

.profile-avatar {
    grid-column: 1 / -1;
    display: grid;
    align-content: start;
    gap: 12px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--line);
}

.profile-avatar-head {
    display: flex;
    align-items: center;
    gap: 14px;
}

.profile-level-badge {
    position: static;
    min-width: 0;
    max-width: 150px;
    padding: 5px 10px;
    border: 1px solid currentColor;
    border-radius: 999px;
    background: var(--surface-glass);
    font-size: 14px;
    line-height: 1.2;
    font-weight: 700;
    letter-spacing: 0;
    text-align: left;
    white-space: nowrap;
}

.profile-badge-stack {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
}

.profile-id-badge {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(24, 168, 255, .42);
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 22%, rgba(69, 240, 183, .28), transparent 38%),
        linear-gradient(135deg, rgba(24, 168, 255, .2), rgba(69, 240, 183, .12)),
        var(--surface-glass);
    color: var(--blue);
    box-shadow: 0 10px 26px rgba(24, 168, 255, .18), inset 0 0 0 1px rgba(255, 255, 255, .08);
    font-size: 10px;
    line-height: 1;
    font-weight: 700;
    text-align: center;
    white-space: normal;
}

.profile-id-badge strong {
    display: block;
    max-width: 38px;
    overflow: hidden;
    color: var(--green);
    font-size: 14px;
    line-height: 1;
    text-overflow: ellipsis;
    text-align: center;
}

.profile-id-badge-inline {
    border-color: rgba(69, 240, 183, .42);
    background: rgba(69, 240, 183, .08);
    color: var(--green);
}

.avatar-preview {
    display: grid;
    place-items: center;
    width: 128px;
    height: 128px;
    border: 1px solid var(--line);
    border-radius: 50%;
    background: var(--surface-glass);
    overflow: hidden;
    color: var(--green);
    font-size: 42px;
    font-weight: 800;
}

.avatar-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.avatar-preview canvas {
    width: 100%;
    height: 100%;
    cursor: grab;
    touch-action: none;
}

.avatar-preview canvas:active {
    cursor: grabbing;
}

.avatar-file-field {
    display: grid;
    gap: 7px;
    width: min(280px, 100%);
    color: var(--muted);
    font-size: 13px;
}

.avatar-file-input {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
}

.avatar-file-button {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 34px;
    padding: 0 10px;
    border: 1px solid rgba(148, 163, 184, .7);
    border-radius: 8px;
    background: var(--field-bg);
    color: var(--muted);
    cursor: pointer;
    text-align: left;
    overflow: hidden;
}

.avatar-file-button span {
    pointer-events: none;
}

.avatar-file-button:hover,
.avatar-file-button:focus-visible {
    border-color: rgba(148, 163, 184, .95);
    background: var(--surface-glass);
    outline: 0;
}

.avatar-file-button:active {
    border-color: rgba(203, 213, 225, .9);
    box-shadow: inset 0 0 12px rgba(226, 232, 240, .24);
}

.avatar-file-field small {
    color: var(--muted);
    overflow-wrap: anywhere;
}

.avatar-controls {
    display: grid;
    gap: 9px;
    width: min(240px, 100%);
}

.avatar-controls[hidden] {
    display: none;
}

.avatar-controls label {
    gap: 5px;
    font-size: 12px;
}

.avatar-controls input[type="range"] {
    width: 100%;
    accent-color: var(--green);
}

.report-editor {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 14px;
    margin-top: 12px;
    align-items: start;
}

.report-card,
.report-history {
    display: grid;
    gap: 12px;
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.report-card {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.report-card label {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.report-card .full {
    grid-column: 1 / -1;
}

.report-history h2 {
    font-size: 18px;
}

.report-item {
    display: grid;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 14px;
    background: var(--surface-glass);
}

.report-item strong,
.report-item span {
    display: block;
}

.report-item span {
    margin-top: 3px;
    color: var(--muted);
    font-size: 12px;
}

.report-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.report-meta span {
    margin-top: 0;
    padding: 5px 8px;
    border: 1px solid var(--line);
    border-radius: 999px;
    color: var(--text);
    background: var(--panel-2);
}

.admin-workspace {
    display: grid;
    grid-template-columns: minmax(0, 1.35fr) minmax(320px, .8fr);
    gap: 14px;
    align-items: start;
}

.admin-master,
.admin-detail-panel,
.admin-detail-empty {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.admin-master {
    min-width: 0;
    overflow: hidden;
}

.admin-toolbar {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(130px, .42fr) minmax(150px, .48fr);
    gap: 10px;
    padding: 12px;
    border-bottom: 1px solid var(--line);
}

.admin-toolbar label,
.admin-detail-form label {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.admin-search {
    min-width: 0;
}

.admin-table-head,
.admin-list-row {
    display: grid;
    align-items: center;
    gap: 10px;
}

.report-table-head,
.report-row {
    grid-template-columns: 94px minmax(220px, 1fr) minmax(120px, .46fr) minmax(120px, .46fr);
}

.user-table-head,
.user-row {
    grid-template-columns: minmax(220px, 1fr) 124px 104px minmax(120px, .5fr);
}

.student-table-head {
    grid-template-columns: minmax(220px, 1fr) 112px 112px 112px minmax(120px, .5fr);
}

.student-row {
    grid-template-columns: 42px minmax(180px, 1fr) 112px 112px 112px minmax(120px, .5fr);
}

.student-row.is-overdue {
    box-shadow: inset 4px 0 0 var(--danger);
}

.student-detail-panel.is-overdue {
    border-color: rgba(255, 85, 112, .38);
}

.admin-table-head {
    padding: 10px 14px;
    border-bottom: 1px solid var(--line);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.admin-row-list {
    min-height: 0;
}

.admin-list-row {
    width: 100%;
    min-height: 60px;
    padding: 10px 14px;
    border: 0;
    border-bottom: 1px solid var(--line);
    background: transparent;
    color: var(--text);
    text-align: left;
    cursor: pointer;
}

.admin-list-row[hidden] {
    display: none;
}

.admin-list-row:hover,
.admin-list-row:focus-visible,
.admin-list-row.is-active {
    background: var(--surface-glass);
    outline: 0;
}

.admin-list-row.is-active {
    box-shadow: inset 4px 0 0 var(--blue);
}

.admin-list-row strong,
.admin-list-row small {
    display: block;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.admin-list-row small,
.admin-list-row > span {
    color: var(--muted);
    font-size: 12px;
}

.admin-list-row strong {
    color: var(--text);
    font-size: 14px;
}

.status-badge {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    max-width: 100%;
    padding: 4px 8px;
    border: 1px solid rgba(24, 168, 255, .34);
    border-radius: 999px;
    background: rgba(24, 168, 255, .12);
    color: var(--blue) !important;
    font-size: 12px;
    white-space: nowrap;
}

.status-badge.success {
    border-color: rgba(69, 240, 183, .34);
    background: rgba(69, 240, 183, .12);
    color: var(--green) !important;
}

.status-badge.danger {
    border-color: rgba(255, 85, 112, .38);
    background: rgba(255, 85, 112, .12);
    color: var(--danger) !important;
}

.status-badge.open {
    border-color: rgba(24, 168, 255, .38);
    background: rgba(24, 168, 255, .12);
    color: var(--blue) !important;
}

.status-badge.warning {
    border-color: rgba(246, 211, 101, .38);
    background: rgba(246, 211, 101, .12);
    color: #f6d365 !important;
}

.user-status-id {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}

.user-id-badge {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 4px 8px;
    border: 1px solid rgba(24, 168, 255, .34);
    border-radius: 999px;
    background:
        linear-gradient(135deg, rgba(24, 168, 255, .18), rgba(69, 240, 183, .12)),
        var(--surface-glass);
    color: var(--blue) !important;
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
}

.group-badge {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    max-width: 100%;
    padding: 4px 8px;
    border: 1px solid rgba(69, 240, 183, .26);
    border-radius: 999px;
    background: rgba(69, 240, 183, .075);
    color: var(--green) !important;
    font-size: 12px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.admin-filter-empty {
    margin: 12px;
}

.admin-detail-stack {
    position: sticky;
    top: 70px;
    min-width: 0;
}

.admin-detail-panel {
    display: grid;
    gap: 14px;
    padding: 16px;
}

.admin-detail-panel[hidden] {
    display: none;
}

.admin-detail-empty {
    display: grid;
    gap: 6px;
    padding: 18px;
}

.admin-detail-empty span {
    color: var(--muted);
}

.admin-detail-head {
    display: grid;
    gap: 7px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--line);
}

.linked-user-head {
    display: flex;
    align-items: center;
    gap: 12px;
}

.linked-user-head > div {
    min-width: 0;
}

.linked-user-avatar {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 68px;
    height: 68px;
    overflow: hidden;
    border: 1px solid rgba(69, 240, 183, .34);
    border-radius: 50%;
    background:
        radial-gradient(circle at 35% 22%, rgba(24, 168, 255, .2), transparent 38%),
        var(--surface-glass);
    color: var(--green);
    font-size: 24px;
    font-weight: 800;
    line-height: 1;
}

.linked-user-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.linked-user-avatar-sm {
    width: 34px;
    height: 34px;
    font-size: 13px;
}

.admin-detail-head h2 {
    font-size: 22px;
    line-height: 1.1;
    overflow-wrap: anywhere;
}

.admin-detail-head p,
.admin-detail-body p {
    color: var(--muted);
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.admin-detail-body {
    display: grid;
    gap: 12px;
}

.admin-detail-form {
    display: grid;
    gap: 10px;
}

.sharing-management {
    display: grid;
    gap: 14px;
}

.sharing-overview {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.sharing-overview div,
.sharing-panel,
.sharing-item {
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
}

.sharing-overview div {
    display: grid;
    gap: 4px;
    padding: 16px;
}

.sharing-overview span,
.sharing-panel-head span,
.sharing-item-meta span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 700;
}

.sharing-overview strong {
    color: var(--green);
    font-size: 30px;
    line-height: 1;
}

.sharing-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    align-items: start;
}

.sharing-panel {
    overflow: hidden;
}

.sharing-panel-head {
    display: grid;
    gap: 7px;
    padding: 16px;
    border-bottom: 1px solid var(--line);
}

.sharing-panel-head h2 {
    font-size: 22px;
    line-height: 1.1;
}

.sharing-list {
    display: grid;
}

.sharing-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    margin: 12px;
    padding: 14px;
    box-shadow: none;
}

.sharing-item + .sharing-item {
    margin-top: 0;
}

.sharing-item-main {
    min-width: 0;
}

.sharing-item-main h3 {
    margin-top: 8px;
    font-size: 17px;
    line-height: 1.15;
    overflow-wrap: anywhere;
}

.sharing-item-main p {
    margin-top: 5px;
    color: var(--muted);
    font-size: 13px;
    line-height: 1.35;
}

.sharing-item-meta {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.sharing-item-meta span {
    padding: 6px 9px;
    border: 1px solid rgba(24, 168, 255, .24);
    border-radius: 999px;
    background: rgba(24, 168, 255, .08);
    color: var(--blue);
}

.sharing-actions {
    align-self: start;
}

.sharing-actions .submit-button {
    min-height: 34px;
    padding: 8px 11px;
    border-radius: 11px;
}

.user-detail-form {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.user-detail-form .full,
.user-detail-form button {
    grid-column: 1 / -1;
}

.user-detail-form > label:has(input[name="nome"]) {
    grid-column: 1 / -1;
}

.user-detail-form .admin-user-nickname-field {
    grid-column: 1;
}

.user-detail-form > label:has(input[type="email"]) {
    grid-column: 1 / -1;
}

.user-detail-form .admin-user-phone-field {
    grid-column: 1;
}

.user-detail-form .admin-user-birth-field,
.user-detail-form .admin-user-weight-field {
    grid-column: 1;
}

.user-detail-form .admin-user-sex-field,
.user-detail-form .admin-user-height-field {
    grid-column: 2;
}

.user-detail-form .user-level-field {
    grid-column: 2;
}

.user-detail-form .imc-card {
    grid-column: 1 / -1;
}

.user-detail-form .user-credential-cards {
    order: 20;
}

.user-detail-form .admin-meta {
    order: 21;
}

.user-detail-form button {
    order: 22;
}

.user-detail-form .submit-button.warning,
.user-detail-form .submit-button.danger {
    min-height: 36px;
    padding: 8px 12px;
    border-radius: 12px;
}

.user-credential-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.simple-info-card {
    display: grid;
    gap: 3px;
    min-width: 0;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--surface-glass);
}

.simple-info-card span {
    color: var(--muted);
    font-size: 11px;
}

.simple-info-card strong {
    color: var(--text);
    font-size: 13px;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.simple-info-card small {
    color: var(--muted);
    font-size: 10px;
    line-height: 1.3;
}

.profile-phone-field {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 8px;
}

.profile-phone-field > label:not(.phone-visibility-toggle) {
    min-width: 0;
}

.profile-phone-field .phone-visibility-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    min-height: 24px;
    margin-top: 30px;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--surface-glass);
    color: var(--muted);
    cursor: pointer;
    user-select: none;
}

.profile-phone-field .phone-visibility-toggle input {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.profile-phone-field .phone-eye {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.profile-phone-field .phone-eye-open {
    display: none;
}

.profile-phone-field .phone-visibility-toggle:has(input:checked) {
    border-color: rgba(69, 240, 183, .42);
    background: rgba(69, 240, 183, .12);
    color: var(--green);
    box-shadow: 0 10px 24px rgba(69, 240, 183, .1);
}

.profile-phone-field .phone-visibility-toggle:has(input:checked) .phone-eye-open {
    display: inline-flex;
}

.profile-phone-field .phone-visibility-toggle:has(input:checked) .phone-eye-closed {
    display: none;
}

.profile-phone-field .phone-visibility-hint {
    color: var(--muted);
    font-size: 10px;
    line-height: 1.25;
}

.profile-phone-field:has(.phone-visibility-toggle input:not(:checked)) .phone-visibility-hint {
    color: color-mix(in srgb, var(--muted) 82%, #111827);
}

.admin-list {
    display: grid;
    gap: 12px;
}

.admin-item {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
    gap: 14px;
    align-items: start;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--panel);
    box-shadow: 0 16px 40px var(--shadow);
}

.admin-item-main {
    display: grid;
    gap: 6px;
    min-width: 0;
}

.admin-item-main strong,
.admin-item-main span,
.admin-item-main p {
    min-width: 0;
    overflow-wrap: anywhere;
}

.admin-item-main span,
.admin-item-main p {
    color: var(--muted);
    font-size: 13px;
}

.admin-item-main p {
    margin: 4px 0 0;
    line-height: 1.45;
}

.admin-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}

.admin-meta span {
    padding: 5px 8px;
    border: 1px solid var(--line);
    border-radius: 999px;
    background: var(--panel-2);
    color: var(--text);
    font-size: 12px;
}

.admin-inline-form,
.admin-user-fields {
    display: grid;
    gap: 10px;
}

.admin-inline-form label,
.admin-user-fields label {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.admin-inline-form button,
.admin-user-fields button {
    min-height: 38px;
}

.user-admin-item {
    grid-template-columns: minmax(220px, .9fr) minmax(360px, 1.6fr);
}

.admin-user-fields {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-user-fields button {
    align-self: end;
}

.folder-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.workout-folder {
    position: relative;
    min-height: 320px;
    padding: 18px;
    border: 1px solid var(--line);
    border-top: 4px solid var(--accent);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 20px 48px var(--shadow);
    cursor: pointer;
    transition: min-height .2s ease, box-shadow .2s ease, transform .2s ease;
}

.workout-folder::before {
    content: "";
    position: absolute;
    top: -13px;
    left: 18px;
    width: 96px;
    height: 16px;
    border-radius: 10px 10px 0 0;
    background: var(--accent);
}

.workout-folder.is-collapsed {
    min-height: 0;
    box-shadow: 0 12px 30px var(--shadow);
}

.workout-folder.is-collapsed .gym-note,
.workout-folder.is-collapsed .exercise-list,
.workout-folder.is-collapsed .teacher-student-list,
.workout-folder.is-collapsed .teacher-plan-panels {
    display: none;
}

.workout-folder.is-collapsed .folder-actions {
    margin-top: 10px;
}

.folder-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 12px;
}

.folder-label {
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.folder-head h2 {
    margin-top: 4px;
    font-size: 23px;
    line-height: 1.08;
}

.status-pill {
    padding: 6px 10px;
    border-radius: 999px;
    background: var(--surface-glass);
    color: var(--muted);
    font-size: 12px;
}

.plan-head-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 0 0 auto;
}

.share-plan-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    width: 26px;
    height: 26px;
    border-radius: 8px;
    border: 1px solid var(--line);
    background: var(--surface-glass);
    color: var(--blue);
    font-size: 14px;
    line-height: 1;
    cursor: pointer;
    transition: background 0.15s;
}

.share-plan-button:hover {
    background: rgba(24, 168, 255, .15);
}

.share-plan-button.is-shared {
    color: var(--blue);
    background: rgba(24, 168, 255, .14);
    border-color: var(--blue);
}

.folder-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 14px 0;
}

.folder-meta span {
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(24, 168, 255, .12);
    color: var(--blue);
    font-size: 13px;
}

.folder-meta .folder-day {
    font-size: 16px;
    font-weight: 800;
}

.folder-meta .shared-by-badge {
    border: 1px solid rgba(69, 240, 183, .28);
    background: rgba(69, 240, 183, .10);
    color: var(--green);
}

.gym-note,
.folder-note {
    margin: 10px 0;
    font-size: 14px;
    line-height: 1.45;
}

.exercise-list {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.teacher-day-folder {
    cursor: pointer;
}

.teacher-student-list {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.teacher-student-group {
    display: grid;
    gap: 8px;
    padding: 10px;
    border: 1px solid rgba(69, 240, 183, .22);
    border-radius: 14px;
    background: rgba(69, 240, 183, .055);
}

.teacher-student-group-title {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 4px 9px;
    border: 1px solid rgba(69, 240, 183, .32);
    border-radius: 999px;
    background: var(--surface-glass);
    color: var(--green);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
}

.teacher-student-group-list {
    display: grid;
    gap: 8px;
}

.teacher-student-button {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    width: 100%;
    padding: 11px 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel-2);
    color: var(--text);
    text-align: left;
    cursor: pointer;
}

.teacher-student-button:hover,
.teacher-student-button.is-active {
    border-color: rgba(69, 240, 183, .42);
    background: rgba(69, 240, 183, .12);
}

.teacher-student-button strong,
.teacher-student-button span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.teacher-student-main {
    display: inline-flex;
    align-items: center;
    gap: 9px;
}

.teacher-student-avatar {
    flex: 0 0 auto;
    display: grid;
    place-items: center;
    width: 40px;
    height: 40px;
    overflow: hidden;
    border: 1px solid rgba(69, 240, 183, .34);
    border-radius: 50%;
    background: var(--surface-glass);
    color: var(--green);
    font-size: 14px;
    font-weight: 800;
    line-height: 1;
}

.teacher-student-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.teacher-student-button span {
    color: var(--muted);
    font-size: 12px;
}

.teacher-student-button .teacher-student-main strong {
    color: var(--text);
    font-size: 14px;
}

.teacher-plan-panels {
    display: grid;
    gap: 12px;
    margin-top: 14px;
}

.teacher-plan-panel {
    display: none;
    gap: 10px;
    padding-top: 12px;
    border-top: 1px solid var(--line);
}

.teacher-plan-panel.is-active {
    display: grid;
}

.teacher-plan-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 10px;
}

.teacher-plan-academy {
    color: var(--accent);
    font-size: 12px;
    font-weight: 800;
}

.teacher-plan-head h3 {
    margin: 3px 0 0;
    font-size: 18px;
    line-height: 1.2;
}

.exercise-row {
    position: relative;
    display: grid;
    grid-template-columns: 90px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    padding: 12px 30px 12px 12px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel-2);
}

.exercise-thumb-button {
    width: 90px;
    height: 90px;
    padding: 0;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--field-bg);
    cursor: zoom-in;
    overflow: hidden;
}

.exercise-thumb {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.exercise-row.is-executed .exercise-thumb-button {
    border-color: rgba(69, 240, 183, .6);
    box-shadow: 0 0 0 3px rgba(69, 240, 183, .12);
}

.exercise-row.is-executed > div > strong {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.exercise-row.is-executed > div > strong::after {
    content: "\2713";
    display: inline-grid;
    place-items: center;
    flex: 0 0 auto;
    width: 17px;
    height: 17px;
    border-radius: 50%;
    background: rgba(69, 240, 183, .16);
    color: var(--green);
    font-size: 12px;
    font-weight: 900;
    line-height: 1;
    box-shadow: 0 0 0 2px rgba(69, 240, 183, .12);
}

.exercise-thumb.placeholder {
    display: grid;
    place-items: center;
    width: 90px;
    height: 90px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--field-bg);
    color: var(--muted);
    font-size: 11px;
    font-weight: 800;
}

.gif-viewer {
    position: fixed;
    inset: 0;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px 0;
    background: rgba(0, 0, 0, .78);
    z-index: 60;
}

.gif-viewer.open {
    display: flex;
}

.gif-viewer-panel {
    width: 100%;
    max-width: 760px;
    max-height: 92vh;
    overflow: hidden;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    background: var(--panel);
    box-shadow: 0 30px 80px rgba(0, 0, 0, .55);
}

.gif-viewer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 12px 14px;
    border-bottom: 1px solid var(--line);
}

.gif-viewer-head h2 {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 18px;
}

.gif-carousel {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
}

.gif-carousel::-webkit-scrollbar {
    display: none;
}

.gif-slide-card {
    width: 100%;
    max-height: calc(92vh - 58px);
    overflow-y: auto;
    scroll-snap-align: start;
    background: var(--panel);
}

.gif-slide-card img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 58vh;
    object-fit: contain;
    background: #fff;
}

.gif-image-stage {
    position: relative;
    overflow: hidden;
    background: #fff;
}

.gif-main-image {
    touch-action: pan-x pan-y;
    user-select: none;
    -webkit-user-select: none;
    -webkit-touch-callout: none;
}

.gif-done-control {
    position: absolute;
    top: 10px;
    right: 10px;
    z-index: 3;
    display: grid;
    justify-items: center;
    gap: 3px;
    min-width: 42px;
    padding: 0;
    border: 0;
    background: transparent;
    filter: drop-shadow(0 8px 16px rgba(0, 0, 0, .26));
    cursor: pointer;
    user-select: none;
}

.gif-swap-control {
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 3;
    display: grid;
    justify-items: center;
    place-items: center;
    gap: 2px;
    width: 42px;
    min-width: 42px;
    padding: 0;
    border: 0;
    background: transparent;
    filter: drop-shadow(0 8px 16px rgba(0, 0, 0, .26));
    cursor: pointer;
    user-select: none;
}

.gif-swap-control img {
    display: block;
    width: 31px;
    height: 31px;
    object-fit: contain;
    background: transparent;
}

.gif-swap-control small {
    margin-top: -1px;
    color: #374151;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    text-shadow: 0 1px 2px rgba(255, 255, 255, .8);
}

.gif-swap-control:focus-visible img {
    outline: 2px solid rgba(24, 168, 255, .7);
    outline-offset: 2px;
}

.gif-done-control input {
    position: absolute;
    width: 1px;
    min-height: 0;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.gif-done-check {
    display: grid;
    place-items: center;
    width: 28px;
    height: 28px;
    border: 2px solid rgba(212, 175, 55, .82);
    border-radius: 50%;
    background: rgba(255, 255, 255, .92);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .78),
        0 0 0 4px rgba(212, 175, 55, .18);
    color: #062015;
    transition: border-color .18s ease, background .18s ease, box-shadow .18s ease, transform .18s ease;
}

.gif-done-check::before {
    content: "";
    font-size: 17px;
    font-weight: 900;
    line-height: 1;
}

.gif-done-control small {
    color: #374151;
    font-size: 11px;
    font-weight: 800;
    line-height: 1;
    text-shadow: 0 1px 2px rgba(255, 255, 255, .8);
}

.gif-done-control input:focus-visible + .gif-done-check {
    outline: 2px solid rgba(24, 168, 255, .7);
    outline-offset: 2px;
}

.gif-done-control input:checked + .gif-done-check {
    border-color: rgba(69, 240, 183, .9);
    background: var(--green);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .36),
        0 0 0 5px rgba(69, 240, 183, .18),
        0 10px 24px rgba(69, 240, 183, .22);
    transform: scale(1.04);
}

.gif-done-control input:checked + .gif-done-check::before {
    content: "\2713";
}

.gif-done-control input:checked ~ small {
    color: #047857;
}

.gif-done-control.is-disabled {
    cursor: not-allowed;
    filter: grayscale(.35) drop-shadow(0 6px 12px rgba(0, 0, 0, .18));
    opacity: .62;
}

.gif-done-control.is-disabled .gif-done-check {
    border-color: rgba(107, 114, 128, .72);
    background: rgba(229, 231, 235, .9);
    box-shadow: 0 0 0 4px rgba(107, 114, 128, .12);
}

.gif-done-control.is-disabled small,
.gif-done-control.is-disabled input:checked ~ small {
    color: #374151;
}

.exercise-done-burst {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    place-items: center;
    color: #fff;
    font-size: clamp(72px, 20vw, 148px);
    text-shadow:
        0 14px 34px rgba(0, 0, 0, .42),
        0 0 26px rgba(69, 240, 183, .38);
    pointer-events: none;
    animation: exerciseDoneThumb 2s cubic-bezier(.2, .9, .25, 1) both;
}

.exercise-done-burst::before,
.exercise-done-burst::after {
    content: "";
    position: absolute;
    width: clamp(120px, 30vw, 230px);
    height: clamp(120px, 30vw, 230px);
    border-radius: 50%;
    border: 2px solid rgba(69, 240, 183, .55);
    pointer-events: none;
}

.exercise-done-burst::before {
    transform-origin: 46% 52%;
    animation: exerciseDoneRing 2s ease-out both;
}

.exercise-done-burst::after {
    width: clamp(96px, 25vw, 190px);
    height: clamp(96px, 25vw, 190px);
    border-color: rgba(69, 240, 183, .38);
    transform-origin: 57% 45%;
    animation: exerciseDoneRingSecond 2s cubic-bezier(.16, .84, .25, 1) .18s both;
}

@keyframes exerciseDoneThumb {
    0% {
        opacity: 0;
        transform: scale(.48) rotate(-24deg) translateY(18px);
    }
    10% {
        opacity: 1;
        transform: scale(1.12) rotate(12deg) translateY(0);
    }
    20% {
        transform: scale(.98) rotate(-9deg) translateY(-4px);
    }
    34% {
        transform: scale(1.04) rotate(8deg) translateY(0);
    }
    48% {
        transform: scale(1) rotate(-6deg) translateY(-3px);
    }
    68% {
        opacity: 1;
        transform: scale(1.03) rotate(5deg) translateY(0);
    }
    86% {
        opacity: .9;
        transform: scale(.98) rotate(-2deg) translateY(2px);
    }
    100% {
        opacity: 0;
        transform: scale(.78) rotate(0) translateY(-14px);
    }
}

@keyframes exerciseDoneRing {
    0% {
        opacity: 0;
        transform: translate(-18px, 10px) scale(.2);
    }
    12% {
        opacity: .95;
    }
    72% {
        opacity: .38;
        transform: translate(-8px, 4px) scale(1.18);
    }
    100% {
        opacity: 0;
        transform: translate(-2px, -4px) scale(1.38);
    }
}

@keyframes exerciseDoneRingSecond {
    0% {
        opacity: 0;
        transform: translate(22px, -12px) scale(.18);
    }
    18% {
        opacity: .86;
    }
    62% {
        opacity: .42;
        transform: translate(12px, -6px) scale(1.24);
    }
    100% {
        opacity: 0;
        transform: translate(4px, 2px) scale(1.55);
    }
}

.gif-viewer-info {
    padding: 12px;
    border-top: 1px solid var(--line);
}

.gif-exercise-heading {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-bottom: 10px;
}

.gif-exercise-heading h3 {
    margin: 0;
    font-size: 16px;
    line-height: 1.15;
}

.gif-group-badge {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border: 1px solid rgba(69, 240, 183, .42);
    border-radius: 999px;
    background: rgba(69, 240, 183, .10);
    color: var(--green);
    font-size: 14px;
    font-weight: 800;
}

.gif-info-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.gif-info-item {
    min-width: 0;
    padding: 9px 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--panel-2);
}

.gif-info-item span,
.gif-info-item strong {
    display: block;
}

.gif-info-item span {
    color: var(--muted);
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

.gif-info-item strong {
    margin-top: 3px;
    overflow-wrap: anywhere;
    font-size: 12px;
}

.series-projection {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
    gap: 6px;
    margin-top: 8px;
}

.series-block {
    width: 100%;
    min-width: 0;
    padding: 8px 7px;
    border: 1px solid var(--line);
    border-radius: 10px;
    background: var(--panel-2);
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
    transition: border-color .18s ease, transform .18s ease, background .18s ease;
}

.series-block:hover,
.series-block:focus-visible {
    border-color: rgba(24, 168, 255, .55);
    background: var(--surface-glass);
    outline: 0;
    transform: translateY(-1px);
}

.series-block span,
.series-block strong,
.series-block small {
    display: block;
}

.series-block span {
    color: var(--muted);
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
}

.series-block strong {
    margin-top: 3px;
    color: var(--text);
    font-size: 12px;
}

.series-block small {
    margin-top: 2px;
    color: var(--green);
    font-size: 13px;
    font-weight: 800;
}

.gif-info-notes {
    display: grid;
    gap: 8px;
    margin-top: 8px;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface-glass);
    color: var(--muted);
    font-size: 12px;
    line-height: 1.35;
}

.gif-note-row {
    display: grid;
    grid-template-columns: 108px minmax(0, 1fr);
    gap: 8px;
    align-items: start;
}

.gif-score-row {
    display: flex;
    justify-content: flex-start;
}

.gif-score-row .status-badge {
    width: fit-content;
    white-space: normal;
}

.gif-note-row strong {
    flex: 0 0 auto;
    color: var(--text);
    white-space: nowrap;
}

.gif-note-row span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.exercise-row strong,
.exercise-row span,
.sets b,
.sets small {
    display: block;
}

.exercise-row span,
.sets small {
    margin-top: 3px;
    font-size: 12px;
}

.exercise-progress {
    display: grid;
    gap: 4px;
    grid-column: 1 / -1;
    margin-top: 2px;
    padding-top: 8px;
    border-top: 1px solid var(--line);
}

.exercise-progress > span {
    display: block;
    max-width: 100%;
    overflow-wrap: anywhere;
    line-height: 1.35;
}

.exercise-progress .status-badge {
    display: inline-flex;
    width: fit-content;
    white-space: normal;
}

.exercise-progress .progress-order,
.exercise-progress .progress-separator {
    display: inline;
    margin-top: 0;
    font-size: inherit;
    line-height: inherit;
}

.exercise-reorder {
    position: absolute;
    right: 8px;
    bottom: 8px;
    display: grid;
    gap: 0;
    margin: 0;
    overflow: hidden;
    border: 1px solid var(--line);
    border-radius: 9px;
    background: var(--panel-2);
    box-shadow: 0 10px 24px var(--shadow);
}

.exercise-reorder button {
    width: 15px;
    height: 15px;
    padding: 0;
    border: 0;
    background: transparent;
    color: var(--muted);
    font-size: 0;
    line-height: 1;
    cursor: pointer;
    opacity: .78;
}

.exercise-reorder button + button {
    border-top: 1px solid var(--line);
}

.exercise-reorder button::before {
    font-size: 9px;
    line-height: 1;
}

.exercise-reorder button[value="up"]::before {
    content: "\25B2";
}

.exercise-reorder button[value="down"]::before {
    content: "\25BC";
}

.exercise-reorder button:hover {
    color: var(--text);
    background: var(--surface-glass);
    opacity: 1;
}

.sets {
    min-width: 58px;
    text-align: right;
}

.sets b {
    font-size: 18px;
    color: var(--green);
}

.progress-order {
    color: var(--blue);
    font-weight: 400;
}

.progress-separator {
    color: var(--muted);
    font-weight: 400;
}

.folder-actions {
    display: grid;
    gap: 8px;
    margin-top: 14px;
}

.plan-completion-card {
    display: grid;
    gap: 5px;
    margin-top: 14px;
    padding: 14px;
    border: 1px solid rgba(69, 240, 183, .58);
    border-radius: 14px;
    background:
        linear-gradient(135deg, rgba(69, 240, 183, .24), rgba(24, 168, 255, .1)),
        color-mix(in srgb, var(--panel) 74%, rgba(69, 240, 183, .2));
    color: var(--text);
    box-shadow: 0 18px 38px rgba(69, 240, 183, .16);
    opacity: 1;
    transform: translateY(0);
    transition: opacity .42s ease, transform .42s ease;
}

.plan-completion-card[hidden] {
    display: none;
}

.plan-completion-card.is-fading-out {
    opacity: 0;
    transform: translateY(6px);
}

.plan-completion-card.is-golden-progress {
    border-color: rgba(214, 169, 47, .58);
    background:
        linear-gradient(135deg, rgba(246, 211, 101, .24), rgba(214, 169, 47, .12)),
        color-mix(in srgb, var(--panel) 76%, rgba(246, 211, 101, .2));
    box-shadow: 0 18px 38px rgba(214, 169, 47, .14);
}

.plan-completion-card.is-compact-progress {
    grid-template-columns: minmax(0, 1fr);
    align-content: center;
    min-height: 34px;
    padding: 0 12px;
    gap: 0;
    border-radius: 12px;
    box-shadow: 0 10px 22px rgba(69, 240, 183, .12);
    cursor: pointer;
}

.plan-completion-card.is-compact-progress:hover,
.plan-completion-card.is-compact-progress:focus {
    border-color: rgba(69, 240, 183, .72);
    outline: 0;
}

.plan-completion-card.is-golden-progress.is-compact-progress:hover,
.plan-completion-card.is-golden-progress.is-compact-progress:focus {
    border-color: rgba(214, 169, 47, .78);
}

.plan-completion-card.is-golden-progress.is-compact-progress {
    box-shadow: 0 10px 22px rgba(214, 169, 47, .14);
}

.plan-completion-card.is-compact-progress strong {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: var(--green);
    font-size: 13px;
    line-height: 1.2;
}

.plan-completion-card.is-compact-progress strong::before {
    content: attr(data-compact-icon);
    flex: 0 0 auto;
    font-size: 13px;
    line-height: 1;
}

.plan-completion-card.is-completed-progress.is-compact-progress strong::before {
    font-size: 15px;
}

.plan-completion-card.is-compact-progress span {
    display: none;
}

.plan-completion-card:focus {
    outline: 2px solid rgba(69, 240, 183, .58);
    outline-offset: 3px;
}

.plan-completion-card.is-golden-progress:focus {
    outline-color: rgba(214, 169, 47, .68);
}

.plan-completion-card.is-zero-progress:focus {
    outline: 0;
}

.plan-completion-card strong {
    color: var(--green);
    font-size: 18px;
    line-height: 1.1;
}

.plan-completion-card span {
    color: color-mix(in srgb, var(--text) 82%, var(--green) 18%);
    font-size: 14px;
    font-weight: 800;
}

.plan-completion-card.is-golden-progress strong,
.plan-completion-card.is-golden-progress.is-compact-progress strong {
    color: var(--orange-light);
}

.plan-completion-card.is-golden-progress span {
    color: #fff;
}

.modal.plan-reset-modal {
    align-items: center;
    padding: 18px;
}

.plan-reset-modal .modal-panel.compact {
    width: min(340px, calc(100vw - 28px));
    border-radius: 18px;
    padding-top: 14px;
    padding-bottom: 18px;
}

.plan-reset-modal .submit-button {
    width: 100%;
    font-size: calc(.86rem + 2px);
}

.folder-actions form {
    margin: 0;
}

.folder-actions button {
    width: 100%;
    min-height: 34px;
    padding: 0 12px;
    font-size: 13px;
    font-weight: 400;
    color: var(--danger);
}

.folder-actions > button {
    color: var(--blue);
}

.folder-actions .restore-plan-button {
    color: var(--green);
}

.empty-state {
    padding: 22px;
    border: 1px dashed var(--line);
    border-radius: 18px;
    background: var(--surface-glass);
}

.empty-state span {
    display: block;
    margin-top: 6px;
    color: var(--muted);
}

.system-dialog {
    position: fixed;
    inset: 0;
    z-index: 130;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    background: rgba(0, 0, 0, .72);
}

.system-dialog.open {
    display: flex;
}

.system-dialog-panel {
    width: min(430px, 100%);
    padding: 18px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: var(--panel);
    box-shadow: 0 30px 80px rgba(0, 0, 0, .54);
}

.system-dialog-panel:focus {
    outline: 0;
}

.system-dialog-panel h2 {
    margin: 0;
    font-size: 20px;
    line-height: 1.2;
}

.system-dialog-panel p {
    margin-top: 10px;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.45;
}

.system-dialog-actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 18px;
}

.system-dialog-button {
    min-height: 40px;
    padding: 0 14px;
    border: 1px solid var(--line);
    border-radius: 12px;
    background: var(--surface-glass);
    color: var(--text);
    cursor: pointer;
}

.system-dialog-button.primary {
    border-color: rgba(24, 168, 255, .38);
    background: rgba(24, 168, 255, .14);
    color: var(--blue);
}

.system-dialog.is-danger .system-dialog-button.primary {
    border-color: rgba(255, 85, 112, .42);
    background: rgba(255, 85, 112, .12);
    color: var(--danger);
}

.pull-refresh-indicator {
    --pull-offset: 0px;
    --pull-progress: 0;
    position: fixed;
    top: max(10px, env(safe-area-inset-top));
    left: 50%;
    z-index: 70;
    display: grid;
    place-items: center;
    min-height: 34px;
    min-width: 132px;
    padding: 0 14px;
    border: 1px solid rgba(24, 168, 255, .32);
    border-radius: 999px;
    background: color-mix(in srgb, var(--panel) 86%, transparent);
    color: var(--text);
    font-size: 12px;
    font-weight: 800;
    line-height: 1;
    box-shadow: 0 16px 36px var(--shadow);
    backdrop-filter: blur(12px);
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, calc(-54px + (var(--pull-offset) * .56))) scale(calc(.9 + (var(--pull-progress) * .1)));
    transition: opacity .16s ease, transform .16s ease, border-color .16s ease, color .16s ease;
}

.pull-refresh-indicator.is-visible {
    opacity: calc(.28 + (var(--pull-progress) * .72));
}

.pull-refresh-indicator.is-ready,
.pull-refresh-indicator.is-refreshing {
    border-color: rgba(69, 240, 183, .42);
    color: var(--green);
}

.pull-refresh-indicator.is-refreshing {
    min-width: 36px;
    width: 36px;
    height: 36px;
    padding: 0;
    border-radius: 50%;
}

.pull-refresh-indicator.is-refreshing .pull-refresh-content {
    display: grid;
    place-items: center;
    width: 24px;
    height: 24px;
    line-height: 1;
    transform-origin: center;
    animation: pullRefreshIconSpin .82s cubic-bezier(.42, 0, .58, 1) infinite;
}

.pull-refresh-indicator.is-refreshing svg {
    display: block;
    width: 24px;
    height: 24px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round;
}

@keyframes pullRefreshIconSpin {
    to {
        transform: rotate(360deg);
    }
}

.modal {
    position: fixed;
    inset: 0;
    display: none;
    align-items: end;
    justify-content: center;
    padding: 12px;
    background: rgba(0, 0, 0, .72);
    z-index: 20;
}

.modal.open {
    display: flex;
}

.modal.series-edit-modal {
    align-items: center;
    z-index: 90;
}

.modal.exercise-swap-modal {
    align-items: flex-start;
    z-index: 95;
}

.exercise-swap-modal .modal-panel {
    height: auto;
    margin-top: clamp(12px, calc(50vh - 180px), 150px);
}

.exercise-swap-modal.is-picker-open .modal-panel {
    height: min(660px, calc(100vh - 24px));
    max-height: min(660px, calc(100vh - 24px));
    display: flex;
    flex-direction: column;
}

.exercise-swap-modal.is-picker-open .modal-panel > form {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    align-content: initial;
}

.exercise-swap-modal.is-picker-open .exercise-swap-picker-list {
    max-height: 390px;
}

.exercise-swap-modal.is-picker-open .modal-panel > form > .submit-button {
    margin-top: auto;
    margin-bottom: -5px;
}

.exercise-swap-modal .modal-head h2 {
    font-size: 18px;
    line-height: 1.2;
}

.series-edit-modal .form-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
}

.series-edit-modal .modal-head h2 {
    font-size: 18px;
    line-height: 1.2;
}

.series-edit-third {
    grid-column: span 2;
}

.series-edit-load-start {
    grid-column: span 3;
}

.series-edit-load-end {
    grid-column: span 3;
}

.plan-modal {
    align-items: flex-start;
    padding-top: 64px;
}

.modal-panel {
    width: min(920px, 100%);
    max-height: min(92vh, 860px);
    overflow: auto;
    border: 1px solid var(--line);
    border-radius: 22px;
    background: var(--panel);
    padding: 18px;
    box-shadow: 0 30px 80px rgba(0, 0, 0, .54);
}

.modal-panel.compact {
    width: min(520px, 100%);
}

.new-users-modal .modal-panel.compact {
    width: min(640px, 100%);
}

.new-users-list {
    display: grid;
    gap: 12px;
}

.new-user-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(210px, 240px);
    gap: 14px;
    align-items: end;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-glass);
}

.new-user-card strong,
.new-user-card span,
.new-user-card small {
    display: block;
    min-width: 0;
    overflow-wrap: anywhere;
}

.new-user-card strong {
    color: var(--text);
    font-size: 15px;
}

.new-user-card span,
.new-user-card small {
    color: var(--muted);
    font-size: 12px;
    margin-top: 4px;
}

.new-user-level-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 8px;
    align-items: end;
}

.new-user-level-form label {
    display: grid;
    gap: 6px;
    color: var(--muted);
    font-size: 12px;
}

.new-user-level-form .submit-button {
    min-height: 38px;
    padding: 0 14px;
    border-radius: 12px;
    background: linear-gradient(145deg, #075ca2, #0a8f68);
    font-size: 12px;
    line-height: 1;
}

.registration-id-modal .modal-panel {
    text-align: center;
}

.registration-id-card {
    display: grid;
    gap: 10px;
    padding: 18px;
    border: 1px solid rgba(69, 240, 183, .22);
    border-radius: 8px;
    background: var(--surface-glass);
    margin-bottom: 16px;
}

.registration-id-card span {
    color: var(--muted);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.registration-id-card strong {
    color: var(--green);
    font-size: clamp(48px, 14vw, 82px);
    line-height: .95;
}

.registration-id-card p {
    max-width: 420px;
    margin: 0 auto;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.5;
}

.modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.modal-head-actions {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}

.modal-copy-plan-button {
    width: 30px;
    height: 30px;
    min-width: 30px;
    min-height: 30px;
    flex-basis: 30px;
    border-radius: 10px;
    color: var(--muted);
    font-size: 18px;
}

.modal-copy-plan-button svg {
    width: 18px;
    height: 18px;
}

.modal-copy-plan-button:hover,
.modal-copy-plan-button:focus-visible {
    border-color: color-mix(in srgb, var(--blue) 44%, var(--line));
    color: var(--blue);
    background: color-mix(in srgb, var(--blue) 12%, var(--surface-glass));
}

.modal-head h2 {
    font-size: 24px;
}

.form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.form-grid label,
.academy-card label {
    display: grid;
    gap: 7px;
    color: var(--muted);
    font-size: 13px;
}

.form-grid .full {
    grid-column: 1 / -1;
}

.exercise-builder {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--surface-glass);
}

.exercise-builder .builder-grid,
.exercise-builder .recommendation-field,
.exercise-builder .submit-button,
.exercise-builder .selected-exercises {
    grid-column: 1 / -1;
}

.exercise-picker-field {
    position: relative;
    display: grid;
    gap: 8px;
    color: var(--muted);
    font-size: 13px;
}

.exercise-picker-button {
    min-height: 46px;
    width: 100%;
    padding: 0 14px;
    border: 1px solid rgba(69, 240, 183, .38);
    border-radius: 14px;
    background:
        linear-gradient(135deg, rgba(69, 240, 183, .18), rgba(24, 168, 255, .18)),
        var(--field-bg);
    color: var(--text);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
    cursor: pointer;
    text-align: left;
    transition: border-color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.exercise-picker-button::after {
    content: "⌄";
    float: right;
    color: var(--green);
    font-size: 18px;
    line-height: 1;
}

.exercise-picker-button:hover:not(:disabled),
.exercise-picker-button[aria-expanded="true"] {
    border-color: rgba(69, 240, 183, .64);
    box-shadow: 0 12px 26px rgba(24, 168, 255, .16);
    transform: translateY(-1px);
}

.exercise-picker-button.has-selection {
    border-color: rgba(24, 168, 255, .52);
    background:
        linear-gradient(135deg, rgba(24, 168, 255, .22), rgba(69, 240, 183, .16)),
        var(--field-bg);
}

.exercise-picker-button:disabled {
    cursor: not-allowed;
    opacity: .62;
}

.exercise-picker-list {
    position: absolute;
    inset: calc(100% + 8px) 0 auto 0;
    z-index: 90;
    max-height: 520px;
    overflow: auto;
    display: grid;
    gap: 6px;
    padding: 8px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--panel);
    box-shadow: 0 22px 48px var(--shadow);
}

.exercise-picker-list[hidden] {
    display: none;
}

.exercise-picker-row {
    display: grid;
    grid-template-columns: 80px minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    min-height: 86px;
    padding: 6px 10px 6px 6px;
    border: 1px solid transparent;
    border-radius: 12px;
    background: transparent;
    color: var(--text);
    cursor: pointer;
    text-align: left;
}

.exercise-picker-row:hover {
    border-color: rgba(69, 240, 183, .35);
    background: rgba(69, 240, 183, .075);
}

.exercise-picker-row img,
.exercise-picker-thumb-empty {
    width: 80px;
    height: 80px;
    border-radius: 10px;
    object-fit: cover;
    background: var(--bg-soft);
}

.exercise-picker-thumb-empty {
    display: block;
    border: 1px dashed var(--line);
}

.exercise-picker-row span:last-child {
    min-width: 0;
    overflow-wrap: anywhere;
}

.exercise-swap-modal .exercise-picker-row {
    grid-template-columns: 80px minmax(0, 1fr);
    min-height: 92px;
}

.exercise-swap-modal .exercise-picker-row img,
.exercise-swap-modal .exercise-picker-thumb-empty {
    width: 86px;
    height: 86px;
}

.builder-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
}

.reps-pair-label {
    min-width: 0;
}

.paired-number-inputs {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
}

.paired-number-inputs input {
    min-width: 0;
    width: 100%;
}

.recommendation-field {
    grid-column: 1 / -1;
}

.selected-exercises {
    display: grid;
    gap: 8px;
}

.selected-exercise-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 13px;
    background: var(--panel);
    cursor: grab;
    touch-action: none;
    user-select: none;
}

.selected-exercise-row.is-dragging {
    position: relative;
    z-index: 4;
    cursor: grabbing;
    border-color: rgba(24, 168, 255, .42);
    box-shadow: 0 12px 30px var(--shadow);
    opacity: .45;
    transform: scale(.99);
}

.drag-ghost {
    position: fixed;
    z-index: 120;
    pointer-events: none;
    opacity: .78;
    transform: rotate(-1deg) scale(.98);
    box-shadow: 0 18px 44px var(--shadow);
}

.selected-exercise-row strong,
.selected-exercise-row span {
    display: block;
}

.selected-exercise-row span {
    margin-top: 3px;
    color: var(--muted);
    font-size: 12px;
}

.selected-exercise-actions {
    display: inline-grid;
    grid-template-columns: 1fr;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
}

.selected-exercise-actions button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 24px;
    width: 24px;
    height: 24px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-glass);
    color: var(--text);
    font-size: 12px;
    font-weight: 400;
    cursor: pointer;
}

.selected-exercise-actions .edit-exercise-button {
    padding: 0;
    color: var(--blue);
    font-size: 14px;
}

.selected-exercise-actions .remove-exercise-button {
    width: 24px;
    padding: 0;
    color: var(--danger);
    font-size: 13px;
}

input,
select,
textarea {
    width: 100%;
    min-height: 44px;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 11px 12px;
    background: var(--field-bg);
    color: var(--text);
    outline: 0;
}

.plan-modal #grupo_muscular {
    min-height: 46px;
    border-color: rgba(255, 85, 112, .34);
    border-radius: 14px;
    background:
        linear-gradient(135deg, rgba(255, 85, 112, .13), rgba(127, 16, 40, .08)),
        var(--field-bg);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
    color: var(--text);
    transition: border-color .16s ease, box-shadow .16s ease;
}

.plan-modal #grupo_muscular:hover,
.plan-modal #grupo_muscular:focus {
    border-color: rgba(255, 85, 112, .52);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .09),
        0 10px 22px rgba(255, 85, 112, .1);
}

.plan-modal #series_qtd,
.plan-modal #repeticoes_qtd,
.plan-modal #repeticoes_finais_qtd,
.plan-modal #carga_inicial,
.plan-modal #carga_final {
    border-color: #6b7280;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05);
}

.plan-modal #series_qtd:focus,
.plan-modal #repeticoes_qtd:focus,
.plan-modal #repeticoes_finais_qtd:focus,
.plan-modal #carga_inicial:focus,
.plan-modal #carga_final:focus {
    border-color: #8b95a5;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, .06),
        0 0 0 2px rgba(107, 114, 128, .18);
}

textarea {
    resize: vertical;
}

.submit-button {
    min-height: 48px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(145deg, var(--blue), #2a6cff);
    color: white;
    font-weight: 400;
    cursor: pointer;
}

.follow-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
}

.follow-button svg {
    flex: 0 0 auto;
}

.submit-button.danger {
    border: 1px solid rgba(255, 85, 112, .38);
    background: rgba(255, 85, 112, .12);
    color: var(--danger);
}

.submit-button.soft-danger {
    min-height: 38px;
    border: 1px solid color-mix(in srgb, var(--danger) 36%, transparent);
    background: color-mix(in srgb, var(--danger) 12%, transparent);
    color: var(--danger);
    font-size: .86rem;
    font-weight: 400;
}

.share-delete-form {
    margin-top: 12px;
}

.share-delete-form .submit-button {
    width: 100%;
}

.submit-button.warning {
    border: 1px solid rgba(246, 211, 101, .42);
    background: rgba(246, 211, 101, .14);
    color: var(--orange-light);
}

.login-page {
    min-height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 76px 16px 28px;
    background: var(--login-gradient);
    overflow-y: auto;
}

.login-shell {
    width: 100%;
    max-width: 420px;
    margin: clamp(18px, 12vh, 92px) auto 0;
}

.login-card {
    width: 100%;
    padding: 26px 22px 22px;
    border: 1px solid var(--line);
    border-radius: 24px;
    background: var(--panel);
    box-shadow: 0 26px 70px var(--shadow);
    overflow: hidden;
    position: relative;
}

.login-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 5px;
    background: linear-gradient(90deg, var(--blue), var(--green));
}

:root[data-theme="light"] .login-card {
    background: #ffffff;
}

.app-title-mark {
    display: inline-flex;
    align-items: center;
    gap: 7px;
}

.app-title-mark img {
    width: 26px;
    height: 26px;
    object-fit: contain;
}

.brand-gradient-text {
    display: inline-flex;
    gap: 4px;
}

.gym-gradient,
.planner-gradient {
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}

.gym-gradient {
    background-image: linear-gradient(90deg, #22c994, var(--green));
}

.planner-gradient {
    background-image: linear-gradient(90deg, var(--green), #8ff7d6);
}

.login-brand {
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
    margin-bottom: 24px;
}

.login-brand .eyebrow {
    font-size: 14px;
}

.login-mark {
    display: grid;
    place-items: center;
    width: 58px;
    height: 58px;
    border: 1px solid var(--line);
    border-radius: 18px;
    background: linear-gradient(145deg, var(--blue), #256dff);
    color: #fff;
    font-weight: 400;
    box-shadow: 0 16px 34px rgba(24, 168, 255, .22);
    overflow: hidden;
}

.login-mark img {
    width: 50px;
    height: 50px;
    object-fit: contain;
}

.login-brand h1 {
    margin-top: 5px;
    font-size: 28px;
    line-height: 1;
    font-weight: 800;
}

.login-brand p {
    margin-top: 8px;
    color: var(--muted);
    font-size: 14px;
    line-height: 1.45;
}

.login-form {
    display: grid;
    gap: 15px;
}

.login-form label,
.recovery-form label,
.register-form label {
    display: grid;
    gap: 8px;
    color: var(--muted);
    font-size: 13px;
    font-weight: 400;
}

.login-form input,
.recovery-form input,
.register-form input {
    min-height: 52px;
    border-radius: 15px;
    background: var(--field-bg);
    font-size: 16px;
}

.login-form .submit-button {
    margin-top: 4px;
    min-height: 54px;
    border-radius: 15px;
    font-size: 16px;
}

.submit-button.secondary {
    margin-top: 4px;
    min-height: 48px;
    border: 1px solid var(--line);
    background: var(--panel-2);
    color: var(--text);
}

#btnAdicionarExercicio {
    border-color: rgba(24, 168, 255, .38);
    box-shadow: 0 0 0 2px rgba(24, 168, 255, .08);
}

.login-links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: 14px;
}

.forgot-button {
    width: 100%;
    min-height: 42px;
    margin-top: 0;
    border: 0;
    background: transparent;
    color: var(--blue);
    font-weight: 400;
    cursor: pointer;
}

.recovery-form,
.register-form {
    display: grid;
    gap: 12px;
    margin-top: 10px;
    padding: 14px;
    border: 1px solid var(--line);
    border-radius: 16px;
    background: var(--surface-glass);
}

.recovery-form[hidden],
.register-form[hidden] {
    display: none;
}

.is-hidden {
    display: none;
}

@media (max-width: 680px) {
    .app-shell {
        padding-top: 30px;
        padding-bottom: 92px;
    }

    .programs-page .topbar,
    .academies-page .topbar,
    .report-page .topbar,
    .admin-page .topbar,
    .profile-page .topbar,
    .help-page .topbar {
        padding-top: 62px;
    }

    .topbar {
        align-items: end;
    }

    .programs-page h1 {
        font-size: 36px;
    }

    .side-menu {
        padding-bottom: calc(34px + env(safe-area-inset-bottom));
    }

    .topbar-actions {
        align-self: flex-start;
        gap: 7px;
    }

    .programs-page .topbar-actions {
        margin-top: 26px;
    }

    .new-users-fab {
        width: 48px;
        height: 48px;
        border-radius: 15px;
    }

    .new-user-card,
    .new-user-level-form {
        grid-template-columns: 1fr;
    }

    .user-chip {
        max-width: 118px;
        height: 44px;
        padding: 0 10px 0 7px;
        font-size: 12px;
    }

    .user-level-badge {
        top: calc(max(12px, env(safe-area-inset-top)) + 48px);
        right: calc(max(12px, env(safe-area-inset-right)) + 58px);
        min-width: 68px;
        max-width: 108px;
        font-size: 9px;
    }

    .icon-button {
        width: 42px;
        height: 42px;
        border-radius: 13px;
        font-size: 24px;
    }

    .modal-copy-plan-button {
        width: 30px;
        height: 30px;
        min-width: 30px;
        min-height: 30px;
        flex-basis: 30px;
        border-radius: 10px;
        font-size: 18px;
    }

    .topbar-actions .icon-button.primary {
        width: 44px;
        height: 44px;
        font-size: 26px;
    }

    .close-button {
        width: 28px;
        height: 28px;
        border-radius: 9px;
        font-size: 15px;
    }

    .folder-grid {
        grid-template-columns: 1fr;
    }

    .academy-card {
        grid-template-columns: 1fr;
    }

    .academy-actions {
        grid-template-columns: 1fr;
    }

    .academy-bulk-footer {
        justify-content: stretch;
    }

    .academy-bulk-button {
        width: 100%;
    }

    .help-guide {
        gap: 12px;
    }

    .help-intro,
    .help-demo,
    .help-steps li,
    .help-finish > div {
        padding: 16px;
    }

    .help-demo {
        grid-template-columns: 1fr;
    }

    .help-demo-app {
        min-height: 405px;
    }

    .help-demo-home,
    .help-demo-created-plan {
        inset: 12px;
    }

    .help-demo-form {
        grid-template-columns: 1fr;
        padding: 12px;
        animation-name: helpDemoFormScrollMobile;
    }

    .help-demo-builder {
        grid-template-columns: 1fr;
        padding: 9px;
    }

    .help-demo-cursor {
        width: 30px;
        height: 30px;
    }

    .help-demo-cursor::after {
        font-size: 30px;
    }

    .help-demo-field,
    .help-demo-selected span,
    .help-demo-stats span {
        min-height: 38px;
        font-size: 12px;
    }

    .help-demo-home-top strong {
        font-size: 21px;
    }

    .help-demo-modal,
    .help-demo-viewer {
        inset: 24px 12px 12px;
    }

    .help-demo-stats {
        grid-template-columns: 1fr;
    }

    .help-steps li {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 10px;
    }

    .help-step-number {
        width: 34px;
        height: 34px;
        border-radius: 12px;
    }

    .help-finish {
        grid-template-columns: 1fr;
    }

    .help-back-button {
        width: 100%;
        max-width: 100%;
    }

    .profile-card {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .profile-card .full,
    .profile-card .profile-wide {
        grid-column: 1 / -1;
    }

    .profile-avatar {
        grid-column: 1 / -1;
    }

    .report-editor {
        grid-template-columns: 1fr;
    }

    .report-card {
        grid-template-columns: 1fr;
    }

    .report-card .full {
        grid-column: auto;
    }

    .admin-item,
    .user-admin-item,
    .admin-user-fields {
        grid-template-columns: 1fr;
    }

    .admin-workspace {
        grid-template-columns: 1fr;
    }

    .sharing-overview,
    .sharing-columns,
    .sharing-item {
        grid-template-columns: 1fr;
    }

    .sharing-actions,
    .sharing-actions .submit-button {
        width: 100%;
    }

    .student-link-card {
        grid-template-columns: 1fr;
    }

    .user-credential-cards {
        grid-template-columns: 1fr;
    }

    .admin-toolbar {
        grid-template-columns: 1fr;
    }

    .admin-table-head {
        display: none;
    }

    .admin-row-list {
        max-height: none;
        min-height: 0;
    }

    .admin-list-row {
        grid-template-columns: 1fr;
        align-items: start;
        gap: 6px;
        min-height: 0;
    }

    .student-row {
        grid-template-columns: 42px minmax(0, 1fr);
    }

    .student-row > span:nth-child(n+3) {
        grid-column: 1 / -1;
    }

    .admin-list-row > span {
        overflow-wrap: anywhere;
    }

    .admin-detail-stack {
        position: static;
    }

    .user-detail-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .user-detail-form > label:not(.admin-user-nickname-field):not(.admin-user-birth-field):not(.admin-user-sex-field):not(.admin-user-weight-field):not(.admin-user-height-field):not(.user-level-field):not(.admin-user-phone-field),
    .user-detail-form .user-credential-cards,
    .user-detail-form .admin-meta,
    .user-detail-form button {
        grid-column: 1 / -1;
    }

    .user-detail-form .admin-user-nickname-field {
        grid-column: 1;
    }

    .user-detail-form .imc-card {
        grid-column: 1 / -1;
    }

    .user-detail-form .admin-user-birth-field,
    .user-detail-form .admin-user-weight-field {
        grid-column: 1;
    }

    .user-detail-form .admin-user-sex-field,
    .user-detail-form .admin-user-height-field,
    .user-detail-form .user-level-field {
        grid-column: 2;
    }

    .user-detail-form .admin-user-phone-field {
        grid-column: 1;
    }

    .gif-info-grid {
        grid-template-columns: 1fr;
    }

    .series-projection {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }

    .form-grid {
        grid-template-columns: 1fr;
    }

    .plan-modal .form-grid {
        grid-template-columns: repeat(12, minmax(0, 1fr));
    }

    .plan-modal .form-grid > label,
    .plan-modal .form-grid > .exercise-builder,
    .plan-modal .form-grid > .submit-button.full {
        grid-column: 1 / -1;
    }

    .plan-modal .form-grid > .plan-student-alias {
        grid-column: 1 / -1;
    }

    .series-edit-modal .form-grid {
        grid-template-columns: repeat(6, minmax(0, 1fr));
    }

    .exercise-swap-modal .form-grid {
        grid-template-columns: 1fr;
    }

    .exercise-swap-modal.is-picker-open .modal-panel {
        height: calc(100vh - 109px - max(18px, env(safe-area-inset-bottom)));
        max-height: calc(100vh - 109px - max(18px, env(safe-area-inset-bottom)));
    }

    .exercise-swap-modal.is-picker-open .exercise-swap-picker-list {
        max-height: min(420px, 48vh);
    }

    .exercise-swap-modal.is-picker-open .modal-panel > form > .submit-button {
        margin-top: auto;
        margin-bottom: -5px;
    }

    .builder-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .exercise-builder {
        grid-template-columns: 1fr;
    }

    .modal {
        align-items: end;
        padding: 0;
    }

    .plan-modal {
        align-items: flex-start;
        padding: 109px 0 max(18px, env(safe-area-inset-bottom));
    }

    .modal-panel {
        max-height: calc(100vh - 109px - max(18px, env(safe-area-inset-bottom)));
        border-radius: 22px 22px 0 0;
        padding-bottom: calc(28px + env(safe-area-inset-bottom));
        scroll-padding-bottom: calc(96px + env(safe-area-inset-bottom));
    }

    .plan-modal .modal-panel {
        max-height: calc(100vh - 109px - max(18px, env(safe-area-inset-bottom)));
        margin-top: 5px;
    }

    .plan-modal #btnSalvarPlano {
        margin-top: 22px;
        margin-bottom: 0;
    }

    @supports (height: 100svh) {
        .modal-panel,
        .plan-modal .modal-panel {
            max-height: calc(100svh - 109px - max(18px, env(safe-area-inset-bottom)));
        }
    }

    .login-shell {
        max-width: 100%;
    }

    .login-card {
        padding: 24px 18px 20px;
        border-radius: 22px;
    }

    .login-brand {
        grid-template-columns: 52px minmax(0, 1fr);
        gap: 12px;
    }

    .login-mark {
        width: 52px;
        height: 52px;
        border-radius: 16px;
    }

    .login-brand h1 {
        font-size: 28px;
    }
}
