* {
    font-family: "Fira Sans";
}

.area {
    background-image: url("../img/body_bg.png");
    height:100%;
}

.area img {
    max-width: 99%;
    max-height: 99%;
}

h1 {
    color: #134783;
    font-weight: 700;
    font-size: 40px;
}

.dashboard_container {
    /*background-color: #faf9f5;*/
    background-image: url(../img/bmcs_middle_tr_bg.png);
    border-radius: 14px;
    margin-top: -80px;
    padding: 0px 6px 0px 6px;
    /* padding: 0px 0px 0px 0px; */
    border: 1px solid #dcdbd7;
}

.dashboard_container_2 {
    /*background-color: #faf9f5;*/
    background-image: url(../img/bmcs_middle_tr_bg.png);
    border-radius: 14px;
    margin-top: -80px;
    padding: 0px 11px 0px 11px;
    /* padding: 0px 0px 0px 0px; */
    border: 1px solid #dcdbd7;
}


.footer-small {
    height: 2em;
    text-align: center;
    font-size: 1em;
    color: #aaa;
}

.navbar-inverse {
    background-color: #444444;
}

.navbar {
    padding-top: 0px;
    margin-bottom: 0px;
}

.nav>li {
    position: relative;
    /*padding-top: 4px;*/
    /*height: 120px;*/
    display: block;
}
.nav>li>a {
    padding-top: 19px;
}

.nav>li:hover {
    background-color: #eeeeee;
}

.navbar-brand {
    float: left;
    height: 50px;
    padding-top: 18px;
    padding-right: 15px;
    padding-bottom: 15px;
    padding-left: 15px;
    font-size: 18px;
    line-height: 20px;
    color: #134783 !important;
    font-weight: 700;
}

.nav-tabs {
    padding-left: 10px;
    /*padding-top: 6px;*/
}

.sdmainbox {
    height: 600px;
/*    background-image: url("../img/body_bg.png");
    background-repeat: no-repeat;
    background-position: left;
*/
}

.sdslogan {
    margin-top: 5px;
    margin-left: 370px;
    font-size: 2.5em;
}
.sdslogan span {
    font-size: 11px;
}

.sdslogan-large {
    margin-top: 5px;
    margin-left: 380px;
    font-size: 3em;
}
.sdslogan-large span {
    font-size: 13px;
}

.sdslogan-small {
    display: inline;
    width: 333px;
    height: 230px;
    padding-top: 40px;
    font-size: 2em;
    text-align: center;
}
.sdslogan-small span {
    font-size: 8px;
}

.sdslogan, .sdslogan-large, .sdslogan-small {
    float: left;
    font-weight: 700;
    color: #FFFFFF;
    text-shadow: 0px 0 9px rgba(60, 60, 60, 0.9);
}
.sdslogan span, .sdslogan-large span, .sdslogan-small span {
    color: #777;
    padding: 10px;
    text-shadow: none;
    font-weight: normal;
}

.title {
    font-size: 2.5em;
    margin: 10px 0 0.5em 0;
}
.title-large {
    margin: 12px 0 1em 0;
    font-size: 3.5em;
}
.title-small {
    display: inline;
    width: 333px;
    height: 230px;
    font-size: 1.5em;
}
.title, .title-large, .title-small {
    text-align: center;
    font-weight: 500;
    color: #134783;
    text-shadow: 0px 0 9px rgba(160, 160, 160, 0.7);
}

.sd_btn_left {
    /*margin-right: 5px !important;*/
    border-top-left-radius: 4px;
    border-top-right-radius: 0px;
    border-bottom-left-radius: 4px;
    border-bottom-right-radius: 0px;
}
.sd_btn_middle {
    /*margin-left: 5px;*/
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
}
.sd_btn_right {
    border-top-left-radius: 0px;
    border-top-right-radius: 4px;
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 4px;
}

.sd_btn_left.active, .sd_btn_middle.active, .sd_btn_right.active {
    background-color: #95e595;
}

.tips {
    margin-top: 10px;
}

label {
    font-weight: normal !important;
}

.icon_login {
    position: fixed;
    left: 2em;
    top: 0;
    margin: 0;
    z-index: 999999999;
}

.icon_login img {
    position: fixed;
    max-width: 8%;
    max-height: 8%;
}

.x_content {
    margin-top: 10px;
}

.entry {
    width: 365px;
    background: rgba(255, 255, 255, .95);
    border-radius: 6px;
    position: absolute;
    left: 0;
    overflow: hidden;
    z-index: 5;
    margin-left: 0;
}

.striped_list {
    display: block;
    list-style-type: none;
    border-bottom: solid 1px #222222;
}
#accordion {
    margin: 10px 3px 10px 3px;
}

/*td { padding: 5px 3px; border: 1px solid rgba(51, 122, 183, 0.35); }*/
td { padding: 5px 3px; border: 1px solid rgba(51, 183, 122, 0.35); }
table.comments td {
  margin: 2px;
  padding: 3px;
  font-weight: normal !important;
  color: #000;
/*  background-color: rgba(149, 210, 234, 0.20);*/
  background-color: rgba(149, 234, 210, 0.20);
  vertical-align: top;
}
td.time {
  width: 9%;
}
div.caution {
    background: rgba(255, 155, 155, .90);
    border-radius: 6px;
    border: 2px solid #f50000;
    position: absolute;
    right: 60px;
    top: 60px;
    overflow: hidden;
    padding: 10px;
    margin: 7px;
}

.area-left, .area-right {
    min-height: 460px;
    font-size: 14px;
    line-height: 20px;
    width: 48%;
    margin: 10px 0 0 0;
}
.area-left {
    float: left;
    padding: 5px 8px 5px 5px;
    color: #000;
    background-color: #e4e4e4 !important;
}
.area-right {
    float: right;
    padding: 5px 5px 5px 8px;
    color: #000 !important;
    background-color: #e9e9e9 !important;
}
div#doctor {
    height:100%;
}
h1, h2, h3, h4, h5, h6 { color: #337ab7; }
h4 i, h4 span { color: #1f4f8b; padding: 4px 8px; }
div.melodie, span.melodie { background-color: #337ab7; padding: 8px 4px; margin: 0; min-width: 2em; color: #fff; cursor: default; }
span.melodie.active { background-color: #2f6fad; }
a.comm.disabled, a.comm.disabled:hover { color: #ccc; }


div#list-doctors > li {
   display: block;
}
div#list-doctors li img {
   width: 36px; height:36px; padding:2px 9px 2px 2px;
}
div#list-doctors ul, div#list-doctors li {
  padding:5px;
  margin:1px;
}

h5.my_owner {
  position: relative;
  right: 0px;
  top: 0px;
  overflow: hidden;
  margin-right: 10px;
  float: right;
}
div#list-doctors li {
  clear: both;
  list-style: none;  
  color: #337ab7;
  text-decoration: none;
  background-color: #f5f5f5;
  border-radius: 7px;
  border: 1px solid transparent;
  cursor: pointer;
}
div#list-doctors li:hover {
  border: 1px solid #337ab7;
}
div#list-doctors li.active {
  background-color: #337ab7;
  color: #f5f5f5;
}
.form-error {
  background-color: red;
  border: 1px solid red;
}
/*
.btns {
border-radius: 4px;
padding: 4px;
display:none;
}
*/
.normal {background-color:rgba(197, 211, 211, 0.4);}
.super {background-color:rgba(219, 222, 222, 0.4);}

#submitBtn {
  width: 40%;
}

div.entry.box, div.edit {
border:1px solid transparent;cursor:pointer; border-radius: 8px; box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2), 0 6px 20px 0 rgba(0, 0, 0, 0.19);
}
div.LICENSE, div.TEXT {
padding: 12px;
margin: 5px;
text-shadow: none;
max-width: 95%;
font-size: 12px;
text-align: left;
overflow-y: scroll;
overflow-x: hidden;
}
div.LICENSE p, div.TEXT p  {
font-weight: normal;
}
div.LICENSE p  b, div.TEXT p b {
font-weight: 700;
}

div.LICENSE {
  color: #999;
  border: 1px solid #fff;
  border-top: 1px solid #999;
  border-radius: 3px;
  max-height: 150px;
  background-color: rgba(196, 196, 196, 0.2);
}
div.TEXT {
  color:#000;
  border: 1px solid #ccc;
  border-radius: 8px;
  background-color: transparent;
  /*background: url(../img/a.jpg);*/
  text-shadow: 1px 1px 1px #fff;
}
div.TEXT p  {
text-indent: 1.5em;
}

p.ATTETION  {
padding: 10px 0 0 0;
font-weight: normal;
font-size:85%;
color: #999;
}

div.scrolling {
  overflow-y: scroll;
  overflow-x: hidden;
}

@media (min-width: 992px) and (max-width: 1023px) {
  div.LICENSE { max-height: 100px; }
  div.TEXT { max-height: 20em; }
}
@media (min-width: 1024px) and (max-width: 1199px) {
  div.LICENSE { max-height: 110px; }
  div.TEXT { max-height: 30em; }
}
@media (min-width: 1200px) and (max-width: 1599px) {
  div.LICENSE { max-height: 120px; }
  div.TEXT { max-height: 40em; }
}
@media (min-width: 1600px) and (max-width: 2400px) {
  div.LICENSE { max-height: 150px;}
  div.TEXT { max-height: 50em; }
}
@media ((min-width: 100px) and (max-width: 735px)), ((min-height: 100px) and (max-height: 735px)) {
  html {
  font-size:9px;
  }
  #footer {
  height:2em;
  }
}

/* Phase 1: conservative service-level visual foundation */
body {
    background: #f5f7fb;
    color: #24364d;
}

.area {
    background: #f5f7fb;
    background-image: none;
}

.dashboard_container,
.dashboard_container_2 {
    background: #fff;
    background-image: none;
    border: 1px solid #d9e2ee;
    box-shadow: 0 12px 28px rgba(32, 54, 80, 0.08);
}

.navbar-inverse {
    background: #fff;
    border-bottom: 1px solid #d9e2ee;
}

.navbar {
    background: #fff;
}

.nav>li:hover {
    background-color: #eef4fb;
}

.navbar-brand {
    color: #1f4f8b !important;
}

.entry {
    background: rgba(255, 255, 255, .98);
    border: 1px solid #d9e2ee;
    box-shadow: 0 12px 30px rgba(32, 54, 80, 0.08);
}

td {
    border-color: rgba(135, 155, 184, 0.24);
}

table.comments td {
    background-color: rgba(233, 241, 255, 0.55);
    border-color: rgba(135, 155, 184, 0.22);
}

/* Phase 1.2: auth and patient shell cleanup */
body.body-login {
    background: #f5f7fb;
}

body.body-login .icon_login {
    left: 18px;
    top: 12px;
    z-index: 30;
}

body.body-login .icon_login img {
    position: static;
    width: 56px;
    max-width: none;
    max-height: none;
}

body.body-login #user.area {
    min-height: 100vh;
    padding-top: 68px;
}

body.body-login #header.navbar {
    background: transparent;
    border: 0;
    box-shadow: none;
}

body.body-login #header .container {
    width: min(1160px, calc(100vw - 32px));
}

body.body-login .navbar-brand {
    padding-left: 72px;
}

body.body-login .sdmainbox {
    height: auto;
    min-height: calc(100vh - 140px);
    display: flex;
    align-items: center;
}

body.body-login .entry,
body.body-login .entry.box {
    width: min(440px, 100%);
    border-radius: 18px;
    box-shadow: 0 18px 36px rgba(22, 35, 54, 0.1);
}

body.body-login .sdslogan,
body.body-login .sdslogan-large,
body.body-login .sdslogan-small {
    margin: 0;
    padding: 0 0 0 44px;
    color: #42586f;
    line-height: 1.45;
}

body.body-login .form-control,
.patient-pane .form-control {
    height: 42px;
    border: 1px solid #cbd8e6;
    border-radius: 10px;
    box-shadow: none;
}

body.body-login .btn.btn-default,
.patient-pane .btn.btn-default,
.patient-pane .btn.btn-start {
    min-height: 40px;
    border: 1px solid #d3deea;
    border-radius: 10px;
    box-shadow: none;
    background-image: none;
    background-clip: padding-box;
    transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

body.body-login .btn.btn-default:hover,
.patient-pane .btn.btn-default:hover,
.patient-pane .btn.btn-start:hover {
    background: #eef4fb;
}

body.body-login .login-form--forgot .btn.btn-default,
body.body-login .login-form--reset .btn.btn-default {
    width: 100%;
    border-radius: 12px !important;
    background: #ffffff;
    color: #27496e;
    border-color: #c8d7e7;
}

body.body-login .login-form--forgot .btn.btn-default:hover,
body.body-login .login-form--reset .btn.btn-default:hover,
body.body-login .login-form--forgot .btn.btn-default:focus,
body.body-login .login-form--reset .btn.btn-default:focus {
    background: #eef4fb;
    color: #1f4f8b;
    border-color: #b4cae1;
    box-shadow: 0 0 0 3px rgba(72, 125, 187, 0.14);
    outline: none;
}

body.body-login .login-form--forgot .btn.btn-default:active,
body.body-login .login-form--reset .btn.btn-default:active,
body.body-login .login-form--forgot .btn.btn-default.active,
body.body-login .login-form--reset .btn.btn-default.active,
body.body-login .login-form--forgot .btn.btn-default:active:hover,
body.body-login .login-form--reset .btn.btn-default:active:hover {
    background: #dfeaf7;
    color: #1f4f8b;
    border-color: #aac2dd;
    box-shadow: inset 0 1px 2px rgba(31, 79, 139, 0.08), 0 0 0 3px rgba(72, 125, 187, 0.12);
}

#menu-level .dropdown-menu {
    border: 1px solid #d8e2ee;
    border-radius: 12px;
    box-shadow: 0 18px 36px rgba(22, 35, 54, 0.12);
    overflow: hidden;
}

#menu-level .dropdown-menu > li > a {
    padding: 10px 14px;
}

.patient-menu-desktop {
    display: block;
}

.patient-menu__trigger {
    display: flex !important;
    align-items: center;
    gap: 8px;
}

.patient-menu-mobile {
    display: none;
}

.patient-menu-mobile__identity {
    padding: 6px 12px 10px;
    color: #6b7f95;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.patient-menu-mobile__link {
    display: block;
    padding: 14px 12px;
    border-top: 1px solid #e7edf5;
    color: #24364d;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
}

.patient-menu-mobile__link:hover,
.patient-menu-mobile__link:focus {
    background: #eef4fb;
    color: #1f4f8b;
    text-decoration: none;
}

.patient-menu-mobile__link--logout {
    color: #9c4a4a;
}

.patient-pane {
    width: min(1120px, calc(100vw - 32px));
    margin: 24px auto;
    padding: 18px 20px;
    border: 1px solid #dde6f0;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(32, 54, 80, 0.08);
}

.patient-pane__title {
    margin: 0 0 12px;
    color: #22374e;
    font-size: 18px;
    font-weight: 600;
}

.patient-profile-form {
    display: flex;
    flex-direction: column;
    gap: 12px;
    max-width: 860px;
}

.patient-profile-form__row {
    display: grid;
    grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
    width: 100%;
    margin-top: 0;
    border: 1px solid #dce5f0;
    border-radius: 14px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 4px 14px rgba(32, 54, 80, 0.04);
}

.patient-profile-form__field-label {
    display: flex;
    align-items: center;
    min-width: 0;
    min-height: 56px;
    margin: 0;
    padding: 0 16px;
    border-right: 1px solid #e3eaf3;
    background: #f4f8fd;
    color: #4d6279;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.patient-profile-form__field-control {
    border: 0 !important;
    border-radius: 0 !important;
    background: #fcfdff;
}

.patient-profile-form .input-group {
    display: grid;
    grid-template-columns: minmax(180px, 240px) minmax(0, 1fr);
    width: 100%;
    margin-top: 0;
    border: 1px solid #dce5f0;
    border-radius: 14px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 4px 14px rgba(32, 54, 80, 0.04);
}

.patient-profile-form .input-group-addon {
    display: flex;
    align-items: center;
    min-width: 0;
    padding: 0 16px;
    border: 0;
    border-right: 1px solid #e3eaf3;
    background: linear-gradient(180deg, #f7faff 0%, #eef4fb 100%);
    color: #50647b;
}

.patient-profile-form__label {
    display: block;
    width: 100%;
    font-style: normal;
    font-weight: 600;
    letter-spacing: 0.01em;
}

.patient-profile-form .form-control {
    height: 56px;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: #fcfdff;
    color: #24364d;
    padding: 0 18px;
}

.patient-profile-form .form-control[readonly] {
    background: #f4f7fb;
    color: #5d7187;
}

.patient-profile-form .btn-group {
    margin-top: 4px;
}

.patient-profile-form .btn-group .btn {
    min-height: 42px;
    padding: 0 18px;
    border: 1px solid #d3deea;
    border-radius: 10px;
    background: #fff;
    color: #304860;
    box-shadow: none;
}

.patient-history-list {
    max-height: none !important;
    overflow: visible !important;
}

.patient-start-panel,
.patient-session-panel {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.patient-start-copy {
    max-width: 72ch;
    color: #65798f;
    line-height: 1.65;
}

.patient-session-head {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.patient-session-title {
    margin: 0;
    color: #22374e;
    font-size: 20px;
    font-weight: 600;
}

.patient-session-title span.active {
    padding: 0;
    color: #1f4f8b;
    background: transparent;
}

.patient-session-alert.caution {
    position: static;
    right: auto;
    top: auto;
    margin: 0;
    border: 1px solid #ecd8d8;
    background: #fff7f7;
    color: #8a4b4b;
}

.patient-progress-card {
    padding: 14px 16px;
    border: 1px solid #e3ebf4;
    border-radius: 14px;
    background: #f8fbff;
}

.patient-progress-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
}

.patient-progress-card__label,
.patient-progress-card__stats {
    color: #6e8198;
    font-size: 12px;
    font-weight: 600;
}

.patient-progress-track {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10px, 1fr));
    gap: 6px;
    align-items: center;
}

.patient-progress-track div.melodie,
.patient-progress-track span.melodie {
    display: block;
    position: relative;
    min-width: 0;
    height: 12px;
    padding: 0;
    margin: 0;
    border-radius: 999px;
    background: #dbe6f2;
    color: transparent;
    overflow: hidden;
}

.patient-progress-track span.melodie::before {
    content: "";
    position: absolute;
    inset: 0 auto 0 0;
    width: var(--progress, 0%);
    border-radius: inherit;
    background: #2f6fad;
    transition: width 0.18s linear;
}

.patient-progress-track span.melodie.active {
    background: #2f6fad;
}

.patient-progress-track span.melodie.is-current {
    background: #e7eff8;
    box-shadow: inset 0 0 0 1px rgba(47, 111, 173, 0.26);
}

.patient-progress-track span.melodie.is-complete::before {
    width: 100%;
}

.patient-session-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    padding-top: 4px;
    border-top: 1px solid #e7edf5;
}

#startBtn,
#pause {
    min-width: 180px;
    width: auto !important;
}

#pause {
    background: #2f6fad;
    color: #fff;
    border-color: #2f6fad;
}

#pause:hover,
#pause:focus {
    background: #255f99;
    color: #fff;
    border-color: #255f99;
    box-shadow: 0 0 0 3px rgba(47, 111, 173, 0.14);
}

#pause:active,
#pause.active {
    background: #214f7d;
    color: #fff;
    border-color: #214f7d;
}

@media (max-width: 900px) {
    .icon_login {
        display: none !important;
    }

    body.body-login .icon_login {
        display: none;
    }

    body.body-login #user.area {
        padding-top: 18px;
    }

    body.body-login .navbar-brand {
        padding-left: 15px;
    }

    body.body-login .sdslogan,
    body.body-login .sdslogan-large,
    body.body-login .sdslogan-small {
        padding-left: 0;
    }
}

@media (max-width: 640px) {
    .icon_login {
        display: none !important;
    }

    #user #header {
        position: sticky;
        top: 0;
        z-index: 40;
    }

    #user #header .container {
        width: calc(100vw - 20px);
        padding: 0;
        position: relative;
    }

    #user #header .navbar-header {
        float: none;
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 12px;
        min-height: 72px;
        padding: 12px 0 10px;
    }

    #user #header .navbar-brand {
        order: 1;
        float: none;
        flex: 1 1 auto;
        height: auto;
        margin: 0;
        padding: 0 8px 0 0;
        font-size: 14px;
        line-height: 1.15;
        white-space: normal;
    }

    #user #header .navbar-toggle {
        order: 2;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 4px;
        margin: 0 0 0 auto;
        padding: 10px 9px;
        border: 1px solid #d7e2ee;
        border-radius: 12px;
        background: #fff;
        box-shadow: 0 10px 24px rgba(32, 54, 80, 0.08);
    }

    #user #header .navbar-toggle .icon-bar {
        width: 20px;
        margin: 0;
        background-color: #324a63;
    }

    #user #header .navbar-collapse {
        position: absolute;
        top: calc(100% + 8px);
        left: 0;
        right: 0;
        margin: 0;
        padding: 0;
        border: 0;
        box-shadow: none;
        background: transparent;
        overflow: visible !important;
    }

    #user #header .navbar-collapse.collapse {
        display: none !important;
    }

    #user #header .navbar-collapse.collapse.in {
        display: block !important;
    }

    #user #header .navbar-nav {
        float: none !important;
        margin: 0;
    }

    #menu-level {
        float: none !important;
        width: 100%;
    }

    #menu-level .patient-menu-desktop,
    #menu-level .dropdown-menu,
    #menu-level .caret,
    #menu-level #my-img {
        display: none !important;
    }

    #menu-level .patient-menu-mobile {
        display: block;
        overflow: hidden;
        border: 1px solid #d7e2ee;
        border-radius: 16px;
        background: #fff;
        box-shadow: 0 18px 36px rgba(32, 54, 80, 0.14);
    }

    .patient-pane {
        width: calc(100vw - 20px);
        margin: 14px auto;
        padding: 14px;
        border-radius: 14px;
    }

    .patient-profile-form .input-group {
        grid-template-columns: 1fr;
    }

    .patient-profile-form__row {
        grid-template-columns: 1fr;
    }

    .patient-profile-form .input-group-addon {
        width: 100%;
        min-height: 44px;
        border-right: 0;
        border-bottom: 1px solid #e3eaf3;
    }

    .patient-profile-form__field-label {
        width: 100%;
        min-height: 44px;
        border-right: 0;
        border-bottom: 1px solid #e3eaf3;
    }

    .patient-profile-form .form-control {
        height: 52px;
    }

    .patient-progress-track {
        gap: 4px;
    }

    .patient-session-actions {
        flex-direction: column;
        align-items: stretch;
    }

    #startBtn,
    #pause {
        width: 100% !important;
    }
}

/* Phase 1.3: corrective auth visual pass */
body.body-login .login-shell {
    width: min(1180px, calc(100vw - 32px));
    margin: 0 auto;
    padding: 16px 0 28px;
}

body.body-login .login-brand {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 18px;
    color: #42586f;
}

body.body-login .login-brand__eyebrow {
    margin: 0;
    color: #6d7f94;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

body.body-login .login-brand__title {
    margin: 0;
    color: #203650;
    font-size: clamp(30px, 4vw, 48px);
    line-height: 1.08;
    font-weight: 700;
    text-shadow: none;
}

body.body-login .login-brand__copy {
    margin: 0;
    max-width: 68ch;
    color: #5c7187;
    font-size: 15px;
    line-height: 1.6;
}

body.body-login .login-layout {
    display: grid;
    grid-template-columns: minmax(0, 420px) minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}

body.body-login .login-card {
    padding: 22px 20px 18px;
    border: 1px solid #dde6f0;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 18px 36px rgba(22, 35, 54, 0.1);
}

body.body-login .login-card .entry,
body.body-login .login-card .entry.box {
    width: 100%;
    position: static !important;
    left: auto !important;
    margin: 0 !important;
    border: 0;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
}

body.body-login .login-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

body.body-login .login-form__eyebrow {
    margin: 0;
    color: #7a8da4;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

body.body-login .login-form__hint {
    margin: -2px 0 2px;
    color: #65798f;
    font-size: 13px;
    line-height: 1.5;
}

body.body-login .login-shell--single {
    width: min(960px, calc(100vw - 32px));
    padding-top: 36px;
}

body.body-login .login-brand--single {
    align-items: center;
    text-align: center;
    margin-bottom: 22px;
}

body.body-login .login-layout--single {
    grid-template-columns: 1fr;
    justify-items: center;
}

body.body-login .login-card--single {
    width: min(460px, 100%);
}

body.body-login .login-form__title {
    margin: 0;
    color: #2a568f;
    font-size: 19px;
    font-weight: 700;
    line-height: 1.25;
}

body.body-login .login-form__title--center {
    text-align: center;
}

body.body-login .login-form__copy {
    margin: -2px 0 2px;
    color: #3f5369;
    font-size: 15px;
    line-height: 1.5;
}

body.body-login .login-form--forgot h3,
body.body-login .login-form--reset h3 {
    display: block;
}

body.body-login .login-form--forgot .btn-group.btn-group-justified,
body.body-login .login-form--reset .btn-group {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
}

body.body-login .login-form--forgot .btn-group.btn-group-justified > .btn-group,
body.body-login .login-form--reset .btn-group > .btn {
    width: 100%;
}

body.body-login .login-form .input-group {
    width: 100%;
    margin-top: 0;
}

body.body-login .login-form .input-group-addon {
    min-width: 46px;
    border-color: #d2dce8;
    background: #f7faff;
    color: #6e8197;
}

body.body-login .login-form h3 {
    margin: 0;
}

body.body-login .login-form .btn-group.btn-group-justified {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

body.body-login .login-form .btn-group.btn-group-justified > .btn-group {
    float: none;
    width: auto;
}

body.body-login .login-form .btn-group.btn-group-justified > .btn-group > .btn {
    width: 100%;
    border-radius: 10px !important;
}

body.body-login .login-form .tips {
    margin-top: 0;
}

body.body-login .login-form .tips a {
    color: #1f4f8b;
    font-weight: 500;
}

body.body-login .login-layout--register {
    grid-template-columns: minmax(0, 520px);
    justify-content: center;
    gap: 16px;
}

body.body-login .login-card--register,
body.body-login .login-legal--register {
    width: min(520px, 100%);
    margin: 0 auto;
}

body.body-login .login-form--register .login-form__hint {
    margin: -2px 0 0;
}

body.body-login .login-form__single-action {
    grid-template-columns: 1fr !important;
}

body.body-login .login-form__single-action > .btn-group {
    width: 100%;
}

body.body-login .login-form__single-action > .btn-group > .btn {
    width: 100%;
}

body.body-login .login-secondary {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

body.body-login .login-note {
    padding: 14px 16px;
    border: 1px solid #e3ebf4;
    border-radius: 14px;
    background: #f8fbff;
    color: #5d738b;
    font-size: 13px;
    line-height: 1.55;
}

body.body-login .login-legal {
    border: 1px solid #dde6f0;
    border-radius: 16px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 14px 28px rgba(22, 35, 54, 0.08);
    overflow: hidden;
}

body.body-login .login-legal > summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 16px 18px;
    list-style: none;
    cursor: pointer;
    color: #203650;
    font-size: 15px;
    font-weight: 600;
}

body.body-login .login-legal > summary::-webkit-details-marker {
    display: none;
}

body.body-login .login-legal > summary::after {
    content: 'Розгорнути';
    color: #6c8096;
    font-size: 12px;
    font-weight: 600;
}

body.body-login .login-legal[open] > summary::after {
    content: 'Згорнути';
}

body.body-login .login-legal__body {
    max-height: 320px;
    overflow: auto;
    padding: 0 18px 18px;
    color: #5a6e84;
    font-size: 13px;
    line-height: 1.62;
}

body.body-login .login-legal__body p,
body.body-login .login-legal__body span,
body.body-login .login-legal__body b {
    color: inherit !important;
    text-shadow: none !important;
}

body.body-login .login-legal__body p {
    margin: 0 0 10px;
    text-indent: 0;
}

body.body-login .login-legal__body p:last-child {
    margin-bottom: 0;
}

@media (max-width: 900px) {
    body.body-login .login-layout {
        grid-template-columns: 1fr;
    }

    body.body-login .login-secondary {
        order: 2;
    }
}

@media (max-width: 640px) {
    body.body-login .login-shell {
        width: calc(100vw - 20px);
        padding-top: 8px;
    }

    body.body-login .login-shell--single {
        width: calc(100vw - 20px);
        padding-top: 18px;
    }

    body.body-login .login-brand {
        gap: 8px;
        margin-bottom: 12px;
    }

    body.body-login .login-brand__copy {
        font-size: 14px;
    }

    body.body-login .login-card {
        padding: 16px 14px 14px;
        border-radius: 14px;
    }

    body.body-login .login-form .btn-group.btn-group-justified {
        grid-template-columns: 1fr;
    }

    body.body-login .login-legal__body {
        max-height: 220px;
        padding: 0 14px 14px;
    }
}

/* Phase 1.4: corrective visual pass */
body.body-login #header.navbar {
    display: none;
}

body.body-login .footer-small {
    color: #73859b;
}

body.body-login .login-card .login-form h3 {
    display: none;
}

body.body-login .login-note {
    margin: 0;
}

body.body-login .login-legal__body {
    background: #fff;
}

@media (max-width: 640px) {
    body.body-login .icon_login {
        display: none;
    }

    body.body-login #user.area {
        padding-top: 12px;
    }
}
