launcher.css 28 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279
  1. /*******************************************************************************
  2. * *
  3. * Fonts *
  4. * *
  5. ******************************************************************************/
  6. @font-face {
  7. font-family: 'Avenir Book';
  8. src: url('../fonts/Avenir-Book.ttf');
  9. }
  10. @font-face {
  11. font-family: 'Avenir Medium';
  12. src: url('../fonts/Avenir-Medium.ttf');
  13. }
  14. @font-face {
  15. font-family: 'Ringbearer';
  16. src: url('../fonts/Ringbearer.ttf');
  17. }
  18. /*******************************************************************************
  19. * *
  20. * Element Styles *
  21. * *
  22. ******************************************************************************/
  23. /* Reset body, html, and div presets. */
  24. body, html, div {
  25. margin: 0px;
  26. padding: 0px;
  27. }
  28. /* Reset p presets. */
  29. p {
  30. -webkit-margin-before: 0em;
  31. -webkit-margin-after: 0em;
  32. }
  33. /*body {
  34. background: url('./../images/backgrounds/0.jpg') no-repeat center center fixed;
  35. background-size: cover;
  36. }*/
  37. /*******************************************************************************
  38. * *
  39. * Frame Styles (frame.ejs) *
  40. * *
  41. ******************************************************************************/
  42. #frame_bar {
  43. -webkit-app-region: drag;
  44. -webkit-user-select: none;
  45. background: rgba(1, 2, 1, 0.5);
  46. min-height: 22px;
  47. display: flex;
  48. align-items: center;
  49. position: relative;
  50. z-index: 10000;
  51. }
  52. #frame_btn_dock {
  53. margin-left: 2px;
  54. }
  55. .frame_btn {
  56. height: 12px;
  57. width: 12px;
  58. border-radius: 50%;
  59. border: 0px;
  60. margin-left: 5px;
  61. -webkit-app-region: no-drag !important;
  62. cursor: pointer;
  63. }
  64. .frame_btn:focus {
  65. outline: 0px;
  66. }
  67. #frame_btn_close {
  68. background-color: #e74c32;
  69. }
  70. #frame_btn_close:hover,
  71. #frame_btn_close:focus {
  72. background-color: #FF9A8A;
  73. }
  74. #frame_btn_close:active {
  75. background-color: #ff8d7b;
  76. }
  77. #frame_btn_restoredown {
  78. background-color: #fed045;
  79. }
  80. #frame_btn_restoredown:hover,
  81. #frame_btn_restoredown:focus {
  82. background-color: #FFE9A9;
  83. }
  84. #frame_btn_restoredown:active {
  85. background-color: #ffde7b;
  86. }
  87. #frame_btn_minimize {
  88. background-color: #96e734;
  89. }
  90. #frame_btn_minimize:hover,
  91. #frame_btn_minimize:focus {
  92. background-color: #D6FFA6;
  93. }
  94. #frame_btn_minimize:active {
  95. background-color: #bfff76;
  96. }
  97. /*******************************************************************************
  98. * *
  99. * Welcome View (welcome.ejs) *
  100. * *
  101. ******************************************************************************/
  102. #welcomeContainer {
  103. position: relative;
  104. display: flex;
  105. justify-content: center;
  106. align-items: center;
  107. height: 100%;
  108. width: 100%;
  109. transition: 0.25s ease;
  110. }
  111. #welcomeContent {
  112. display: flex;
  113. flex-direction: column;
  114. justify-content: center;
  115. align-items: center;
  116. width: 50%;
  117. top: -10%;
  118. position: relative;
  119. }
  120. .cloudDiv {
  121. position: absolute;
  122. height: 100%;
  123. width: 100%;
  124. display: flex;
  125. flex-direction: column;
  126. }
  127. .cloudTop {
  128. height: 50%;
  129. width: 100%;
  130. background-image: url('../images/cloudTrans.png');
  131. animation: clouds1 80s linear infinite;
  132. background-size: cover;
  133. }
  134. .cloudBottom {
  135. height: 50%;
  136. width: 100%;
  137. background-image: url('../images/cloudTrans2.png');
  138. animation: clouds2 70s linear infinite;
  139. background-size: cover;
  140. }
  141. @keyframes clouds1 {
  142. to {
  143. background-position: 200%;
  144. }
  145. }
  146. @keyframes clouds2 {
  147. to {
  148. background-position: 230%;
  149. }
  150. }
  151. #welcomeImageSeal {
  152. border-radius: 50%;
  153. border: 2px solid #cad7e1;
  154. background: rgba(1, 2, 1, 0.5);
  155. height: 125px;
  156. width: 125px;
  157. box-shadow: 0px 0px 10px 0px rgb(0, 0, 0);
  158. margin-bottom: 10%;
  159. margin-top: 10%;
  160. }
  161. #welcomeHeader {
  162. font-family: 'Avenir Medium';
  163. text-align: center;
  164. color: white;
  165. margin-bottom: 25px;
  166. letter-spacing: 1px;
  167. font-size: 20px;
  168. text-shadow: white 0px 0px 0px;
  169. }
  170. #welcomeDescription {
  171. font-family: 'Avenir Book';
  172. text-align: center;
  173. color: white;
  174. font-size: 14px;
  175. font-weight: 100;
  176. text-shadow: rgba(255, 255, 255, 0.75) 0px 0px 20px
  177. }
  178. /* Login button styles. */
  179. #welcomeButton {
  180. background: none;
  181. color: #fff;
  182. font-weight: bold;
  183. font-family: 'Avenir Book';
  184. letter-spacing: 2px;
  185. border: none;
  186. padding: 15px 5px;
  187. margin: 10px 0px;
  188. cursor: pointer;
  189. position: relative;
  190. right: -20px;
  191. transition: 0.5s ease;
  192. margin-top: 5%;
  193. margin-bottom: -5%;
  194. }
  195. #welcomeButton:disabled {
  196. color: rgba(255, 255, 255, 0.75);
  197. pointer-events: none;
  198. }
  199. #welcomeButton:hover,
  200. #welcomeButton:focus {
  201. text-shadow: 0px 0px 20px #fff;
  202. outline: none;
  203. }
  204. #welcomeButton:active {
  205. color: #c7c7c7;
  206. text-shadow: 0px 0px 20px #c7c7c7;
  207. }
  208. #welcomeSVG {
  209. -webkit-transform: translate3d(0, 0, 0);
  210. overflow: visible;
  211. transform: rotate(90deg);
  212. margin-left: 20px;
  213. transition: 0.25s ease;
  214. width: 20px;
  215. height: 20px;
  216. }
  217. #welcomeButton:hover #welcomeSVG,
  218. #welcomeButton:focus #welcomeSVG {
  219. -webkit-filter: drop-shadow(0px 0px 2px #fff);
  220. }
  221. #welcomeButton:active #welcomeSVG .arrowLine {
  222. stroke: #c7c7c7;
  223. }
  224. #welcomeButton:active #welcomeSVG {
  225. -webkit-filter: drop-shadow(0px 0px 2px #c7c7c7);
  226. }
  227. #welcomeButton:disabled #welcomeSVG .arrowLine {
  228. stroke: rgba(255, 255, 255, 0.75);
  229. }
  230. #welcomeButtonContent {
  231. display: flex;
  232. align-items: center;
  233. }
  234. /*******************************************************************************
  235. * *
  236. * Login View (login.ejs) *
  237. * *
  238. ******************************************************************************/
  239. /* Login span styles. */
  240. .loginSpan {
  241. font-family: 'Avenir Book';
  242. font-size: 14px;
  243. color: #fff;
  244. font-weight: bold;
  245. }
  246. /* Styles for dimmer login span. */
  247. .loginSpanDim {
  248. font-family: 'Avenir Book';
  249. font-size: 12px;
  250. color: #848484;
  251. font-weight: bold;
  252. }
  253. /* Main login container. */
  254. #loginContainer {
  255. position: relative;
  256. display: flex;
  257. justify-content: center;
  258. align-items: center;
  259. height: 100%;
  260. width: 100%;
  261. transition: filter 0.25s ease;
  262. }
  263. /* Login content wrapper. */
  264. #loginContent {
  265. display: flex;
  266. justify-content: center;
  267. align-items: center;
  268. height: 100%;
  269. padding: 0px 25px;
  270. }
  271. /* Login form. */
  272. #loginForm {
  273. display: flex;
  274. flex-direction: column;
  275. justify-content: center;
  276. align-items: center;
  277. }
  278. /* Login form anchor styles. */
  279. #loginForm a {
  280. font-family: 'Avenir Book';
  281. font-size: 12px;
  282. color: #848484;
  283. font-weight: bold;
  284. text-decoration: none;
  285. transition: 0.25s ease;
  286. }
  287. #loginForm a:hover,
  288. #loginForm a:focus {
  289. color: #a2a2a2;
  290. outline: none;
  291. }
  292. #loginForm a:active {
  293. color: #8b8b8b;
  294. }
  295. /* Logo on login form. */
  296. #loginImageSeal {
  297. border-radius: 50%;
  298. border: 2px solid #cad7e1;
  299. background: rgba(1, 2, 1, 0.5);
  300. height: 125px;
  301. width: 125px;
  302. box-shadow: 0px 0px 10px 0px rgb(0, 0, 0);
  303. margin-bottom: 20px;
  304. }
  305. /* Header on login view. */
  306. #loginSubheader {
  307. font-family: 'Avenir Medium';
  308. margin-bottom: 25px;
  309. font-size: 12px;
  310. letter-spacing: 1px;
  311. }
  312. /* Container to organize login field elements. */
  313. .loginFieldContainer {
  314. position: relative;
  315. display: flex;
  316. flex-direction: column;
  317. justify-content: center;
  318. align-items: center;
  319. }
  320. /* SVG icons on the login view. */
  321. .loginSVG {
  322. fill: #fff;
  323. height: 20px;
  324. width: 20px;
  325. }
  326. /* Span which displays errors related to login field content. */
  327. .loginErrorSpan {
  328. font-family: 'Avenir Medium';
  329. font-weight: bold;
  330. font-size: 8px;
  331. color: #ff1b0c;
  332. width: 100%;
  333. text-align: right;
  334. position: absolute;
  335. top: 7px;
  336. opacity: 0;
  337. transition: 0.25s ease;
  338. }
  339. .shake {
  340. animation: shake 0.82s cubic-bezier(.36,.07,.19,.97) both;
  341. }
  342. @keyframes shake {
  343. 10%, 90% {
  344. transform: translate3d(-1px, 0, 0);
  345. }
  346. 20%, 80% {
  347. transform: translate3d(2px, 0, 0);
  348. }
  349. 30%, 50%, 70% {
  350. transform: translate3d(-4px, 0, 0);
  351. }
  352. 40%, 60% {
  353. transform: translate3d(4px, 0, 0);
  354. }
  355. }
  356. /* Login text input styles. */
  357. .loginField {
  358. font-family: 'Avenir Book';
  359. background: none;
  360. border-width: 1.5px 0px 0px 0px;
  361. border-style: solid;
  362. width: 250px;
  363. margin-bottom: 20px;
  364. border-color: #fff;
  365. color: rgba(255, 255, 255, 0.75);
  366. font-weight: bold;
  367. text-align: center;
  368. box-sizing: border-box;
  369. padding: 7.5px;
  370. font-size: 10px;
  371. letter-spacing: 1px;
  372. }
  373. .loginField:focus {
  374. outline: none;
  375. }
  376. .loginField:disabled {
  377. color: rgba(255, 255, 255, 0.50);
  378. }
  379. .loginField::-webkit-input-placeholder {
  380. color: rgba(255, 255, 255, 0.75);
  381. font-size: 10px;
  382. letter-spacing: 1px;
  383. text-align: center;
  384. font-weight: bold;
  385. }
  386. .loginField:focus::-webkit-input-placeholder {
  387. color: transparent;
  388. }
  389. /* Add spacing between password field and options bar. */
  390. #labelPassword {
  391. margin-bottom: 13px;
  392. }
  393. /* Container which contains the forgot and remember options. */
  394. #loginOptions {
  395. display: flex;
  396. justify-content: space-between;
  397. width: 100%;
  398. }
  399. /* Remember option text. */
  400. #loginRememberText {
  401. padding-right: 10px;
  402. transition: 0.25s ease;
  403. }
  404. /* Login button styles. */
  405. #loginButton {
  406. background: none;
  407. color: #fff;
  408. font-weight: bold;
  409. font-family: 'Avenir Book';
  410. letter-spacing: 2px;
  411. border: none;
  412. padding: 15px 5px;
  413. margin: 10px 0px;
  414. cursor: pointer;
  415. position: relative;
  416. right: -20px;
  417. transition: 0.5s ease;
  418. }
  419. #loginButton:disabled {
  420. color: rgba(255, 255, 255, 0.75);
  421. pointer-events: none;
  422. }
  423. #loginButton[loading] {
  424. color: #fff;
  425. }
  426. #loginButton:hover,
  427. #loginButton:focus {
  428. text-shadow: 0px 0px 20px #fff;
  429. outline: none;
  430. }
  431. #loginButton:active {
  432. color: #c7c7c7;
  433. text-shadow: 0px 0px 20px #c7c7c7;
  434. }
  435. #loginSVG {
  436. -webkit-transform: translate3d(0, 0, 0);
  437. overflow: visible;
  438. transform: rotate(90deg);
  439. margin-left: 20px;
  440. transition: 0.25s ease;
  441. width: 20px;
  442. height: 20px;
  443. }
  444. #loginButton:hover #loginSVG,
  445. #loginButton:focus #loginSVG {
  446. -webkit-filter: drop-shadow(0px 0px 2px #fff);
  447. }
  448. #loginButton:active #loginSVG .arrowLine {
  449. stroke: #c7c7c7;
  450. }
  451. #loginButton:active #loginSVG {
  452. -webkit-filter: drop-shadow(0px 0px 2px #c7c7c7);
  453. }
  454. #loginButton:disabled #loginSVG .arrowLine {
  455. stroke: rgba(255, 255, 255, 0.75);
  456. }
  457. #loginButtonContent {
  458. display: flex;
  459. align-items: center;
  460. }
  461. #loginButton .circle-loader,
  462. #loginButton[loading] #loginSVG {
  463. display: none;
  464. }
  465. #loginButton[loading] .circle-loader,
  466. #loginButton #loginSVG {
  467. display: initial;
  468. }
  469. .circle-loader {
  470. margin-left: 20px;
  471. border: 2px solid rgba(255, 255, 255, 0.5);
  472. border-left-color: #ffffff;
  473. animation-name: loader-spin;
  474. animation-duration: 1s;
  475. animation-iteration-count: infinite;
  476. animation-timing-function: linear;
  477. position: relative;
  478. display: inline-block;
  479. vertical-align: top;
  480. border-radius: 50%;
  481. width: 16px;
  482. height: 16px;
  483. }
  484. .load-complete {
  485. animation: none;
  486. border-color: #ffffff;
  487. transition: border 500ms ease-out;
  488. }
  489. .checkmark {
  490. display: none;
  491. }
  492. .checkmark.draw:after {
  493. animation-duration: 800ms;
  494. animation-timing-function: ease;
  495. animation-name: checkmark;
  496. transform: scaleX(-1) rotate(135deg);
  497. }
  498. .checkmark:after {
  499. opacity: 1;
  500. height: 8px;
  501. width: 4px;
  502. transform-origin: left top;
  503. border-right: 2px solid #ffffff;
  504. border-top: 2px solid #ffffff;
  505. content: '';
  506. left: 2px;
  507. top: 8px;
  508. position: absolute;
  509. }
  510. @keyframes loader-spin {
  511. 0% {
  512. transform: rotate(0deg);
  513. }
  514. 100% {
  515. transform: rotate(360deg);
  516. }
  517. }
  518. @keyframes checkmark {
  519. 0% {
  520. height: 0;
  521. width: 0;
  522. opacity: 1;
  523. }
  524. 20% {
  525. height: 0;
  526. width: 4px;
  527. opacity: 1;
  528. }
  529. 40% {
  530. height: 8px;
  531. width: 4px;
  532. opacity: 1;
  533. }
  534. 100% {
  535. height: 8px;
  536. width: 4px;
  537. opacity: 1;
  538. }
  539. }
  540. /*.spinningCircle {
  541. margin-left: 20px;
  542. height: 16px;
  543. width: 16px;
  544. border-radius: 50%;
  545. border: 2px solid rgba(255,255,255,0);
  546. border-top-color: #ffffff;
  547. border-right-color: #ffffff;
  548. border-left-color: rgba(255, 255, 255, 0.50);
  549. border-bottom-color: rgba(255, 255, 255, 0.50);
  550. animation: single2 4s infinite linear;
  551. }
  552. @keyframes single2 {
  553. 0% {
  554. transform: rotate(0deg);
  555. }
  556. 100% {
  557. transform: rotate(720deg);
  558. }
  559. }*/
  560. /* Disclaimer container. */
  561. #loginDisclaimer {
  562. display: flex;
  563. flex-direction: column;
  564. justify-content: center;
  565. align-items: center;
  566. }
  567. /* Add spacing between register anchor and disclaimer. */
  568. #loginRegisterSpan {
  569. margin-bottom: 5px;
  570. }
  571. /* Disclaimer text styles. */
  572. .loginDisclaimerText {
  573. font-family: 'Avenir Book';
  574. font-size: 7px;
  575. color: #848484;
  576. font-weight: bold;
  577. text-align: center;
  578. }
  579. /* * *
  580. * Login View | Custom Checkbox
  581. * * */
  582. /* Checkbox container. */
  583. #checkmarkContainer {
  584. display: flex;
  585. justify-content: flex-end;
  586. align-items: center;
  587. position: relative;
  588. cursor: pointer;
  589. font-size: 22px;
  590. -webkit-user-select: none;
  591. }
  592. /* Hide the default checkbox. */
  593. #checkmarkContainer input {
  594. opacity: 0;
  595. cursor: pointer;
  596. position: absolute;
  597. }
  598. /* Create a custom checkbox. */
  599. .loginCheckmark {
  600. position: relative;
  601. height: 10px;
  602. width: 10px;
  603. border: 1px solid #848484;
  604. border-radius: 1px;
  605. background: none;
  606. transition: 0.25s ease;
  607. }
  608. /* On hover and focus, add a grey border color. */
  609. #checkmarkContainer:hover input ~ *,
  610. #checkmarkContainer input:focus ~ * {
  611. color: #a2a2a2;
  612. border-color: #a2a2a2;
  613. }
  614. /* On keydown, darken the checkbox a bit. */
  615. #checkmarkContainer input:active ~ *:not(#loginRememberText) {
  616. color: #8d8d8d;
  617. border-color: #8d8d8d;
  618. }
  619. #checkmarkContainer[disabled] {
  620. pointer-events: none;
  621. }
  622. /* For checked -> #checkmarkContainer input:checked ~ * */
  623. /* Create the checkmark/indicator (hidden when not checked). */
  624. .loginCheckmark:after {
  625. content: "";
  626. display: none;
  627. }
  628. /* Show the checkmark when checked. */
  629. #checkmarkContainer input:checked ~ .loginCheckmark:after {
  630. display: block;
  631. }
  632. /* Style the checkmark/indicator. */
  633. #checkmarkContainer .loginCheckmark:after {
  634. position: absolute;
  635. left: 3.5px;
  636. top: 0.5px;
  637. width: 2px;
  638. height: 6px;
  639. border: solid #a2a2a2;
  640. border-width: 0 2px 2px 0;
  641. transform: rotate(45deg);
  642. }
  643. /* * *
  644. * Login View | Loader
  645. * * */
  646. /* Will reuse this elsewhere down the line.
  647. #loginLoading {
  648. position: absolute;
  649. display: flex;
  650. align-items: center;
  651. justify-content: center;
  652. width: 100%;
  653. height: 100%;
  654. background: rgba(0, 0, 0, 0.80);
  655. }
  656. #loginLoadingContent {
  657. position: relative;
  658. display: flex;
  659. flex-direction: column;
  660. align-items: center;
  661. justify-content: center;
  662. }
  663. #loadSpinnerContainer {
  664. position: relative;
  665. display: flex;
  666. align-items: center;
  667. justify-content: center;
  668. }
  669. #loadCenterImage {
  670. position: absolute;
  671. width: 200px;
  672. height: auto;
  673. }
  674. #loadSpinnerImage {
  675. width: 280px;
  676. height: auto;
  677. }
  678. #loadDescText {
  679. color: #f1eada;
  680. font-family: 'Avenir Medium';
  681. font-weight: bold;
  682. letter-spacing: 1px;
  683. font-size: 16px;
  684. }
  685. @keyframes rotating {
  686. from {
  687. transform: rotate(0deg);
  688. }
  689. to {
  690. transform: rotate(360deg);
  691. }
  692. }
  693. .rotating {
  694. animation: rotating 10s linear infinite;
  695. }*/
  696. /*
  697. #login_filter {
  698. height: calc(100% - 22px);
  699. width: 100%;
  700. z-index: 9000;
  701. position: absolute;
  702. filter: blur(8px) contrast(0.9) brightness(1.0);
  703. background: url('./../images/backgrounds/0.jpg') no-repeat center center fixed;
  704. transform: scale(1.2);
  705. background-size: cover;
  706. }
  707. */
  708. /*******************************************************************************
  709. * *
  710. * Landing View (Structural Styles) *
  711. * *
  712. ******************************************************************************/
  713. /* Main content container. */
  714. #landingContainer {
  715. height: 100%;
  716. }
  717. /* Upper content container. */
  718. #landingContainer > #upper {
  719. height: 77%;
  720. display: flex;
  721. }
  722. #landingContainer > #upper > #left {
  723. display: inline-flex;
  724. width: 15%;
  725. height: 100%;
  726. justify-content: flex-end;
  727. }
  728. #landingContainer > #upper > #content {
  729. display: inline-flex;
  730. width: 59%;
  731. height: 100%;
  732. }
  733. #landingContainer > #upper > #right {
  734. display: inline-flex;
  735. width: 26%;
  736. height: 100%;
  737. }
  738. /* Lower content container. */
  739. #landingContainer > #lower {
  740. height: 23%;
  741. display: flex;
  742. background: linear-gradient(to top, rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0));
  743. }
  744. #landingContainer > #lower > #left {
  745. height: 100%;
  746. width: 33%;
  747. display: inline-flex;
  748. justify-content: center;
  749. }
  750. #landingContainer > #lower > #left #content {
  751. position: relative;
  752. top: 25px;
  753. display: inline-flex;
  754. line-height: 24px;
  755. left: 50px;
  756. }
  757. #landingContainer > #lower > #center {
  758. height: 100%;
  759. width: 34%;
  760. display: inline-flex;
  761. justify-content: center;
  762. }
  763. #landingContainer > #lower > #center #content {
  764. position: relative;
  765. top: 10px;
  766. }
  767. #landingContainer > #lower > #right {
  768. height: 100%;
  769. width: 33%;
  770. display: inline-flex;
  771. }
  772. /*******************************************************************************
  773. * *
  774. * Landing View (Top Styles) *
  775. * *
  776. ******************************************************************************/
  777. /* * *
  778. * Landing View (Top Styles) | Left Content
  779. * * */
  780. /* Logo image. */
  781. #image_seal {
  782. height: 70px;
  783. width: auto;
  784. position: relative;
  785. margin-top: 50px;
  786. border: 2px solid white;
  787. border-radius: 50%;
  788. box-shadow: 0px 0px 10px 0px rgb(0, 0, 0);
  789. }
  790. /* * *
  791. * Landing View (Bottom Styles) | Right Content
  792. * * */
  793. /* Wrapper container for top, right content. */
  794. #rightContainer {
  795. display: flex;
  796. flex-direction: column;
  797. position: relative;
  798. top: 50px;
  799. align-items: flex-end;
  800. height: calc(100% - 50px);
  801. }
  802. /* Right hand user content container. */
  803. #user_content {
  804. display: flex;
  805. align-items: center;
  806. justify-content: center;
  807. box-sizing: border-box;
  808. height: 75px;
  809. }
  810. /* User profile avatar container. */
  811. #avatarContainer {
  812. border-radius: 50%;
  813. border: 2px solid #cad7e1;
  814. background: rgba(1, 2, 1, 0.5);
  815. height: 70px;
  816. width: 70px;
  817. box-shadow: 0px 0px 10px 0px rgb(0, 0, 0);
  818. overflow: hidden;
  819. position: relative;
  820. }
  821. /* Avatar edit overlay. */
  822. #avatarOverlay {
  823. opacity: 0;
  824. position: absolute;
  825. z-index: 1;
  826. top: 0;
  827. bottom: 0;
  828. left: 0;
  829. right: 0;
  830. display: flex;
  831. justify-content: center;
  832. align-items: center;
  833. font-family: 'Avenir Book';
  834. color: #fff;
  835. transition: 0.25s ease;
  836. font-weight: bold;
  837. letter-spacing: 2px;
  838. background: linear-gradient(65deg, rgba(0, 0, 0, 0.4), rgba(136, 77, 77, 0.4) 60%);
  839. -webkit-user-select: none;
  840. cursor: pointer;
  841. }
  842. #avatarOverlay:hover {
  843. opacity: 1;
  844. }
  845. /* User profile avater image. */
  846. #avatarImage {
  847. height: 100%;
  848. width: auto;
  849. }
  850. /* User profile name text. */
  851. #user_text {
  852. font-family: 'Avenir Book';
  853. font-size: 12px;
  854. min-width: 112px;
  855. font-weight: 900;
  856. letter-spacing: 1px;
  857. color: white;
  858. text-shadow: 0px 0px 20px black;
  859. position: relative;
  860. right: 25px;
  861. text-align: right;
  862. }
  863. /* Social media icon content container. */
  864. #mediaContent {
  865. position: relative;
  866. display: flex;
  867. flex-direction: column;
  868. right: 25px;
  869. align-items: flex-end;
  870. margin-top: 40px;
  871. height: 100%;
  872. align-items: center;
  873. }
  874. /* Social Media Icon division containers. */
  875. #internalMedia, #externalMedia {
  876. display: flex;
  877. flex-direction: column;
  878. }
  879. /* Container object which wraps an icon to ensure fluid transitions. */
  880. .mediaContainer {
  881. display: flex;
  882. justify-content: center;
  883. align-items: center;
  884. height: 27px;
  885. }
  886. /* Divider bar between the external and internal icons. */
  887. .mediaDivider {
  888. height: 1px;
  889. width: 14px;
  890. background: rgb(255, 255, 255);
  891. margin: 10px 0px;
  892. }
  893. /* Social media icon shared styles. */
  894. .mediaSVG {
  895. fill: #ffffff;
  896. height: 12px;
  897. transition: 0.25s ease;
  898. cursor: pointer;
  899. height: 12px;
  900. width: 25px;
  901. }
  902. .mediaSVG:hover, .mediaSVG:active {
  903. height: 20px;
  904. }
  905. /* News icon colors. */
  906. #newsSVG {
  907. stroke: #ffffff;
  908. }
  909. /* Twitter icon colors. */
  910. #twitterSVG:hover {
  911. fill: #1da1f2;
  912. }
  913. #twitterSVG:active {
  914. fill: #1b8dd4;
  915. }
  916. /* Instagram icon colors. */
  917. #instagramSVG:hover {
  918. fill: url('#instaFill')
  919. /*fill: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%); */
  920. }
  921. #instagramSVG:active {
  922. fill: url('#instaFill')
  923. }
  924. /* Youtube icon colors. */
  925. #youtubeSVG:hover {
  926. fill: #f00;
  927. }
  928. #youtubeSVG:active {
  929. fill: #ea0202;
  930. }
  931. /* Discord icon colors. */
  932. #discordSVG:hover {
  933. fill: #7288d9;
  934. }
  935. #discordSVG:active {
  936. fill: #657ac4;
  937. }
  938. /*******************************************************************************
  939. * *
  940. * Landing View (Bottom Styles) *
  941. * *
  942. ******************************************************************************/
  943. /* Style for a general label on the bottom of the landing view. */
  944. .bot_label {
  945. color: white;
  946. font-family: 'Avenir Book';
  947. font-size: 9px;
  948. letter-spacing: 1px;
  949. font-weight: bold;
  950. text-shadow: 0px 0px 0px #bebcbb;
  951. }
  952. /* Divider used on the bottom of the landing view. */
  953. .bot_divider {
  954. height: 25px;
  955. width: 2px;
  956. background: rgba(107, 105, 105, 0.7);
  957. margin-left: 20px;
  958. margin-right: 20px;
  959. }
  960. /* * *
  961. * Landing View (Bottom Styles) | Left Content
  962. * * */
  963. /* Span which displays the player count of the selected server. */
  964. #player_count {
  965. color: #949494;
  966. font-family: 'Avenir Book';
  967. font-size: 8px;
  968. font-weight: 900;
  969. text-shadow: 0px 0px 20px #949494;
  970. margin-left: 10px;
  971. }
  972. /* Icon which displays the status of the mojang services. */
  973. #mojang_status_icon {
  974. font-size: 30px;
  975. color: #848484;
  976. margin-left: 15px;
  977. }
  978. /* * *
  979. * Landing View (Bottom Styles) | Center Content
  980. * * */
  981. /* Button which opens the menu view. */
  982. #menu_button {
  983. font-family: 'Avenir Book';
  984. background: none;
  985. border: none;
  986. cursor: pointer;
  987. }
  988. /* Arrow image which floats above the menu button. */
  989. #menu_img {
  990. height: 11px;
  991. margin-left: -2px;
  992. }
  993. /* Span which contains the menu button text. */
  994. #menu_text {
  995. color: white;
  996. font-weight: 900;
  997. letter-spacing: 2px;
  998. text-shadow: 0px 0px 0px #bebcbb;
  999. font-size: 11px;
  1000. line-height: 30px;
  1001. display: flex;
  1002. }
  1003. /* * *
  1004. * Landing View (Bottom Styles) | Right Content
  1005. * * */
  1006. /* Main launch content container. */
  1007. #landingContainer > #lower > #right #launch_content {
  1008. position: relative;
  1009. top: 25px;
  1010. display: inline-flex;
  1011. line-height: 24px;
  1012. }
  1013. /* The launch button. */
  1014. #launch_button {
  1015. font-family: 'Avenir Book';
  1016. background: none;
  1017. border: none;
  1018. cursor: pointer;
  1019. color: #fff;
  1020. font-weight: 900;
  1021. letter-spacing: 2px;
  1022. text-shadow: 0px 0px 0px #bebcbb;
  1023. font-size: 20px;
  1024. padding: 0px;
  1025. }
  1026. /* Launch details main container, hidden until launch processing begins. */
  1027. #launch_details {
  1028. position: relative;
  1029. top: 25px;
  1030. display: none;
  1031. }
  1032. /* Left side of launch details container, displays percentage and a divider. */
  1033. #launch_details_left {
  1034. display: flex;
  1035. }
  1036. /* Span which displays percentage complete. */
  1037. #launch_progress_label {
  1038. color: white;
  1039. font-family: 'Avenir Book';
  1040. font-weight: 900;
  1041. letter-spacing: 1px;
  1042. text-shadow: 0px 0px 0px #bebcbb;
  1043. font-size: 20px;
  1044. min-width: 53.21px;
  1045. max-width: 53.21px;
  1046. text-align: right;
  1047. }
  1048. /* Right side of launch details container, displays progress bar and details. */
  1049. #launch_details_right {
  1050. display: flex;
  1051. flex-direction: column;
  1052. justify-content: center;
  1053. }
  1054. /* Progress bar styles. */
  1055. #launch_progress[value] {
  1056. height: 3px;
  1057. width: 265px;
  1058. -webkit-appearance: none;
  1059. }
  1060. #launch_progress[value]::-webkit-progress-bar {
  1061. background-color: transparent;
  1062. }
  1063. #launch_progress[value]::-webkit-progress-value {
  1064. background-color: #fff;
  1065. }
  1066. /* Span which displays information about the status of the launch process. */
  1067. #launch_details_text {
  1068. font-size: 11px;
  1069. text-overflow: ellipsis;
  1070. white-space: nowrap;
  1071. overflow: hidden;
  1072. }
  1073. /*******************************************************************************
  1074. * *
  1075. * Overlay View (app.ejs) *
  1076. * *
  1077. ******************************************************************************/
  1078. #overlayContainer {
  1079. position: absolute;
  1080. top: 22px;
  1081. display: flex;
  1082. align-items: center;
  1083. justify-content: center;
  1084. width: 100%;
  1085. height: calc(100% - 22px);
  1086. background: rgba(0, 0, 0, 0.50);
  1087. }
  1088. #overlayContent {
  1089. position: relative;
  1090. display: flex;
  1091. flex-direction: column;
  1092. align-items: center;
  1093. /*justify-content: space-between;*/
  1094. width: 300px;
  1095. /*height: 35%;*/
  1096. box-sizing: border-box;
  1097. padding: 15px 0px;
  1098. /* background-color: #424242; */
  1099. text-align: center;
  1100. }
  1101. #overlayContent a {
  1102. color: rgba(202, 202, 202, 0.75);
  1103. transition: 0.25s ease;
  1104. }
  1105. #overlayContent a:hover {
  1106. color: rgba(255, 255, 255, 0.75);
  1107. }
  1108. #overlayContent a:active {
  1109. color: rgba(165, 165, 165, 0.75);
  1110. }
  1111. #overlayContent > *:first-child {
  1112. margin-top: 0px !important;
  1113. }
  1114. #overlayContent > *:last-child {
  1115. margin-bottom: 0px !important;
  1116. }
  1117. #overlayContent > * {
  1118. margin: 8px 0px;
  1119. }
  1120. #overlayTitle {
  1121. font-family: 'Avenir Medium';
  1122. font-size: 20px;
  1123. color: #fff;
  1124. font-weight: bold;
  1125. letter-spacing: 1px;
  1126. }
  1127. #overlayDesc {
  1128. font-family: 'Avenir Book';
  1129. font-size: 12px;
  1130. color: #fff;
  1131. font-weight: bold;
  1132. }
  1133. #overlayAcknowledge {
  1134. background: none;
  1135. border: 1px solid #ffffff;
  1136. color: white;
  1137. font-family: 'Avenir Medium';
  1138. font-weight: bold;
  1139. border-radius: 2px;
  1140. padding: 0px 8.1px;
  1141. cursor: pointer;
  1142. transition: 0.25s ease;
  1143. }
  1144. #overlayAcknowledge:hover,
  1145. #overlayAcknowledge:focus {
  1146. box-shadow: 0px 0px 10px 0px #fff;
  1147. outline: none;
  1148. }
  1149. #overlayAcknowledge:active {
  1150. border-color: rgba(255, 255, 255, 0.75);
  1151. color: rgba(255, 255, 255, 0.75);
  1152. }