/* classowl button */

.classowl-button       { display: block; cursor: pointer; width: 130px; padding: 0 10px; border-radius: 5px; }
.classowl-button       { font-size: 14px; line-height: 32px; text-align: center; text-decoration: none; }
.classowl-button       { box-sizing: border-box; user-select: none; }
.classowl-button       { position: relative; border: none; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; }
.classowl-button:hover { text-decoration: none; }

.classowl-button.icon32  { width: 32px; height: 32px; padding: 0; line-height: 30px; }

.classowl-button.green    { color: #fff; background-color: #10B163; border: 1px solid #E4E5E7;  box-shadow: 0 8px 15px 0 rgba(16,177,99,0.5); }
.classowl-button.green-ns { color: #fff; background-color: #10B163; }
.classowl-button.blue     { color: #fff; background-color: #3080EB; box-shadow: 0 8px 15px 0 rgba(48,128,235,0.5); }
.classowl-button.blue-ns  { color: #fff; background-color: #3080EB; }
.classowl-button.blue2    { color: #fff; background-color: #657FAC; box-shadow: 0 8px 15px 0 rgba(101,127,172,0.5); }
.classowl-button.blue2-ns { color: #fff; background-color: #657FAC; }
.classowl-button.blue3    { color: #fff; background-color: #1f3c77; box-shadow: 0 8px 15px 0 rgba(101,127,172,0.5); }
.classowl-button.navy     { color: #fff; background-color: #0044CD; box-shadow: 0 8px 15px 0 rgba(0,68,205,0.5); }
.classowl-button.red      { color: #fff; background-color: #FF5D40; box-shadow: 0 8px 15px 0 rgba(255,93,64,0.5); }
.classowl-button.red-ns   { color: #fff; background-color: #FF5D40; }
.classowl-button.red2-ns  { color: #fff; background-color: #F83C3C; }
.classowl-button.glass       { color: #657FAC; background-color: transparent; border: 1px solid #E4E5E7; }
.classowl-button.glass-blue  { color: #657FAC; background-color: transparent; border: 1px solid #657FAC; }
.classowl-button.glass-blue2 { color: #0044CD; background-color: transparent; border: 1px solid #0044CD; }
.classowl-button.glass-red   { color: #657FAC; background-color: transparent; border: 1px solid #F83C3C; }
.classowl-button.glass-green { color: #10B163; background-color: transparent; border: 1px solid #10B163; }
.classowl-button.white       { color: #657FAC; background-color: #fff; border: 1px solid #E4E5E7; }
.classowl-button.link        { color: #657FAC; background-color: #fff; border: none; }
.classowl-button.link2       { color: #657FAC; background-color: transparent; border: none; }

.classowl-button.icon-green  { color: #10B163; background-color: transparent; }
.classowl-button.icon-blue   { color: #228dcf; background-color: transparent; }
.classowl-button.icon-blue2  { color: #657FAC; background-color: transparent; }
.classowl-button.icon-blue3  { color: #1f3c77; background-color: transparent; }
.classowl-button.icon-red    { color: #FF5D40; background-color: transparent; }
.classowl-button.icon-red2   { color: #F83C3C; background-color: transparent; }
.classowl-button.icon-yellow { color: #f8b33c; background-color: transparent; }
.classowl-button.icon-gray   { color: #cccccc; background-color: transparent; }

.classowl-button:active::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; right: 0; background-color: #000; opacity: 0.05; }
.classowl-button:disabled       { pointer-events: none; opacity: 0.5; /*color: #000; background-color: #999; box-shadow: 0 8px 15px 0 rgba(0,0,0,0.3);*/ filter: grayscale(1); }

.classowl-button.blue-ns:disabled     { box-shadow: none; }
.classowl-button.green-ns:disabled    { box-shadow: none; }
.classowl-button.red-ns:disabled      { box-shadow: none; }
.classowl-button.glass-green:disabled { box-shadow: none; }


.classowl-button.progress         { background-color: #999; }
.classowl-button.progress > .bar  { position: absolute; left: 0; top: 0; bottom: 0; width: 0; }
.classowl-button.progress > .text { position: relative; z-index: 2; }
.classowl-button.progress:disabled > .bar { display: none; }

.classowl-button.green.progress > .bar  { background-color: #10B163; }
.classowl-button.navy.progress  > .bar  { background-color: #3080EB; }



/* classowl input frame */

.classowl-input-frame                { position: relative; }
.classowl-input-frame > .input       { border: 1px solid #e5e5e5; border-radius: 3px; padding: 2px 9px; font-size: 14px; line-height: 30px; width: 100%; }
.classowl-input-frame > .input:focus { border-color: #228dcf; }

.classowl-input-frame > .icon                 { display: none; position: absolute; top: 0; width: 20px; line-height: 36px; font-size: 18px; cursor: default; }
.classowl-input-frame > .icon                 { background-color: transparent; border: none; }
.classowl-input-frame > .icon                 { text-align: center; text-decoration: none; color: #999; }
.classowl-input-frame > .input:focus ~ .icon  { color: #228dcf; }
.classowl-input-frame > .input:read-only      { cursor: default; }
.classowl-input-frame > .input:disabled         { pointer-events: none; background-color: #f8f8f8; }
.classowl-input-frame > .input:disabled ~ .icon { pointer-events: none; color: #999; }

.classowl-input-frame.icon-right > .input  { padding-right: 20px; }
.classowl-input-frame.icon-right > .icon   { display: block; right: 0; left: auto; }
.classowl-input-frame.icon-left  > .input  { padding-left: 20px;  }
.classowl-input-frame.icon-left  > .icon   { display: block; left: 0; right: auto; }

.classowl-input-frame.icon-right.icon-wide > .input { padding-right: 36px; }
.classowl-input-frame.icon-left.icon-wide  > .input { padding-left: 36px; }
.classowl-input-frame.icon-wide  > .icon            { width: 36px; }

.classowl-input-frame.images-left > .input { padding-left: 36px; }
.classowl-input-frame.images-left > .image { width: 24px; height: 24px; border-radius: 50%; background: no-repeat center center; background-size: cover; }
.classowl-input-frame.images-left > .image { position: absolute; z-index: 2; transform: translate(0, -50%); left: 6px; top: 50%; border: 1px solid #fff; background-color: #eee; }

.classowl-input-frame.required > .input { background-color: #ffffee; }

.classowl-input-frame.labeled              { margin-top: 20px; }
.classowl-input-frame > label              { font-size: 12px; line-height: 18px; position: absolute; left: 0; top: -22px; max-width: 100%; color: #657FAC; }
.classowl-input-frame > label:empty        { display: none; }

.classowl-input-frame         > .input-loading { position: absolute; z-index: 2; width: 36px; top: 0; right: 0; bottom: 0; }
.classowl-input-frame         > .input-loading { display: none; align-items: center; justify-content: center; }
.classowl-input-frame.loading > .input-loading { display: flex; }

.classowl-input-frame.drop-left > .picker      { left: initial; right: 0; }

/* classowl input phone */

.classowl-input-phone                         { position: relative; }
.classowl-input-phone > .input                { border: 1px solid #e5e5e5; border-radius: 3px; padding: 2px 9px; font-size: 14px; line-height: 30px; width: 100%; }
.classowl-input-phone > .input:focus          { border-color: #228dcf; }
.classowl-input-phone .iti                    { display: block; }
.classowl-input-phone .iti__tel-input         { border: 1px solid #e5e5e5; border-radius: 3px; padding: 2px 9px; font-size: 14px; line-height: 30px; width: 100%; }
.classowl-input-phone .iti__tel-input:focus   { border-color: #228dcf; }
.classowl-input-phone .iti__country-container { font-size: 14px; }
.classowl-input-phone .iti__dropdown-content  { font-size: 12px; min-width: 220px; }
.classowl-input-phone .iti__search-input      { padding: 10px; border: none !important; }


/* student-profile */

fieldset.disabled .classowl-input-phone { pointer-events: none; } 


/* classowl user photo selector */

.classowl-photo                    { display: inline-block; position: relative; overflow: hidden; }
.classowl-photo                    { user-select: none; -ms-user-select: none; -moz-user-select: none; -webkit-user-select: none; }
.classowl-photo                    { width: 58px; height: 58px; border: 1px solid #e5e5e5; border-radius: 50%; }
.classowl-photo                    { background: no-repeat center center; background-size: cover; }
.classowl-photo input[type='file'] { display: none; }

.classowl-photo       > *        { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); cursor: pointer; }
.classowl-photo       > *        { width: calc(100% - 2px); height: calc(100% - 2px); border: 2px solid #fff; }
.classowl-photo       > *        { padding: 0 !important; margin: 0 !important; border-radius: 50%; }
.classowl-photo       > *:before { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); }
.classowl-photo       > *:before { color: #fff; font-size: 36px; font-weight: 400; }
.classowl-photo       > .clear:before  { content: '×'; }
.classowl-photo       > .clear         { background-color: rgba(239,73,73,0.78); }
.classowl-photo       > .select:before { content: '+'; }
.classowl-photo       > .select        { background-color: rgba(31,60,119,0.78); }

.classowl-photo       > * { opacity: 0; }
.classowl-photo:hover > * { opacity: 1; }

.classowl-photo       > .clear  { display: block; }
.classowl-photo       > .select { display: none;  }
.classowl-photo.empty > .clear  { display: none;  }
.classowl-photo.empty > .select { display: block; }

.classowl-photo.small            { width: 34px; height: 34px; }
.classowl-photo.small > *        { width: calc(100% - 1px); height: calc(100% - 1px); border-width: 1px; }
.classowl-photo.small > *:before { font-size: 24px; }

.classowl-photo.large            { width: 88px; height: 88px; }
.classowl-photo.large > *:before { font-size: 48px; }

.classowl-photo.disabled           { pointer-events: none; }
.classowl-photo.disabled > .clear  { display: none; }
.classowl-photo.disabled > .select { display: none; }

/* classowl recorder */

.classowl-recorder                                     { font-size: 0; }
.classowl-recorder > div                               { display: inline-block; vertical-align: middle; }

.classowl-recorder .recorder-container > *             { display: inline-block; vertical-align: middle; }
.classowl-recorder .recorder-container > .btn          { position: relative; width: 70px; height: 70px; border-radius: 50%; background-color: #ef4949; padding: 3px; margin-right: 10px; cursor: pointer; }
.classowl-recorder .recorder-container > .btn > .inner { position: absolute; transform: translate(-50%, -50%); left: 50%; top: 50%; }
.classowl-recorder .recorder-container > .btn > .inner { width: 60px; height: 60px; border-radius: 50%; border: 2px solid white; }
.classowl-recorder .recorder-container > .btn > span   { position: absolute; transform: translate(-50%, -50%); left: 50%; top: 50%; }
.classowl-recorder .recorder-container > .btn > span   { max-width: 80%; font-size: 12px; color: #fff; }
.classowl-recorder .recorder-container > .btn.stop     { display: none; }
.classowl-recorder .recorder-container > canvas        { height: 70px; width: 250px; background-color: rgb(245, 245, 245); }
.classowl-recorder .recorder-container > .timer        { color: #282828; font-size: 18px; margin-left: 10px; }
.classowl-recorder .recorder-container > .error        { display: none; font-size: 14px; }
.classowl-recorder .recorder-container > .error b      { font-weight: 600; }

.classowl-recorder .player-container           { display: none; }
.classowl-recorder .player-container > *       { display: inline-block; vertical-align: middle; }
.classowl-recorder .player-container > .remove { margin-left: 10px; color: #de3030; font-size: 18px; line-height: 35px; width: 20px; text-align: center; cursor: pointer; }

.classowl-recorder.small .recorder-container > .btn          { height: 35px; width: 35px; padding: 2px; }
.classowl-recorder.small .recorder-container > .btn > .inner { height: 30px; width: 30px; border-width: 1px; }
.classowl-recorder.small .recorder-container > .btn > span   { max-width: 70%; font-size: 10px; }
.classowl-recorder.small .recorder-container > canvas        { height: 35px; width: 150px; }
.classowl-recorder.small .recorder-container > .timer        { font-size: 14px; }
.classowl-recorder.small .player-container   > audio         { height: 35px; }

.classowl-recorder.recording .recorder-container > .btn.start { display: none; }
.classowl-recorder.recording .recorder-container > .btn.stop  { display: inline-block; }

.classowl-recorder.play .recorder-container         { display: none; }
.classowl-recorder.play .player-container           { display: inline-block; }

.classowl-recorder.error .recorder-container          { display: inline-block; }
.classowl-recorder.error .recorder-container > .btn   { display: none; }
.classowl-recorder.error .recorder-container > canvas { display: none; }
.classowl-recorder.error .recorder-container > .timer { display: none; }
.classowl-recorder.error .recorder-container > .error { display: inline-block; }
.classowl-recorder.error .player-container            { display: none; }

/* classowl dropdown */

.classowl-dropdown                     { display: inline-block; position: relative; }
.classowl-dropdown > .drop-icon        { display: block; min-width: 30px; height: 30px; line-height: 30px; text-align: center; cursor: pointer; }
.classowl-dropdown > .drop-icon > *    { display: inline-block; vertical-align: middle; color: #228dcf; }
.classowl-dropdown > .drop-icon > i    { font-size: 18px; }
.classowl-dropdown > .drop-icon > span { font-size: 14px; }
.classowl-dropdown > .drop-icon > span:empty { display: none; }

.classowl-dropdown > .drop-list        { position: absolute; top: calc(100% + 5px); z-index: 2; box-shadow: 0 2px 4px rgba(0,0,0,0.2); cursor: default; }
.classowl-dropdown > .drop-list        { min-width: 200px; border-radius: 5px; border: 1px solid #d8dde6; background-color: #fff; user-select: none; }
.classowl-dropdown > .drop-list:before { position: absolute; top: -1px; content: ''; width: 10px; height: 10px; background-color: #fff; }
.classowl-dropdown > .drop-list:before { border-left: 1px solid #d8dde6; border-top: 1px solid #d8dde6; }

.classowl-dropdown           > .drop-list        { left: 50%; transform: translate(-50%, 0); }
.classowl-dropdown           > .drop-list:before { left: 50%; transform: translate(-50%, -50%) rotate(45deg); }

.classowl-dropdown.drop-left > .drop-list        { left: initial; right: -10px; transform: translate(0, 0); }
.classowl-dropdown.drop-left > .drop-list:before { left: initial; right: 18.5px;  transform: translate(0%, -50%) rotate(45deg); }

.classowl-dropdown.drop-right > .drop-list        { left: -10px; transform: translate(0, 0); }
.classowl-dropdown.drop-right > .drop-list:before { left: 18.5px;  transform: translate(0%, -50%) rotate(45deg); }

.classowl-dropdown      > .drop-list          { display: none; }
.classowl-dropdown.open > .drop-list          { display: block; }
.classowl-dropdown      > .drop-list > .inner { position: relative; max-height: 400px; border-radius: inherit; }
.classowl-dropdown      > .drop-list > .inner { overflow-x: hidden; overflow-y: auto; }

.classowl-dropdown.has-angle:before       { position: absolute; content: ''; width: 5px; height: 5px; border-right: 1px solid #228dcf; border-bottom: 1px solid #228dcf; }
.classowl-dropdown.has-angle:before       { transform: translate(-50%, -50%) rotate(45deg); top: 100%; left: 50%; }
.classowl-dropdown.has-angle.open:before  { transform: translate(-50%, -50%) rotate(-135deg); }

.classowl-dropdown .dropdown-items           { margin: 0; padding: 0; list-style-type: none; }
.classowl-dropdown .dropdown-items > li      { margin: 0; padding: 0; list-style-type: none; }

.classowl-dropdown .dropdown-item            { position: relative; user-select: none; }
.classowl-dropdown .dropdown-item            { border-bottom: 1px solid #d8dde6; }
.classowl-dropdown .dropdown-item:last-child { border-bottom: none; }
.classowl-dropdown .dropdown-item:focus      { background-color: #e5e5e5; }
.classowl-dropdown .dropdown-item:hover      { background-color: #e5e5e5; }
.classowl-dropdown .dropdown-item       > *  { display: block; padding: 0 15px; user-select: none; cursor: pointer; }
.classowl-dropdown .dropdown-item       > *  { box-sizing: border-box; width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.classowl-dropdown .dropdown-item       > *  { line-height: 32px; font-size: 14px; color: #282828; text-align: left; text-decoration: none; }
.classowl-dropdown .dropdown-item.small > *  { line-height: 24px; font-size: 12px; }

.classowl-dropdown .dropdown-item       > form          { padding: 0; }
.classowl-dropdown .dropdown-item       > form > button { display: block; padding: 0 15px; border: none; background-color: transparent; cursor: pointer; }
.classowl-dropdown .dropdown-item       > form > button { box-sizing: border-box; width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.classowl-dropdown .dropdown-item       > form > button { line-height: 32px; font-size: 14px; color: #282828; text-align: left; text-decoration: none; }


/* classowl checkbox */

.classowl-checkbox         { position: relative; font-size: 0; }
.classowl-checkbox > input { display: none; }
.classowl-checkbox > label { display: block; position: relative; user-select: none; cursor: pointer; padding: 0; margin: 0; min-width: 20px; min-height: 20px; }

.classowl-checkbox label:before { display: block; content: ''; position: absolute; top: 50%; margin-top: -10px; right: 0;
    border: 1px solid #228dcf; height: 20px; width: 20px; border-radius: 2px; background: #fff;
    -webkit-transition: all 0.3s ease; transition: all 0.3s ease; box-sizing: border-box; }
.classowl-checkbox label:after { display: block; content: ''; position: absolute; top: 50%; margin-top: -8px;
    right: 7px; width: 6px; height: 13px; opacity: 0; box-sizing: border-box;
    transform: rotate(45deg); transition: opacity 0.3s ease; transition-delay: 0.1s; }

.classowl-checkbox input:checked          + label:after  { border-right: 2px solid #fff; border-bottom: 2px solid #fff; opacity: 1; }
.classowl-checkbox input:checked          + label:before { background-color: #337ab7; border-color: #337ab7; }
.classowl-checkbox input:disabled         + label:before { background-color: #fff; border-color: #999; }
.classowl-checkbox input:disabled         + label        { cursor: default; }
.classowl-checkbox input:checked:disabled + label:before { background-color: #999; border-color: #999; }

.classowl-checkbox label span        { display: block; margin-right: 30px; font-size: 14px; line-height: 20px; color: #657FAC; white-space: initial; }
.classowl-checkbox label span:empty  { display: none; }

.classowl-checkbox.left label:before { right: auto; left: 0; }
.classowl-checkbox.left label:after  { right: auto; left: 7px; }
.classowl-checkbox.left label span   { margin-right: 0; margin-left: 30px; }


/* classowl dropdown + multiselect */

.classowl-multiselect                       { position: relative; font-size: 0; user-select: none; }
.classowl-multiselect > .drop-icon          { display: block; padding: 2px 9px; line-height: 30px; border: 1px solid #e5e5e5; border-radius: 5px; }
.classowl-multiselect > .drop-icon > *      { display: inline-block; vertical-align: middle; min-height: 21px; }
.classowl-multiselect > .drop-icon > i      { width: 18px; font-size: 18px; text-align: center; margin-top: 4px; }
.classowl-multiselect > .drop-icon > span   { width: calc(100% - 18px); text-align: left; font-size: 14px; }
.classowl-multiselect > .drop-icon > .title { color: #999; }
.classowl-multiselect > .drop-icon > .title > span { color: #282828; background-color: #f8f8f8; border: 1px solid #e5e5e5; border-radius: 3px; padding: 0 2px; }
.classowl-multiselect > .drop-icon > .empty { color: #999; }
.classowl-multiselect > .drop-icon > .title       + .empty { display: none; }
.classowl-multiselect > .drop-icon > .title:empty          { display: none; }
.classowl-multiselect > .drop-icon > .title:empty + .empty { display: inline-block; }
.classowl-multiselect.required              { background-color: #ffffee; }


.classowl-multiselect        > .drop-list { position: absolute; z-index: 10; left: 0; }
.classowl-multiselect        > .drop-list { min-width: calc(100% - 2px); border-radius: 5px; border: 1px solid #d8dde6; background-color: #fff; }
.classowl-multiselect        > .drop-list { top: calc(100% - 1px); bottom: auto; }
.classowl-multiselect.dropup > .drop-list { top: auto; bottom: calc(100% - 1px); }

.classowl-multiselect      > .drop-list                   { display: none; }
.classowl-multiselect.open > .drop-list                   { display: block; }
.classowl-multiselect      > .drop-icon > i.fa-angle-down { display: inline-block; }
.classowl-multiselect      > .drop-icon > i.fa-angle-up   { display: none; }
.classowl-multiselect.open > .drop-icon > i.fa-angle-down { display: none; }
.classowl-multiselect.open > .drop-icon > i.fa-angle-up   { display: inline-block; }

.classowl-multiselect.open        > .drop-icon { border-radius: 3px 3px 0 0; box-shadow: 0 1px 2px rgba(0,0,0,0.2); }
.classowl-multiselect.open        > .drop-list { border-radius: 0 0 3px 3px; box-shadow: 0 2px 2px rgba(0,0,0,0.2); }

.classowl-multiselect.open.dropup > .drop-icon { border-radius: 0 0 3px 3px; box-shadow: 0 -1px 2px rgba(0,0,0,0.2); }
.classowl-multiselect.open.dropup > .drop-list { border-radius: 3px 3px 0 0; box-shadow: -2px -2px 2px -1px rgba(0,0,0,0.1), 2px -2px 2px -1px rgba(0,0,0,0.1); }

.classowl-multiselect > .drop-list > .inner { position: relative; max-height: 250px; }
.classowl-multiselect > .drop-list > .inner { overflow-x: hidden; overflow-y: auto; }

.classowl-multiselect > .drop-list > .inner .classowl-checkbox             { padding: 0; }
.classowl-multiselect > .drop-list > .inner .classowl-checkbox             { border-top: 1px solid #e5e5e5; }
.classowl-multiselect > .drop-list > .inner .classowl-checkbox:first-child { border-top: none; }
.classowl-multiselect > .drop-list > .inner .classowl-checkbox label       { padding: 10px 0; margin: 0 0 0 10px; }
.classowl-multiselect > .drop-list > .inner .classowl-checkbox label span  { font-size: 14px; }
.classowl-multiselect > .drop-list > .inner .classowl-checkbox:hover       { background-color: #f0f0f0; }



.classowl-icon-toggle       { position: relative; font-size: 0; }
.classowl-icon-toggle input { display: none; }
.classowl-icon-toggle label { display: block; position: relative; user-select: none; cursor: pointer; padding: 0; min-width: 20px; min-height: 20px; }

.classowl-icon-toggle input                  + label        { font-size: 24px; }
.classowl-icon-toggle input                  + label        { filter: grayscale(100%); opacity: 0.3; }
.classowl-icon-toggle input:checked          + label        { filter: initial; opacity: 1; }
.classowl-icon-toggle input:disabled         + label        { opacity: 0.5; pointer-events: none; cursor: default; }


/* classowl dropdown button */

.classowl-dropdown-button                    { position: relative; }
.classowl-dropdown-button > .dropdown        { position: absolute; box-shadow: 0 2px 4px rgba(0,0,0,0.2); }
.classowl-dropdown-button > .dropdown        { border: 1px solid #d8dde6; background-color: #fff; }
.classowl-dropdown-button > .dropdown        { top: 100%; right: 0; min-width: 100%; }
.classowl-dropdown-button              > .dropdown       { display: none; }
.classowl-dropdown-button:focus        > .dropdown       { display: block; z-index: 2; }
.classowl-dropdown-button:focus        > .dropdown:empty { display: none; }
.classowl-dropdown-button:focus-within > .dropdown       { display: block; z-index: 2; }
.classowl-dropdown-button:focus-within > .dropdown:empty { display: none; }

.classowl-dropdown-button .action-button              { position: relative; user-select: none; cursor: pointer; }
.classowl-dropdown-button .action-button              { background-color: #3080EB; border-radius: 5px; }
.classowl-dropdown-button .action-button              { line-height: 34px; min-width: 30px; }
.classowl-dropdown-button .action-button > .text      { font-size: 14px; color: #ffffff; padding: 0 36px 0 10px; }
.classowl-dropdown-button .action-button > .icon      { position: absolute; right: 0; top: 0; width: 36px; height: 36px; }
.classowl-dropdown-button .action-button > .icon      { font-size: 18px; color: #ffffff; text-align: center; }

.classowl-dropdown-button:focus        .action-button > .icon { transform: scaleY(-1); }
.classowl-dropdown-button:focus-within .action-button > .icon { transform: scaleY(-1); }

.classowl-dropdown-button .action-item            { position: relative; user-select: none; }
.classowl-dropdown-button .action-item            { border-bottom: 1px solid #d8dde6; }
.classowl-dropdown-button .action-item:last-child { border-bottom: none; }
.classowl-dropdown-button .action-item:focus      { background-color: #e5e5e5; }
.classowl-dropdown-button .action-item:hover      { background-color: #e5e5e5; }
.classowl-dropdown-button .action-item > .inner   { display: block; padding: 0 15px; user-select: none; cursor: pointer; }
.classowl-dropdown-button .action-item > .inner   { box-sizing: border-box; width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.classowl-dropdown-button .action-item > .inner   { line-height: 32px; font-size: 14px; color: #282828; text-align: left; text-decoration: none; }
.classowl-dropdown-button .action-item.small > .inner { line-height: 24px; font-size: 12px; color: #657FAC; font-weight: bold; }


/* modal form */

.classowl-modal-form                          { position: fixed; z-index: 200; left: 0; right: 0; top: 0; bottom: 0; background-color: rgba(0,0,0,0.5); overflow-y: auto; }
.classowl-modal-form                          { display: none; }

.classowl-modal-form                            { user-select: none; }
.classowl-modal-form > .container > .form-inner { user-select: text; }

.classowl-modal-form > .container             { box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -webkit-box-sizing: border-box; }
.classowl-modal-form > .container             { position: relative; margin: 100px auto 20px; background-color: #fff; }
.classowl-modal-form > .container             { padding: 35px 25px 25px; border: 1px solid #D8DDE6; border-radius: 5px; box-shadow: 0 8px 15px 0 rgba(0,0,0,0.35); }

.classowl-modal-form > .container > .form-close       { position: absolute; z-index: 2; display: block; text-align: center; text-decoration: none; }
.classowl-modal-form > .container > .form-close       { top: 35px; right: 25px; width: 20px; height: 20px; line-height: 20px; }
.classowl-modal-form > .container > .form-close       { font-size: 36px; color: #657FAC; opacity: 0.4; cursor: pointer; }
.classowl-modal-form > .container > .form-close:hover { text-decoration: none; }

.classowl-modal-form > .container > .form-title { margin-top: -6px; padding-right: 30px; }
.classowl-modal-form > .container > .form-title { color: #657FAC; font-size: 24px; font-weight: 300; line-height: 32px; }

.classowl-modal-form > .container .form-subtitle { color: #999; font-size: 12px; line-height: 18px; }

.classowl-modal-form > .container > .form-inner { margin-top: 20px; }

@media screen and (max-width: 400px) {
    .classowl-modal-form > .container { position: absolute; transform: translate(0, 0); left: 0; top: 0; }
    .classowl-modal-form > .container { margin: 0; padding-top: 0; border-radius: 0; }

    .classowl-modal-form > .container > .form-close { top: 0; left: 0; width: 46px; height: 46px; line-height: 46px; color: #2D6DF2; opacity: 1; }

    .classowl-modal-form > .container > .form-title { margin: 0 -25px; padding: 16px 25px 14px 46px; border-bottom: 1px solid rgb(45,109,242,0.2); }
    .classowl-modal-form > .container > .form-title { font-size: 14px; line-height: 16px; font-weight: bold; text-align: center; color: #2D6DF2; }
    .classowl-modal-form > .container > .form-title { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

    .classowl-modal-form > .container > .form-inner { margin-bottom: 25px; }
}


.classowl-modal-form      > .container { width: 320px; }
.classowl-modal-form.w320 > .container { width: 320px; }
.classowl-modal-form.w640 > .container { width: 640px; }
.classowl-modal-form.w960 > .container { width: 960px; }

@media screen and (max-width: 1024px) {
    .classowl-modal-form      > .container { width: 320px; }
    .classowl-modal-form.w320 > .container { width: 320px; }
    .classowl-modal-form.w640 > .container { width: 640px; }
    .classowl-modal-form.w960 > .container { width: 640px; }
}

@media screen and (max-width: 800px) {
    .classowl-modal-form      > .container { width: 320px; }
    .classowl-modal-form.w320 > .container { width: 320px; }
    .classowl-modal-form.w640 > .container { width: 640px; }
    .classowl-modal-form.w960 > .container { width: 640px; }
}

@media screen and (max-width: 640px) {
    .classowl-modal-form      > .container { width: 320px; }
    .classowl-modal-form.w320 > .container { width: 320px; }
    .classowl-modal-form.w640 > .container { width: 320px; }
    .classowl-modal-form.w960 > .container { width: 320px; }
}

@media screen and (max-width: 400px) {
    .classowl-modal-form      > .container { width: 100%; height: 100vh; overflow-y: auto; }
    .classowl-modal-form.w320 > .container { width: 100%; height: 100vh; overflow-y: auto; }
    .classowl-modal-form.w640 > .container { width: 100%; height: 100vh; overflow-y: auto; }
    .classowl-modal-form.w960 > .container { width: 100%; height: 100vh; overflow-y: auto; }
}

.classowl-modal-form .form-inputs            { margin: 0 -5px; display: flex; align-items: stretch; flex-wrap: wrap; justify-content: flex-start; }
.classowl-modal-form .form-inputs > *        { margin: 0 5px 10px; }
.classowl-modal-form .form-inputs > .w50-3   { width: calc(16.66% - 10px); }
.classowl-modal-form .form-inputs > .single  { width: calc(25% - 10px); }
.classowl-modal-form .form-inputs > .w25     { width: calc(25% - 10px); }
.classowl-modal-form .form-inputs > .w33     { width: calc(33.33% - 10px); }
.classowl-modal-form .form-inputs > .w100-3  { width: calc(33.33% - 10px); }
.classowl-modal-form .form-inputs > .double  { width: calc(50% - 10px); }
.classowl-modal-form .form-inputs > .w50     { width: calc(50% - 10px); }
.classowl-modal-form .form-inputs > .w75     { width: calc(75% - 10px); }
.classowl-modal-form .form-inputs > .w75-100 { width: calc(75% - 10px); }
.classowl-modal-form .form-inputs > .full    { width: calc(100% - 10px); }
.classowl-modal-form .form-inputs > .w100    { width: calc(100% - 10px); }

@media screen and (max-width: 640px) {
    .classowl-modal-form .form-inputs > .w50-3   { width: calc(33.33% - 10px); }
    .classowl-modal-form .form-inputs > .single  { width: calc(50% - 10px); }
    .classowl-modal-form .form-inputs > .w25     { width: calc(50% - 10px); }
    .classowl-modal-form .form-inputs > .w33     { width: calc(50% - 10px); }
    .classowl-modal-form .form-inputs > .w100-3  { width: calc(50% - 10px); }
    .classowl-modal-form .form-inputs > .double  { width: calc(100% - 10px); }
    .classowl-modal-form .form-inputs > .w50     { width: calc(100% - 10px); }
    .classowl-modal-form .form-inputs > .w75     { width: calc(100% - 10px); }
    .classowl-modal-form .form-inputs > .w75-100 { width: calc(100% - 10px); }
}

.classowl-modal-form .form-inputs label { font-size: 12px; color: #657FAC; line-height: 18px; margin-bottom: 4px; }

.classowl-modal-form .form-line       { display: flex; align-items: center; min-height: 21px; }
.classowl-modal-form .form-line label { flex-grow: 0; flex-shrink: 0; }
.classowl-modal-form .form-line .line { flex-grow: 1; flex-shrink: 1; }
.classowl-modal-form .form-line label { font-size: 14px; color: #657FAC; line-height: 21px; margin-right: 10px; }
.classowl-modal-form .form-line .line { height: 1px; background-color: #ccc; }

.classowl-modal-form .form-ctrls { display: flex; align-items: center; justify-content: space-between; margin-top: 20px; }

.classowl-modal-form .form-group          { border: 1px solid #e5e5e5; border-radius: 5px; padding: 10px; margin: 0; }
.classowl-modal-form .form-group > legend { font-size: 14px; color: #1f3c77; }



/* classowl-user-block */

.classowl-user-block                               { margin: 0; padding: 0; display: block; }
.classowl-user-block .user-item                    { margin: 0; padding: 0; border: none; background-color: transparent; text-align: left; }
.classowl-user-block .user-item                    { display: flex; align-items: center; }
.classowl-user-block .user-item > .photo           { width: 30px; height: 30px; border-radius: 50%; background: no-repeat center center; background-size: cover; }
.classowl-user-block .user-item > .photo > img     { display: block; width: 100%; height: 100%; border-radius: 50%; object-fit: cover; }
.classowl-user-block .user-item > .photo > svg     { display: block; width: 100%; height: 100%; border-radius: 50%; }
.classowl-user-block .user-item > .title           { margin-left: 10px; font-size: 14px; max-width: 300px; }
.classowl-user-block .user-item > .title           { color: #228dcf; white-space: nowrap; }
.classowl-user-block .user-item > .title > .status { display: block; color: #999; font-size: 12px; }
.classowl-user-block            button              { cursor: pointer; pointer-events: all; }
.classowl-user-block[action=""] button              { cursor: default; pointer-events: none; }
.classowl-user-block[action=""] .user-item > .title { color: #282828; }


/* classowl-signature */

.classowl-signature       { position: relative; cursor: pointer; user-select: none; overflow: hidden; }
.classowl-signature       { background-color: #f8f8f8; box-shadow: 0 0 2px 1px #00000010; }
.classowl-signature:hover { box-shadow: 0 0 2px 1px #00000020; }
.classowl-signature:focus { box-shadow: 0 0 2px 1px #228dcf; }
.classowl-signature       { display: flex; align-items: center; justify-content: center; flex-direction: column; }

.classowl-signature                               { width: 200px; height: 100px; }
.classowl-signature > *                           { width: 100%; height: 100%; }
.classowl-signature > .classowl-signature-draw    { position: absolute; left: 0; top: 0; pointer-events: none; }
.classowl-signature > .classowl-signature-img     { object-fit: contain; }
.classowl-signature > .classowl-signature-btn     { align-items: center; justify-content: center; }
.classowl-signature > .classowl-signature-btn     { font-size: 14px; font-style: italic; color: #657FAC; }
.classowl-signature > .classowl-signature-btn > i { margin-right: 5px; }
.classowl-signature > .classowl-signature-svg > svg { box-sizing: border-box; max-width: 100%; max-height: 100%; margin: 0 auto; display: block; }

.classowl-signature       > .classowl-signature-draw        { display: none; }
.classowl-signature       > .classowl-signature-img[src=""] { display: none; }
.classowl-signature       > .classowl-signature-svg:empty   { display: none; }
/*.classowl-signature       > .classowl-signature-txt:empty   { display: none; }*/
.classowl-signature       > .classowl-signature-btn         { display: none; }

.classowl-signature.empty > .classowl-signature-draw { display: none; }
.classowl-signature.empty > .classowl-signature-img  { display: none; }
.classowl-signature.empty > .classowl-signature-svg  { display: none; }
/*.classowl-signature.empty > .classowl-signature-txt  { display: none; }*/
.classowl-signature.empty > .classowl-signature-btn  { display: flex; }

.classowl-signature.disabled { pointer-events: none; box-shadow: none; background-color: transparent; }
.classowl-signature.disabled > .classowl-signature-btn  { display: none; }


/* classowl-toggle */

.classowl-toggle                  { position: relative; display: block; font-size: 0; cursor: pointer; line-height: 24px; }
.classowl-toggle                  { display: flex; align-items: center; }

.classowl-toggle > input          { display: none; }
.classowl-toggle > .toggle        { position: relative; border-radius: 9px; width: 36px; height: 18px; }
.classowl-toggle > .toggle:before { content: ''; width: 14px; height: 14px; border-radius: 7px; background-color: #fff; }
.classowl-toggle > .toggle:before { position: absolute; display: block; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.classowl-toggle > .toggle,
.classowl-toggle > .toggle:before { transition: all 200ms ease-in-out; }

.classowl-toggle >                  .toggle        { background-color: #fff; border: 1px solid rgba(119,144,157,0.2); }
.classowl-toggle >                  .toggle:before { left: 50%; border: 0.5px solid rgba(119,144,157,0.2); box-shadow: 0 2px 4px 0 rgba(0,0,0,0.1); }
.classowl-toggle > input          ~ .toggle        { background-color: #999; border: none; }
.classowl-toggle > input          ~ .toggle:before { left: 9px; border: none; box-shadow: none; }
.classowl-toggle > input:checked  ~ .toggle        { background-color: #228dcf; border: none; }
.classowl-toggle > input:checked  ~ .toggle:before { left: calc(100% - 9px); border: none; box-shadow: none; }
.classowl-toggle > input:disabled ~ .toggle        { background-color: #ccc; border: none; }

.classowl-toggle > .caption                         { font-size: 14px; margin: 0 0 0 10px; }
.classowl-toggle > input          ~ .caption        { color: #999; }
.classowl-toggle > input:checked  ~ .caption        { color: #282828; }
.classowl-toggle > input          ~ .caption.state0 { display: block; }
.classowl-toggle > input          ~ .caption.state1 { display: none; }
.classowl-toggle > input:checked  ~ .caption.state0 { display: none; }
.classowl-toggle > input:checked  ~ .caption.state1 { display: block; }
.classowl-toggle > input          ~ .caption:empty  { display: none !important; }

.classowl-toggle.small > .toggle                         { border-radius: 6px; width: 24px; height: 12px; }
.classowl-toggle.small > .toggle:before                  { width: 10px; height: 10px; border-radius: 5px; }
.classowl-toggle.small > input          ~ .toggle:before { left: 6px; }
.classowl-toggle.small > input:checked  ~ .toggle:before { left: calc(100% - 6px); }
.classowl-toggle.small > .caption                        { font-size: 12px; }

.classowl-toggle.right            { flex-direction: row-reverse; }
.classowl-toggle.right > .caption { margin: 0 10px 0 0; }


/* gauge */
/* http://pepijndevos.nl/2023/12/24/lightweight-pure-css-gauge.html */

.classowl-gauge          { position: relative; overflow: hidden; user-select: none; }
.classowl-gauge > .title { position: absolute; transform: translate(-50%, 0); left: 50%; bottom: 0; }
.classowl-gauge > .title { text-align: center; white-space: nowrap; }
.classowl-gauge > .title { font-size: 16px; line-height: 20px; font-weight: 600; }

.classowl-gauge {
    --value1: 0.5;
    --value2: 0.5;
    --size: 100px;
    width: calc(var(--size));
    height: calc(var(--size) / 2);
}

.classowl-gauge       { --color1: #000000ff; --color2: #00000080; --color3: #00000020; }
.classowl-gauge.red   { --color1: #c00000ff; --color2: #c0000080; --color3: #ff000020; }
.classowl-gauge.blue  { --color1: #0000ffff; --color2: #0000ff80; --color3: #0000ff20; }
.classowl-gauge.green { --color1: #00a000ff; --color2: #00a00080; --color3: #00a00020; }

.classowl-gauge > .gauge {
    --value0: inherit;
    --value1: inherit;
    --value2: inherit;
    --size: inherit;
    --cutout: 50%;
    --color0: #000;
    --color1: inherit;
    --color2: inherit;
    --color3: inherit;
    --background: white;
    --line-width: 1deg;
    width: var(--size);
    height: var(--size);
    border-radius: calc(var(--size) / 2);
    background:
        radial-gradient(
            var(--background) 0 var(--cutout),
            transparent var(--cutout) 100%),
        conic-gradient(from -90deg,
            transparent calc(180deg * var(--value0) - var(--line-width)),
            var(--color0) calc(180deg * var(--value0) - var(--line-width)),
            var(--color0) calc(180deg * var(--value0) + var(--line-width)),
            transparent calc(180deg * var(--value0) + var(--line-width)),
            transparent 180deg),
        conic-gradient(from -90deg,
            var(--color1) calc(180deg * var(--value1)),
            var(--color2) calc(180deg * var(--value1)) calc(180deg * var(--value2)), 
            var(--color3) calc(180deg * var(--value2)) 180deg,
            transparent 180deg)
        ;
}


/* classowl-table-large */

.classowl-table-large       { max-width: 100%; overflow: auto; scrollbar-width: thin; }
.classowl-table-large       { background-color: #fff; border: 1px solid #ddd; }
.classowl-table-large:empty { display: none; }

.classowl-table-large > table                   { min-width: 100%; border-collapse: collapse; background-color: #fff; }

.classowl-table-large > table > * > * > th      { padding: 20px 15px; }
.classowl-table-large > table > * > * > td      { padding:  5px 15px; }

.classowl-table-large.compact > table > * > * > th { padding: 5px 10px; }
.classowl-table-large.compact > table > * > * > td { padding: 5px 10px; }

.classowl-table-large > table > thead           { position: relative; z-index: 3; top: 0; }
.classowl-table-large > table > thead           { box-shadow: 0px 1px 4px -2px rgba(0,0,0,0.3); }
.classowl-table-large > table > thead > tr > th { background-color: #fcfcfc; }
.classowl-table-large > table > thead > tr > th { color: #282828; font-size: 14px; }
.classowl-table-large > table > thead > tr > th { font-size: 12px; color: #b2b2b2; text-align: left; font-weight: normal; line-height: 18px; }

.classowl-table-large > table > tbody > tr            > td { border-bottom: 1px solid #f2f2f2; }
.classowl-table-large > table > tbody > tr:last-child > td { border-bottom: none; }
.classowl-table-large > table > tbody > tr > td            { color: #282828; font-size: 14px; }
.classowl-table-large > table > tbody > tr > td > .title   { color: #1f3c77; font-size: 14px; font-weight: 600; }
.classowl-table-large > table > tbody > tr > td > .descr   { color: #999999; font-size: 12px; }

.classowl-table-large > table .l { text-align: left; }
.classowl-table-large > table .c { text-align: center; }
.classowl-table-large > table .r { text-align: right; }

.classowl-table-large > table                  .sticky-t { position: sticky; top:   0; }
.classowl-table-large > table > * > * >       *.sticky-l { position: sticky; left:  0; z-index: 2; box-shadow:  1px 0 0 0 #eee; }
.classowl-table-large > table > * > * >       *.sticky-r { position: sticky; right: 0; z-index: 2; box-shadow: -1px 0 0 0 #eee; }
.classowl-table-large > table > tbody > tr > td.sticky-l { background-color: #fff; }
.classowl-table-large > table > tbody > tr > td.sticky-r { background-color: #fff; }

.classowl-table-large > table td.not-found    { padding: 20px; text-align: center; font-size: 18px; font-weight: 400; font-style: italic; color: #999; }

.classowl-table-large > table .item-ctrls     { display: flex; align-items: center; }
.classowl-table-large > table .item-ctrls > * { flex-grow: 0; flex-shrink: 0; margin: 0 2px; }
.classowl-table-large > table .item-ctrls .classowl-button.icon32 { font-size: 18px; }
