/** Account page **/

html:has(.page--account) { background-color: var(--bg-clr-dark); }
.page--account { display: grid; grid-template-columns: 250px auto; gap: 15px; }



/** Pages **/

.login-page, .register-page, .admin-page, .admin-item { background-color: var(--primary); }
.form .errors { max-width: 90%; }



/*** Account Pages | Content ***/

.page--form .content { min-width: 230px; min-height: 380px; height: 100vh; width: 100%; display: flex; align-items: center; justify-content: center; flex-direction: row; border-radius: 20px; overflow: auto; }
.page--form .content a { width: min-content; height: min-content; }
.page--form .content .image-block { display: flex; align-items: center; justify-content: center; height: 500px; min-width: 350px; width: 20%; background-color: var(--bg-clr-dark); border-radius: 20px 0 0 20px; pointer-events: none; }
.page--form .content .image-block img { width: 80%; }


/*** Account Pages | form ***/

.page--form .form { min-width: 230px; max-width: 370px; height: 500px; width: 25%; background-color: var(--bg-clr-light); color: var(--text-clr); display: flex; align-items: center; justify-content: center; flex-direction: column; border-radius: 0 20px 20px 0; overflow: hidden; }
.page--form .form form { width: 100%; display: flex; align-items: center; justify-content: center; flex-direction: column; }
.page--form .form h2 { margin: 10px 0 20px; text-align: center; color: var(--black); }
.page--form .form form > div { min-width: 230px; width: 85%; margin-bottom: 20px; }
.page--form .form h4 { margin-bottom: 10px; color: var(--black); display: flex; justify-content: space-between; align-items: end; --fs: 25px; }
.page--form .form h4 a { opacity: .7; --fs: small; width: fit-content; margin: 0 !important; }
.page--form .form input { width: calc(100% - 10px); height: 32px; background-color: var(--transparent); border: 1px lightgray solid; padding: 5px; border-radius: 5px; transition: all .3s; --fs: 20px; }
.page--form .form .passBox { position: relative; }
.page--form .form .password { width: calc(100% - 50px); }
.page--form .form .showPass { margin: 0; background-color: var(--text-clr); width: 32px; height: 32px; display: flex; justify-content: center; align-items: center; bottom: 0; right: 0; position: absolute; border-radius: 3px; cursor: pointer; border: 2px solid var(--secondary); transition: all .3s; }
.page--form .form .showPass .da-icon { --clr: var(--text-clr-invert); position: absolute;}
.page--form .form input:hover, .page--form .form input:focus, .page--form .form input:focus-visible { transition: all .3s; border: gray 1px solid; outline: 0; }
.page--form .form button { width: 100%; background-color: var(--accent); color: var(--black); padding: 15px 20px; border-radius: 10px; transition: all .3s; border: none; --fs: 25px; color: var(--text-clr-invert); }
.page--form .form button:hover { background-color: var(--accent-hover); cursor: pointer; color: var(--text-clr); }
.page--form .form form div > .link-button { text-align: center; width: 100%; background-color: var(--accent); color: var(--black); padding: 15px 20px; border-radius: 10px; transition: all .3s; border: none; }
.page--form .form form div > .link-button:hover { background-color: var(--accent-hover); cursor: pointer; }
.page--form .form form div > button > p { --fs: 13px; }
.page--form .form form div > .link-button > p { --fs: 13px; }
.page--form .form form a { margin: 0 0 15px 0; color: var(--text-clr); }
.page--form .form form .link { margin: 10px 0; display: flex; justify-content: space-between; flex-direction: row; align-items: center; }
.page--form .form form .link hr { text-align: center; width: 20%; color: var(--text-clr); }
.page--form .form form .link h5 { font-weight: 400; color: var(--text-clr); text-align: center; --fs: 16px; }
.page--form .form form .link h5 a { --fs: 16px; }
.page--form .form form .errors { color: var(--red-500) !important; --fs: 16px; }
.page--form .form form .success { color: var(--green-500) !important; --fs: 16px; }



/** Account Sidebar **/

.page--account header { pointer-events: none; }
.page--account nav { pointer-events: all; height: 100vh; width: 250px; position: fixed; top: 0; left: 0; background-color: var(--bg-clr); }

.page--account nav .user-group { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 15px; width: 220px; margin: 30px auto; }
.page--account nav .user-group .popup__inner { transition: opacity .3s; opacity: 0; pointer-events: none; position: absolute; top: 100%; left: 0; z-index: 100;  box-shadow: 0px 0px 45px 0px rgba(0,0,0,0.75); border-radius: 10px; background-color: rgba(0,0,0,0.4); }
.page--account nav .user-group .popup__inner .link { outline: unset; border: unset; background-color: var(--bg-clr-light); display: flex; align-items: center; justify-content: left; width: 220px; padding: 10px 15px; gap: 10px; border-radius: 10px; transition: opacity .3s;}
.page--account nav .user-group .popup__inner .link:not(:last-child) { margin-bottom: 5px; }
.page--account nav .user-group:hover .popup__inner { opacity: 1; pointer-events: all; }

.page--account nav .link-group .link { outline: unset; border: unset; display: flex; align-items: center; justify-content: left; width: 220px; padding: 10px 15px; gap: 10px; border-radius: 10px; margin: 10px auto; opacity: .7; transition: opacity .3s; }
.page--account nav .link-group .link:hover { opacity: 1; }
.page--account nav .link-group .link.active { background-color: var(--bg-clr-light); opacity: 1; }

.page--account nav .da-icon { --clr: var(--accent); }
.page--account nav p { --fs: 18px; }



/** Account Content **/

.page--account .content { min-height: calc(100vh - 30px); margin: 15px 15px 15px 0; grid-column: 2; }
.page--account.dashboard .content,
.page--account.analytics .content { row-gap: 15px; --gc: 1; --gr: 4; display: grid; grid-template-columns: repeat(var(--gc), minmax(0,1fr)); grid-template-rows: repeat(var(--gr), minmax(0,1fr)); }
.page--account:not(.dashboard, .analytics) .content { background-color: var(--bg-clr); border-radius: 10px; }

.page--account .btn-group { justify-content: start; margin: 30px; }
.page--account .btn-group .btn { display: flex !important; justify-content: center !important; align-items: center; gap: 5px; --fw: 600; }



/*** Account Content > Dashboard ***/

.page--account .content .row { --gc: 4; column-gap: 15px; display: grid; grid-template-columns: repeat(var(--gc), minmax(0,1fr)); }
.page--account .content .row .col { background-color: var(--bg-clr); border-radius: 10px; display: grid; place-content: center; text-align: center; border: 1px solid var(--bg-clr-dark); }
.page--account .content .row .col:hover { border: 1px solid var(--accent); }
.page--account .content .row:first-child .col { display: flex; flex-direction: column; align-items: start; justify-content: space-between; padding: 20px 0; }
.page--account.analytics .content .row .col { display: flex; flex-direction: column; align-items: start; justify-content: space-between; padding: 20px 0; }
.page--account .content .row .col > *:not(.btn) { margin: 0 30px; }
.page--account .content .row .col .btn { width: fit-content; margin: 30px auto; min-width: unset; padding: 0 20px; }
.page--account .content .row .col .statsrate { display: flex; gap: 30px; align-items: center; }
.page--account .content .row .col .statsrate p { --fs: 18px; }

.page--account .content .row .col .statsrate .da-icon--accent { --clr: var(--accent); }
.page--account .content .row .col .statsrate:has(.da-icon--accent) p { color: var(--accent); }
.page--account .content .row .col .statsrate .da-icon--red { --clr: var(--red-300); }
.page--account .content .row .col .statsrate:has(.da-icon--red) p { color: var(--red-300); }
.page--account .content .row .col .statsrate .da-icon--orange { --clr: var(--orange-300); }
.page--account .content .row .col .statsrate:has(.da-icon--orange) p { color: var(--orange-300); }

.page--account.dashboard .content .chart { height: 400px; width: 1000px; position: relative; aspect-ratio: unset !important; }

.page--account .row.span--2 { grid-row: span 2; }
.page--account .col.span--2 { grid-column: span 2; }
.page--account .col.span--3 { grid-column: span 3; }
.page--account .col.span--4 { grid-column: span 4; }

.page--account .col.bg--accent { background: linear-gradient(160deg,var(--bg-clr),var(--accent)) !important; }
.page--account .col.bg--light { background-color: var(--bg-clr-light) !important; }
.page--account .col.bg--dark { background-color: var(--bg-clr-dark) !important; }



/*** Account Content > Analytics ***/

.page--account.analytics .content .chart { height: 400px; width: 740px; position: relative; aspect-ratio: unset !important; }



/*** Account Content > Projects ***/

.dataTables_wrapper { margin: 30px; height: calc(100% - 60px); }
.dataTables_wrapper * { color: var(--text-clr) !important; font-family: var(--font-primary) !important; font-size: 14px !important; font-weight: 300 !important; }
.dataTables_wrapper a { color: var(--accent) !important;  --fs: 12px !important; font-weight: 700 !important; display: flex; justify-content: center; align-items: center; gap: 10px; }
.dataTables_wrapper .da-icon { --clr: var(--accent); }
.dataTables_wrapper .dataTable th { text-align: left; }
.dataTables_wrapper .dataTables_filter .input { padding: 0 5px !important; margin-left: 5px; }

.dataTables_wrapper tr > * { border-top: 0 !important; }
.dataTables_wrapper tr td.actions { display: flex; gap: 20px; }
.dataTables_wrapper tr.odd > * { box-shadow: unset !important; }
.dataTables_wrapper tr.odd { background-color: var(--bg-clr-light); border-radius: 20px; }
table.dataTable.no-footer { border-bottom: 0 !important; }
table.dataTable th { border-bottom: 0 !important; }



/*** Account Content > View ***/

.page--account.view .form { margin: 30px; width: calc(100% - 60px); }
.page--account.view .form__box { width: 100%; margin-bottom: 30px; }
.page--account.view .form__box input:not([type="submit"]) { width: 100%; margin-top: 15px; padding: 5px; border-radius: 10px; border: 0; outline: 0 !important; --fs: 16px; background-color: var(--bg-clr-light); }
.page--account.view .form__box select { width: 100%; margin-top: 15px; padding: 5px; border-radius: 10px; border: 0; outline: 0 !important; --fs: 16px; background-color: var(--bg-clr-light); }
.page--account.view .form__box input[type="submit"] { margin-top: 15px; }
.page--account.view .form__box *:is(input[readonly],textarea[readonly]) { cursor: not-allowed; }
.page--account.view .form__box textarea { width: 100%; min-width: 250px; max-width: 1572px; margin-top: 15px; padding: 5px; border-radius: 10px; border: 0; outline: 0 !important; --fs: 16px; background-color: var(--bg-clr-light); min-height: 200px; max-height: 450px; }
.page--account.view .form__box:has(.col) { display: flex; gap: 30px; }
.page--account.view .form__box .col { width: 50%; }
