/* .school settings */

.my-settings                  { display: flex; min-width: 800px; min-height: calc(100vh - 60px - 80px); }
.my-settings > .settings-side { width: 200px; border-right: 1px solid #e5e5e5; }

.my-settings > .settings-side .sticky                       { position: sticky; top: 60px; }
.my-settings > .settings-side .sticky > .title              { padding: 15px; font-size: 18px;  line-height: 30px; font-weight: bold; color: #282828; border-bottom: 1px solid transparent; }
.my-settings > .settings-side .sticky ul                    { margin: 0; padding: 0; }
.my-settings > .settings-side .sticky ul > li               { margin: 0; padding: 0; list-style-type: none; }
.my-settings > .settings-side .sticky ul > li           > a { display: block; padding: 0 15px; line-height: 35px; font-size: 14px; text-decoration: none; }
.my-settings > .settings-side .sticky ul > li           > a { background-color: transparent; color: #282828; }
.my-settings > .settings-side .sticky ul > li.selected  > a { background-color: #0044CD; color: #ffffff; }
.my-settings > .settings-side .sticky ul > li > ul > li > a { padding: 0 15px 0 25px; line-height: 24px; font-size: 12px; }


.settings-page                          { width: calc(100% - 200px); }
.settings-page > .title                 { padding: 15px; font-size: 18px; line-height: 30px; color: #282828; }
.settings-page > .title > .add-item     { float: right; font-size: 14px; line-height: 30px; }
.settings-page > .title                 { border-bottom: 1px solid #e5e5e5; }
.settings-page > .subtitle              { border-top: 1px solid #e5e5e5; border-bottom: none; }
.settings-page > .inner                 { padding: 15px; font-size: 0; }
.settings-page > .inner > form > button { margin: 20px 0 0 auto; }
.settings-page > .warning               { padding: 15px; font-size: 14px; text-align: left; color: #ef4949; font-weight: 600; }
.settings-page > .warning               { border-bottom: 1px solid #e5e5e5; }


/* school settings - subjects */

.settings-subjects > .inner > form > .list          { margin: 0 -10px; }
.settings-subjects > .inner > form > .list > *      { margin: 0 10px 20px; width: 200px; overflow: hidden; }
.settings-subjects > .inner > form > .list > *.hide { width: 0; }
.settings-subjects > .inner > form > .list > *      { display: inline-block; vertical-align: middle; }

.settings-subjects .classowl-input-frame > input          ~ .icon { color: #cccccc; cursor: pointer; }
.settings-subjects .classowl-input-frame > input:focus    ~ .icon { color: #ef4949; }
.settings-subjects .classowl-input-frame > input:disabled ~ .icon { color: #cccccc; cursor: default; }


/* school settings - transcripts */

.settings-transcripts          .transcripts-status                 { float: right; margin: 3px 0 0 20px; }
.settings-transcripts.disabled .transcripts-status .cikumas-switch { opacity: 0.5; cursor: default; }

.settings-transcripts .transcripts-mode              { display: inline-block; margin: 0 0 20px 0; width: calc(40%); }
.settings-transcripts .transcripts-mode label        { font-size: 12px; margin-bottom: 5px; line-height: 18px; }

.settings-transcripts .transcripts-date              { display: inline-block; margin: 0 0 20px 0; width: calc(40%); }
.settings-transcripts .transcripts-date label        { font-size: 12px; margin-bottom: 5px; line-height: 18px; }

.settings-transcripts .printed-grade                 { display: inline-block; margin: 0 0 20px 10px; width: calc(20% - 10px); }
.settings-transcripts .printed-grade label           { font-size: 12px; margin-bottom: 5px; line-height: 18px; }

.settings-transcripts .transcripts-template          { display: inline-block; margin: 0 0 20px 10px; width: calc(30% - 10px); }
.settings-transcripts .transcripts-template label    { font-size: 12px; margin-bottom: 5px; line-height: 18px; }
.settings-transcripts .transcripts-template          { padding-right: 0; }
.settings-transcripts .transcripts-template .preview { display: none; transform: translate(100%, 0); color: #228dcf; cursor: pointer; }

.settings-transcripts .transcripts-head > *   { display: inline-block; vertical-align: middle; }
.settings-transcripts .transcripts-head > *   { font-size: 12px; line-height: 18px; color: #1F3C77; padding: 10px 0; }
.settings-transcripts .transcripts-head > .c1 { width: calc(20% - 10px); margin-right: 10px; }
.settings-transcripts .transcripts-head > .c2 { width: calc(20% - 10px); margin-left: 10px; }
.settings-transcripts .transcripts-head > .c3 { width: calc(30% - 10px); margin-left: 10px; }

.settings-transcripts .transcripts-body > div                { margin-bottom: 20px; }
.settings-transcripts .transcripts-body > div > *            { display: inline-block; vertical-align: middle; margin-bottom: 0; }
.settings-transcripts .transcripts-body > div > .grade-level { font-size: 16px; width: calc(20% - 10px); margin-right: 10px; }

.settings-transcripts .inner.empty form             { display: none; }
.settings-transcripts .inner > .mappings-info       { font-style: italic; font-size: 14px; color: #999; text-align: left; margin-bottom: 20px; }

.settings-transcripts > .inner > form > .list          { margin: 0 -10px; }
.settings-transcripts > .inner > form > .list > *      { margin: 0 10px 20px; width: 200px; }
.settings-transcripts > .inner > form > .list > *.x2   { margin: 0 10px 20px; width: 420px; }
.settings-transcripts > .inner > form > .list > *.hide { width: 0; }
.settings-transcripts > .inner > form > .list > *      { display: inline-block; vertical-align: middle; }

.settings-transcripts .transcripts-mapping label    { font-size: 12px; margin-bottom: 5px; line-height: 18px; }
.settings-transcripts .transcripts-mapping textarea { line-height: normal; resize: none; font-size: 12px; }


/* .school settings - periods */

.settings-periods .block-year                                  { padding-bottom: 0; }
.settings-periods .block-year > .period-add                    { float: right;  font-size: 14px; line-height: 27px; }

.settings-periods .block-year .period-range                    { display: inline-block; vertical-align: middle; font-size: 14px; color: #ccc; }
.settings-periods .block-year .period-rename                   { display: inline-block; vertical-align: middle; }
.settings-periods .block-year .period-rename > .period-title   { display: inline-block; vertical-align: middle; font-size: 18px; line-height: 27px; color: #1f3c77; padding-left: 10px; }
.settings-periods .block-year .period-rename > .period-name          { display: inline-block; vertical-align: middle; width: 250px; }
.settings-periods .block-year .period-rename > .period-name > .input { font-size: 18px; color: #1f3c77; }
.settings-periods .block-year .period-rename > a               { display: inline-block; vertical-align: middle; font-size: 18px; }
.settings-periods .block-year .period-rename > a               { width: 36px; height: 36px; line-height: 36px; text-align: center; }
.settings-periods .block-year .period-rename > a.period-edit   { color: #228dcf; }
.settings-periods .block-year .period-rename > a.period-cancel { color: #ef4949; }
.settings-periods .block-year .period-rename > a.period-save   { color: #228dcf; }

.settings-periods .block-year .period-rename > .period-title   { display: inline-block; }
.settings-periods .block-year .period-rename > .period-name    { display: none; }
.settings-periods .block-year .period-rename > a.period-edit   { display: inline-block; }
.settings-periods .block-year .period-rename > a.period-cancel { display: none; }
.settings-periods .block-year .period-rename > a.period-save   { display: none; }

.settings-periods .block-year .period-rename.editing > .period-title   { display: none; }
.settings-periods .block-year .period-rename.editing > .period-name    { display: inline-block; }
.settings-periods .block-year .period-rename.editing > a.period-edit   { display: none; }
.settings-periods .block-year .period-rename.editing > a.period-cancel { display: inline-block; }
.settings-periods .block-year .period-rename.editing > a.period-save   { display: inline-block; }

.settings-periods .block-semester                                        { margin-top: 20px; }
.settings-periods .block-semester > .period-add                          { float: right; font-size: 14px; line-height: 27px; }

.settings-periods .block-semester .period-rename > .period-title         { font-size: 14px; }
.settings-periods .block-semester .period-rename > .period-name          { width: 150px; }
.settings-periods .block-semester .period-rename > .period-name > .input { font-size: 14px; }
.settings-periods .block-semester .period-rename > a                     { width: 30px; height: 30px; line-height: 30px; }

.settings-periods .block-semester > .items                               { margin: 10px -15px 0; }
.settings-periods .block-semester > .items > *:first-child               { border-top: 1px solid #ccc; }
.settings-periods .block-semester > .items > *                           { border-bottom: 1px solid #ccc; padding: 0 20px; }
.settings-periods .block-semester > .items > *:nth-child(2n+1)           { background-color: #f7f9fd; }

.settings-periods .block-quarter .period-modify > fieldset        { display: inline-block; vertical-align: middle; width: calc(100% - 36px - 36px); }
.settings-periods .block-quarter .period-modify > fieldset > *    { display: inline-block; vertical-align: middle; }
.settings-periods .block-quarter .period-modify .period-from      { width: 100px; }
.settings-periods .block-quarter .period-modify .period-till      { width: 100px; }
.settings-periods .block-quarter .period-modify .period-name      { width: calc(100% - 100px - 100px - 30px - 41px - 20px); }
.settings-periods .block-quarter .period-modify .period-name-title{ width: calc(100% - 100px - 100px - 30px - 41px - 20px); font-size: 14px; color: #1f3c77; padding: 0 10px; }
.settings-periods .block-quarter .period-modify .h-line           { font-size: 14px; margin: 0 10px; width: 10px; text-align: center; }
.settings-periods .block-quarter .period-modify .v-line           { height: 50px; width: 0; margin: 0 20px; }
.settings-periods .block-quarter .period-modify .v-line           { border-left: 1px solid #ccc; }
.settings-periods .block-quarter .period-modify .input.error      { border-color: #ef4949; background-color: rgb(239, 73, 73, 0.1); }

.settings-periods .block-quarter .period-modify .picker                { min-width: 300px; }
.settings-periods .block-quarter .period-modify .picker__select--year  { width: auto; padding: 0; }
.settings-periods .block-quarter .period-modify .picker__select--month { width: auto; padding: 0; }

.settings-periods .block-quarter .period-modify > a               { display: inline-block; vertical-align: middle; }
.settings-periods .block-quarter .period-modify > a               { width: 36px; height: 36px; text-align: center; line-height: 36px; font-size: 18px; }
.settings-periods .block-quarter .period-modify > a.period-edit   { color: #228dcf; }
.settings-periods .block-quarter .period-modify > a.period-delete { color: #ef4949; }
.settings-periods .block-quarter .period-modify > a.period-cancel { color: #ef4949; }
.settings-periods .block-quarter .period-modify > a.period-save   { color: #228dcf; }

.settings-periods .block-quarter .period-modify .period-name                   { display: none; }
.settings-periods .block-quarter .period-modify .period-name-title             { display: inline-block; }
.settings-periods .block-quarter .period-modify > a.period-edit                { display: inline-block; }
.settings-periods .block-quarter .period-modify > a.period-delete              { display: inline-block; }
.settings-periods .block-quarter .period-modify > a.period-cancel              { display: none; }
.settings-periods .block-quarter .period-modify > a.period-save                { display: none; }

.settings-periods .block-quarter .period-modify.editing .period-name           { display: inline-block; }
.settings-periods .block-quarter .period-modify.editing .period-name-title     { display: none; }
.settings-periods .block-quarter .period-modify.editing > a.period-edit        { display: none; }
.settings-periods .block-quarter .period-modify.editing > a.period-delete      { display: none; }
.settings-periods .block-quarter .period-modify.editing > a.period-cancel      { display: inline-block; }
.settings-periods .block-quarter .period-modify.editing > a.period-save        { display: inline-block; }


/* school settings - rubrics */

.modal-rubric-size form .dimensions        { margin-top: 60px; font-size: 0; }
.modal-rubric-size form .dimensions > *    { display: inline-block; vertical-align: middle; }
.modal-rubric-size form .dimensions > span { margin: 0 20px; width: 20px; text-align: center; font-size: 14px; }
.modal-rubric-size form .dimensions > .classowl-input-frame       { position: relative; width: calc(50% - 30px); }
.modal-rubric-size form .dimensions > .classowl-input-frame label { position: absolute; top: -24px; left: 0; line-height: 18px; font-size: 12px; color: #5c82b0; }


.settings-rubrics          .rubrics-status                 { float: right; margin: 3px 0 0 20px; }
.settings-rubrics.disabled .rubrics-status .cikumas-switch { opacity: 0.5; cursor: default; }

.settings-rubrics > .inner                          { border-bottom: 1px solid #e5e5e5; }
.settings-rubrics > .inner:last-child               { border-bottom: none; }
.settings-rubrics > .inner.none                     { color: #999; font-size: 14px; text-align: center; font-style: italic; }
.settings-rubrics > .inner > form > .ctrls > *                     { display: inline-block; vertical-align: middle; }
.settings-rubrics > .inner > form > .ctrls > .classowl-input-frame { margin-right: 20px; }
.settings-rubrics > .inner > form > .ctrls > .cikumas-switch       { margin: 6px 0; }
.settings-rubrics > .inner > form > .ctrls > button                { float: right; margin-left: 20px; }
.settings-rubrics > .inner > form > .ctrls > a                     { float: right; margin-left: 20px; }
.settings-rubrics > .inner > form .classowl-input-frame            { width: 170px; }

.settings-rubrics > .inner > form > .grid                   { position: relative; overflow: hidden; padding: 20px 0 10px; margin: 0 -6px; }
.settings-rubrics > .inner > form > .grid table             { border: none; border-collapse: collapse; }

.settings-rubrics > .inner > form > .grid thead td .title   { font-size: 14px; margin-bottom: 10px; padding-left: 5px; }
.settings-rubrics > .inner > form > .grid tbody td textarea { resize: none; font-size: 12px; line-height: 18px; height: 84px; }
.settings-rubrics > .inner > form > .grid thead th input    { text-align: center; }

.settings-rubrics > .inner > form > .grid th,
.settings-rubrics > .inner > form > .grid td                   { width: 170px; position: relative; vertical-align: top; padding: 6px; text-align: left; font-size: 0; font-weight: normal; }

.settings-rubrics > .inner > form > .grid th       a.ctrl-grid { opacity: 0; }
.settings-rubrics > .inner > form > .grid th:hover a.ctrl-grid { opacity: 1; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid          { height: 24px; padding: 0 5px; line-height: 24px; font-size: 0; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid.del      { color: #ef4949; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid > *      { display: inline-block; vertical-align: middle; font-size: 14px; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid > span   { margin-left: 5px; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid.swap     { width: 24px; padding: 0; text-align: center; color: #1f3c77; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid.swap     { position: absolute; right: 6px; bottom: 6px; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid.swap.l   { right: 30px; }
.settings-rubrics > .inner > form > .grid a.ctrl-grid.swap.u   { bottom: 30px; }
.settings-rubrics > .inner > form > .grid thead tr th:first-of-type:last-of-type:hover a.ctrl-grid.del    { opacity: 0.3; pointer-events: none; }
.settings-rubrics > .inner > form > .grid thead tr th:first-of-type:hover              a.ctrl-grid.swap.l { opacity: 0.3; pointer-events: none; }
.settings-rubrics > .inner > form > .grid thead tr th:last-of-type:hover               a.ctrl-grid.swap.r { opacity: 0.3; pointer-events: none; }
.settings-rubrics > .inner > form > .grid tbody tr:first-of-type:last-of-type th:hover a.ctrl-grid.del    { opacity: 0.3; pointer-events: none; }
.settings-rubrics > .inner > form > .grid tbody tr:first-of-type              th:hover a.ctrl-grid.swap.u { opacity: 0.3; pointer-events: none; }
.settings-rubrics > .inner > form > .grid tbody tr:last-of-type               th:hover a.ctrl-grid.swap.d { opacity: 0.3; pointer-events: none; }


/* school settings - ranges */

.settings-ranges > .title > .add-item { margin-top: -4px; }

.settings-ranges > .inner            { border-bottom: 1px solid #e5e5e5; }
.settings-ranges > .inner:last-child { border-bottom: none; }

.settings-ranges > .inner .ctrls > *                     { display: inline-block; vertical-align: middle; }
.settings-ranges > .inner .ctrls .classowl-input-frame   { margin-right: 20px; }
.settings-ranges > .inner .ctrls .cikumas-switch         { margin: 6px 0; }
.settings-ranges > .inner .ctrls .classowl-button        { float: right; margin-left: 20px; }
.settings-ranges > .inner .ctrls.disabled .classowl-input-frame { opacity: 0.5; pointer-events: none; }
.settings-ranges > .inner .ctrls.disabled .do-delete            { display: none; }
.settings-ranges > .inner .ctrls.disabled .do-save              { display: none; }

.settings-ranges > .inner .list                          { margin-top: 20px; }
.settings-ranges > .inner .list > .item > *              { display: inline-block; vertical-align: middle; }
.settings-ranges > .inner .list > .item > .icon-asg-type { width: 32px; height: 32px; border-radius: 3px; position: relative; }
.settings-ranges > .inner .list > .item > .value         { width: calc(100% - 172px); min-height: 55px; }
.settings-ranges > .inner .list > .item > .name          { width: 120px; font-size: 14px; color: #999; margin: 0 10px; }
.settings-ranges > .inner .list > .item > .mark          { width: 80px; margin: 0 14px; }
.settings-ranges > .inner .list > .item > .color         { width: 32px; height: 32px; }

.settings-ranges > .inner .list > .item > .icon           { position: relative; width: 32px; height: 32px; border-radius: 3px; }
.settings-ranges > .inner .list > .item > .icon > *       { position: absolute; right: 0; width: 24px; height: 24px; }
.settings-ranges > .inner .list > .item > .icon > *       { display: block; font-size: 18px; text-align: center; line-height: 24px; }
.settings-ranges > .inner .list > .item > .icon > .remove { color: #f36f47; top: 50%; transform: translate(0, -50%); }
.settings-ranges > .inner .list > .item > .icon > .insert { color: #228dcf; top: 100%; transform: translate(0, 0); }

.settings-ranges > .inner .list > .item:first-child > .icon > .remove { display: none; }
.settings-ranges > .inner .list > .item:last-child  > .icon > .remove { display: none; }
.settings-ranges > .inner .list > .item:last-child  > .icon > .insert { display: none; }

.settings-ranges > .inner fieldset:disabled > .list > .item > .icon > .remove { display: none; }
.settings-ranges > .inner fieldset:disabled > .list > .item > .icon > .insert { display: none; }


.settings-ranges > .inner .list > .item > .mark > *          { width: 100%; }
.settings-ranges > .inner .list > .item > .mark .input       { padding-right: 3px; line-height: 24px; border-radius: 3px; text-align: center; }
.settings-ranges > .inner .list > .item > .mark .input       { color: #999; border: 1px solid #e5e5e5; }
.settings-ranges > .inner .list > .item > .mark .input:focus { color: #282828; border: 1px solid #999; }
.settings-ranges > .inner .list > .item > .color input       { display: block; width: 100%; height: 100%; border: none; cursor: pointer; padding-inline-end: 0; padding-inline-start: 0; }


/* school settings - weightings */

.settings-weightings > .title > .add-item { margin-top: -4px; }

.settings-weightings > .inner            { border-bottom: 1px solid #e5e5e5; }
.settings-weightings > .inner:last-child { border-bottom: none; }
.settings-weightings > .inner.none       { color: #999; font-size: 14px; text-align: center; font-style: italic; }

.settings-weightings > .inner .ctrls > *                     { display: inline-block; vertical-align: middle; }
.settings-weightings > .inner .ctrls .classowl-input-frame   { margin-right: 20px; }
.settings-weightings > .inner .ctrls .cikumas-switch         { margin: 6px 0; }
.settings-weightings > .inner .ctrls .classowl-button        { float: right; margin-left: 20px; }
.settings-weightings > .inner .ctrls.disabled .classowl-input-frame { opacity: 0.5; pointer-events: none; }
.settings-weightings > .inner .ctrls.disabled .do-delete            { display: none; }
.settings-weightings > .inner .ctrls.disabled .do-save              { display: none; }

.settings-weightings > .inner .list                          { margin-top: 20px; }
.settings-weightings > .inner .list > .item > *              { display: inline-block; vertical-align: middle; }
.settings-weightings > .inner .list > .item > .icon-asg-type { width: 32px; height: 32px; border-radius: 3px; position: relative; }
.settings-weightings > .inner .list > .item > .value         { width: calc(100% - 172px); min-height: 55px; }
.settings-weightings > .inner .list > .item > .name          { width: 120px; font-size: 14px; color: #999; margin: 0 10px; }
.settings-weightings > .inner .list > .item > .name .percent { font-size: 12px; }


/* school settings - profile */

.settings-profile > .inner > form           { max-width: 400px; }
.settings-profile > .inner .form-inputs > * { margin-top: 30px; }

.settings-profile > .inner .user-name     { display: flex; justify-content: space-between; }
.settings-profile > .inner .user-name > * { width: calc(50% - 10px); }

.settings-profile > .inner .user-birthday                    { display: flex; justify-content: space-between; }
.settings-profile > .inner .user-birthday > *:nth-of-type(1) { width: calc(30% - 10px); }
.settings-profile > .inner .user-birthday > *:nth-of-type(2) { width: calc(40% - 20px); }
.settings-profile > .inner .user-birthday > *:nth-of-type(3) { width: calc(30% - 10px); }

.settings-profile > .inner .user-pass     { display: flex; justify-content: space-between; }
.settings-profile > .inner .user-pass > * { width: calc(50% - 10px); }

.settings-profile > .inner .share-contacts         { display: none; }
.settings-profile > .inner .share-contacts.teacher { display: block; }


/* school settings - privacy */

.settings-privacy > .inner > form           { max-width: 400px; }
.settings-privacy > .inner .privacy-hint    { font-size: 14px; color: #1F3C77; margin: 0 0 20px 0; }

.settings-privacy > .inner .user-group      { border-bottom: 1px solid #ccc; }
.settings-privacy > .inner .user-group > *  { margin: 10px 0; }

.settings-privacy > .inner .user-item             { display: flex; align-items: center; margin-top: 10px; }
.settings-privacy > .inner .user-item .user-photo { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; }
.settings-privacy > .inner .user-item .user-name  { margin-left: 10px; color: #1F3C77; font-weight: bold; font-size: 14px; }


/* school settings - school */

.settings-school > .inner > form           { max-width: 400px; }
.settings-school > .inner .form-inputs > * { margin-top: 30px; }
.settings-school > .inner .form-inputs > .cikumas-switch { margin-top: 10px; }

.settings-school > .inner .school-code     { height: 36px; line-height: 36px; font-size: 24px; color: #282828; }

.settings-school > .inner .classowl-photo                         { display: inline-block; vertical-align: bottom; margin-right: 10px; margin-top: 10px; }
.settings-school > .inner .classowl-photo + .classowl-input-frame { display: inline-block; vertical-align: bottom; width: calc(100% - 60px - 10px); }
.settings-school > .inner .classowl-photo + .classowl-input-frame { margin-bottom: 7px; }
.settings-school > .inner .classowl-photo.empty > .select         { opacity: 1; }


/* school settings - other */
/* used as generic page of this type: other, dashboard */

.settings-other > .inner > form                         { max-width: 400px; }
.settings-other > .inner fieldset                       { margin-bottom: 20px; }
.settings-other > .inner fieldset > legend              { margin-bottom: 10px; font-size: 16px; font-weight: 600; color: #282828; }
.settings-other > .inner .form-inputs > .cikumas-switch { margin: 10px 0; }
.settings-other > .inner .title-value                   { margin: 10px 0; display: flex; align-items: center; justify-content: space-between; }
.settings-other > .inner .title-value > *               { max-width: 50%; }
.settings-other > .inner .title-value > .title          { font-size: 14px; color: #282828; }


/* school settings - payment */

.settings-payment > .inner > form                        { max-width: 400px; }

.settings-payment > .inner .user-card > *                { margin-top: 30px; display: inline-block; }
.settings-payment > .inner .user-card > * > input        { font-size: 18px; }
.settings-payment > .inner .user-card > *:nth-of-type(1) { width: 100%; }
.settings-payment > .inner .user-card > *:nth-of-type(2) { width: 80px; margin-right: 10px; }
.settings-payment > .inner .user-card > *:nth-of-type(3) { width: 100px; margin-right: 10px; }
.settings-payment > .inner .user-card > *:nth-of-type(4) { width: 80px; margin-left: calc(100% - 260px - 20px); }

.settings-payment > .inner > form            button { margin: 20px 0 0 auto; }
.settings-payment > .inner > .payment-cancel button { width: auto; min-width: 220px; }


.settings-payment > .inner > .payment-cards             { margin-top: -30px; }
.settings-payment > .inner > .payment-cards ul          { margin: 0; padding: 0; }
.settings-payment > .inner > .payment-cards ul > li     { margin: 0; padding: 0; list-style-type: none; padding: 5px 0; }
.settings-payment > .inner > .payment-cards ul > li > * { display: inline-block; vertical-align: middle; }

.settings-payment > .inner > .payment-cards ul > li         > .card-number { width: calc(100% - 100px); line-height: 27px; font-size: 18px; color: #282828; }
.settings-payment > .inner > .payment-cards ul > li.default > .card-number { font-weight: bold; }
.settings-payment > .inner > .payment-cards ul > li.expired > .card-number { color: #ef4949; }

.settings-payment > .inner > .payment-cards ul > li         > a            { margin-left: 20px; width: 25px; height: 25px; text-align: center; text-decoration: none; }
.settings-payment > .inner > .payment-cards ul > li         > a > i        { display: inline-block; line-height: 27px; font-size: 18px; }
.settings-payment > .inner > .payment-cards ul > li:first-child:last-child > a { pointer-events: none; color: #999; }

.settings-payment > .inner > .payment-cards ul > li         > a > i.on     { display: none; }
.settings-payment > .inner > .payment-cards ul > li         > a > i.off    { display: block; }
.settings-payment > .inner > .payment-cards ul > li.default > a > i.on     { display: block; }
.settings-payment > .inner > .payment-cards ul > li.default > a > i.off    { display: none; }

.settings-payment > .inner > .message { color: #999; font-size: 14px; text-align: center; font-style: italic; }


/* school settings - integrations */

.settings-integrations > .inner > form            { margin-bottom: 20px; }

.settings-integrations > .inner > form button     { margin: 0; padding: 0 10px; width: 320px; text-align: left; font-size: 0; }
.settings-integrations > .inner > form button > * { display: inline-block; vertical-align: middle; line-height: 21px; font-size: 14px; }
.settings-integrations > .inner > form button > i { width: 15px; height: 15px; margin-right: 10px; }
.settings-integrations > .inner > form button > i { background: no-repeat center center; background-size: contain; }
.settings-integrations > .inner > form.form-google    button > i { background-image: url('/static/img/google-account.png'); }
.settings-integrations > .inner > form.form-calendar  button > i { background-image: url('/static/img/google-calendar.png'); }
.settings-integrations > .inner > form.form-classroom button > i { background-image: url('/static/img/google-classroom.png'); }
.settings-integrations > .inner > form.form-microsoft button > i { background-image: url('/static/img/microsoft-logo.png'); }

.settings-integrations > .inner > form > *      { display: inline-block; vertical-align: middle; }
.settings-integrations > .inner > form > .hint  { margin-left: 20px; width: calc(100% - 320px - 20px - 20px); max-width: 500px; font-size: 14px; color: #0044CD; }


/* school settings - subjects */

.settings-asgtypes > .inner > form > .list          { margin: 0 -10px; }
.settings-asgtypes > .inner > form > .list > *      { margin: 0 10px 20px; width: 300px; overflow: hidden; }
.settings-asgtypes > .inner > form > .list > *.hide { width: 0; }
.settings-asgtypes > .inner > form > .list > *      { display: inline-block; vertical-align: middle; }

.settings-asgtypes .classowl-input-frame > input          ~ .icon { color: #cccccc; cursor: pointer; }
.settings-asgtypes .classowl-input-frame > input:focus    ~ .icon { color: #ef4949; }
.settings-asgtypes .classowl-input-frame > input:disabled ~ .icon { color: #cccccc; cursor: default; }


/* school settings - signin as */

.settings-signin-as > .inner > form           { max-width: 400px; }
.settings-signin-as > .inner .form-inputs > * { margin-top: 30px; }


/* school settings - feedbacks */

.settings-feedbacks .list td.overlap { color: #ef4949; }


/* school settings - barometer */

.settings-barometer   .list       { overflow: auto; scrollbar-width: thin; }
.settings-barometer   .list table { width: auto; }
.settings-barometer   .list th,
.settings-barometer   .list td    { font-size: 14px; padding: 5px 20px; border-bottom: 1px solid #ccc; }
.settings-barometer   .list th    { text-align: left; }
.settings-barometer   .list th.c  { text-align: center; }
.settings-barometer   .list td.c  { text-align: center; }
.settings-barometer   .list td    { white-space: nowrap; }
.settings-barometer   .list td .sub    { font-size: 12px; color: #999; }

.settings-barometer   .list tr:nth-child(2n+1) td { background-color: #f7f9fd; }

.settings-barometer   .classowl-input-frame     { width: 100px; }

.settings-barometer   form                      { display: inline-block; overflow: auto; max-width: 100%; }
.settings-barometer   .ctrls                    { display: flex; justify-content: flex-end; margin: 20px; }
.settings-barometer   .ctrls button             { margin-left: 10px; }


/* school settings - secondary accounts */

.settings-secondary-accounts > .inner > form           { max-width: 400px; }
.settings-secondary-accounts > .inner .form-inputs > * { margin-top: 30px; }

.settings-secondary-accounts   .list          { overflow: auto; scrollbar-width: thin; }
.settings-secondary-accounts   .list table    { width: 100%; }
.settings-secondary-accounts   .list th,
.settings-secondary-accounts   .list td       { font-size: 14px; padding: 5px 20px; border-bottom: 1px solid #ccc; }
.settings-secondary-accounts   .list th       { text-align: left; }
.settings-secondary-accounts   .list td       { white-space: nowrap; }
.settings-secondary-accounts   .list td .user { display: flex; align-items: center; }
.settings-secondary-accounts   .list td .user >.photo { margin-right: 10px; width: 30px; height: 30px; border-radius: 50%; display: block; }
.settings-secondary-accounts   .list td .sub  { font-size: 12px; color: #999; }

.settings-secondary-accounts   .list tr:nth-child(2n+1) td { background-color: #f7f9fd; }

.settings-secondary-accounts   .list .ctrls                        { display: flex; justify-content: flex-end; }
.settings-secondary-accounts   .list .ctrls form                   { margin-left: 10px; }
.settings-secondary-accounts   .list .ctrls form > button          { display: block; background-color: transparent; border: none; cursor: pointer; }
.settings-secondary-accounts   .list .ctrls form > button          { font-size: 18px; width: 30px; height: 30px; text-align: center; line-height: 30px; }
.settings-secondary-accounts   .list .ctrls form > button.ctrl-del { color: #ef4949; }


/* school settings - competences */

.settings-competences   form        { overflow-x: auto; padding-bottom: 80px; }
.settings-competences   .list table { width: auto; }
.settings-competences   .list th,
.settings-competences   .list td    { font-size: 14px; padding: 5px 20px; border-bottom: 1px solid #ccc; }
.settings-competences   .list th    { text-align: left; }
.settings-competences   .list td    { white-space: nowrap; }

.settings-competences   .list tr:nth-child(2n+1) td { background-color: #f7f9fd; }

.settings-competences   .classowl-input-frame     { width: 200px; }

.settings-competences   form                      { display: inline-block; max-width: 100%; }
.settings-competences   .ctrls                    { display: flex; justify-content: flex-end; margin: 20px; }
.settings-competences   .ctrls button             { margin-left: 10px; }


/* school settings - finances */

.settings-finances > .inner > form                         { max-width: 400px; }
.settings-finances > .inner fieldset                       { margin-bottom: 20px; }
.settings-finances > .inner fieldset > legend              { margin-bottom: 10px; font-size: 16px; font-weight: 600; color: #282828; }
.settings-finances > .inner .form-inputs > .cikumas-switch { margin: 10px 0; }
.settings-finances > .inner .title-value                   { margin: 10px 0; display: flex; align-items: center; justify-content: space-between; }
.settings-finances > .inner .title-value > .title          { font-size: 14px; color: #282828; }
.settings-finances > .inner .title-value > .classowl-input-frame { width: 70%; }

/* school settings - drive */

.settings-drive > .inner > form                         { max-width: 400px; }
.settings-drive > .inner fieldset                       { margin-bottom: 20px; }
.settings-drive > .inner fieldset > legend              { margin-bottom: 10px; font-size: 16px; font-weight: 600; color: #282828; }
.settings-drive > .inner .form-inputs > .cikumas-switch { margin: 10px 0; }
.settings-drive > .inner .title-value                   { margin: 10px 0; display: flex; align-items: center; justify-content: space-between; }
.settings-drive > .inner .title-value > *               { max-width: 50%; }
.settings-drive > .inner .title-value > .title          { font-size: 14px; color: #282828; }

/* school settings - onboarding */

.settings-onboarding > .inner > form                         { max-width: 100%; }
.settings-onboarding > .inner fieldset                       { margin-bottom: 20px; }
.settings-onboarding > .inner fieldset > legend              { margin-bottom: 10px; font-size: 16px; font-weight: 600; color: #282828; }
.settings-onboarding > .inner .form-inputs > .cikumas-switch { margin: 10px 0; }

.settings-onboarding > .inner .title-value                   { margin: 10px 0; display: flex; align-items: center; justify-content: space-between; }
.settings-onboarding > .inner .title-value > *               { max-width: 50%; }
.settings-onboarding > .inner .title-value > .title          { font-size: 14px; color: #282828; }

.settings-onboarding > .inner .rich-text                   { margin: 10px 0; }
.settings-onboarding > .inner .rich-text > *               { max-width: 100%; }
.settings-onboarding > .inner .rich-text > .title          { font-size: 14px; color: #282828; }
.settings-onboarding > .inner .rich-text > textarea        { width: 100%; }


/* school settings - flex */

.settings-flex > .inner > form                         { max-width: 400px; }
.settings-flex > .inner fieldset                       { margin-bottom: 20px; }
.settings-flex > .inner fieldset > legend              { margin-bottom: 10px; font-size: 16px; font-weight: 600; color: #282828; }
.settings-flex > .inner .form-inputs > .cikumas-switch { margin: 10px 0; }
.settings-flex > .inner .title-value                   { margin: 10px 0; display: flex; align-items: center; justify-content: space-between; }
.settings-flex > .inner .title-value > .title          { font-size: 14px; color: #282828; }
.settings-flex > .inner .title-value > .classowl-input-frame { width: 70%; }
.settings-flex > .inner .title-value > .classowl-multiselect { width: 70%; }


/* settings list with archived */

.settings-list             > .title { display: flex; align-items: center; justify-content: space-between; }
.settings-list > .archived > .title { display: flex; align-items: center; justify-content: space-between; }

.settings-list .list       { overflow: auto; scrollbar-width: thin; }
.settings-list .list table { width: 100%; }
.settings-list .list th,
.settings-list .list td    { font-size: 14px; padding: 5px 20px; border-bottom: 1px solid #ccc; }
.settings-list .list th    { text-align: left; }
.settings-list .list td    { white-space: nowrap; }
.settings-list .list td .title { font-size: 14px; color: #282828; }
.settings-list .list td .descr { font-size: 12px; color: #999; }

.settings-list .list tr:nth-child(2n+1) td { background-color: #f7f9fd; }

.settings-list .list .ctrls                    { display: flex; justify-content: flex-end; }
/*.settings-list .list .ctrls form               { margin-left: 10px; }*/
.settings-list .list .ctrls form > .icon       { border: none; background-color: transparent; cursor: pointer; padding: 0; color: #228dcf; }
.settings-list .list .ctrls form > .icon       { display: block; font-size: 18px; width: 30px; height: 30px; text-align: center; line-height: 30px; }
.settings-list .list .ctrls form > a           { display: block; font-size: 18px; width: 30px; height: 30px; text-align: center; line-height: 30px; }
.settings-list .list .ctrls form > .ctrl-edit  { color: #228dcf; }
.settings-list .list .ctrls form > .ctrl-del   { color: #ef4949; }

.settings-list .archived                  { padding-top: 20px; }
.settings-list .archived > .title         { display: flex; align-items: center; justify-content: space-between; }
.settings-list .archived > .title         { cursor: pointer; color: #888; padding: 5px 15px; font-size: 14px; line-height: 30px; border-bottom: 1px solid #e5e5e5; }

.settings-list .archived > .title:hover            { background-color: #eee; }
.settings-list .archived > .title          + .list { display: none; }
.settings-list .archived > .title.expanded + .list { display: block; }
.settings-list .archived > .title.expanded > .icon { transform: rotate(180deg); }


/* export settings */

.settings-export > .inner > form                         { max-width: 400px; }
.settings-export > .inner fieldset                       { margin-bottom: 20px; }
.settings-export > .inner fieldset > legend              { margin-bottom: 10px; font-size: 16px; font-weight: 600; color: #282828; }
.settings-export > .inner .form-inputs > .cikumas-switch { margin: 10px 0; }
.settings-export > .inner .title-value                   { margin: 10px 0; display: flex; align-items: center; justify-content: space-between; }
.settings-export > .inner .title-value > *               { max-width: 50%; }
.settings-export > .inner .title-value > .title          { font-size: 14px; color: #282828; }

.settings-export-items .items-list-buttons { display: flex; }
.settings-export-items .items-list-buttons button { margin-left: 10px; }
.settings-export-items .last-upload-timestamp {font-size: 10px; text-align: center; line-height: 18px;}
.settings-export-items .filter-title { display: flex; justify-content: left; align-items:  center; }
.settings-export-items .filter-title > .ctrls > form > .icon {font-size: 15px;}
.settings-export-items .filter-delimiter { margin: 12px 0 5px; font-size: 12px; }
.settings-export-items .filter-delimiter > span { color: #282828; background-color: #f8f8f8; border: 1px solid #e5e5e5; border-radius: 3px; padding: 0 2px;}


.export-item-filter .filter           { display: flex; align-items: center; }
.export-item-filter .filter > .search { flex-grow: 1; flex-shrink: 1; }

.export-item-filter .list       { max-height: 300px; overflow: auto; margin-top: 10px; border: 1px solid #e5e5e5; }

.export-item-filter .list table { width: 100%; border-collapse: collapse; border: none; }
.export-item-filter .list thead { position: sticky; top: 0; z-index: 2; }
.export-item-filter .list tr.hide { display: none; }
.export-item-filter .list th    { font-size: 14px; padding: 2px 5px; background-color: #e5e5e5; color: #282828; font-weight: 400; }
.export-item-filter .list td    { font-size: 14px; padding: 2px 5px; color: #657FAC; border-bottom: 1px solid #e5e5e5; }
.export-item-filter .list .l    { text-align: left; }
.export-item-filter .list .c    { text-align: center; }

.export-item-filter .list .classowl-checkbox { max-width: 20px; margin: 0 auto; }

.export-item-filter .user-card                             { border: none; background-color: inherit; text-align: left; cursor: pointer; }
.export-item-filter .user-card                             { display: flex; align-items: center; }
.export-item-filter .user-card > .user-photo               { flex-grow: 0; flex-shrink: 0; width: 27px; height: 27px; border-radius: 50%; background: no-repeat center; background-size: cover; }
.export-item-filter .user-card > .user-info                { flex-grow: 1; flex-shrink: 1; margin: 0 8px; text-align: left; }
.export-item-filter .user-card > .user-info > .user-name   { font-size: 14px; color: #657FAC; }
.export-item-filter .user-card > .user-info > .user-status { font-size: 12px; color: #999; }

.export-item-filter .sel-options                    { display: flex; align-items: center; }
.export-item-filter .sel-options                    { font-size: 14px; line-height: 24px; }
.export-item-filter .sel-options > .ctrl-icon       { width: 24px; height: 24px; cursor: pointer; }
.export-item-filter .sel-options > .ctrl-icon       { color: #228dcf; font-size: 16px; text-align: center; line-height: 24px; }
.export-item-filter .sel-options > .ctrl-icon:hover { color: #228dcf; }

.export-item-filter .form-ctrls { display: flex; }

.export-item-filter .selected-count        { font-weight: 600; }
.export-item-filter .selected-count:before { content: '('; font-weight: 400; }
.export-item-filter .selected-count:after  { content: ')'; font-weight: 400; }
.export-item-filter .selected-count:empty  { display: none; }

.settings-export > .export-endpoint  .form-inputs > .classowl-input-frame { margin-top: 30px; }
