X-Git-Url: https://git.rapsys.eu/airbundle/blobdiff_plain/da015abd850ca09b6da4c0a282f9c610f1dfcce0..d7d9568d591148592db2ef8925d46a0c96cadb7b:/Resources/public/css/screen.css diff --git a/Resources/public/css/screen.css b/Resources/public/css/screen.css index ee9eb27..6d7d54c 100644 --- a/Resources/public/css/screen.css +++ b/Resources/public/css/screen.css @@ -1,6 +1,6 @@ /* Reset link */ a { - text-decoration: none; + /*text-decoration: none;*/ color: #066; } @@ -38,41 +38,92 @@ dt, h1, h2, h3, h4, h5, h6, label, legend, th, details { /* Default styling */ h1 { font-size: 2rem; - margin: 1.34rem 0; } h2 { font-size: 1.5rem; - margin: 1.245rem 0; + margin: 0 0 .5rem; + padding: .5rem; } h3 { font-size: 1.17rem; - margin: 1.17rem 0; + margin: 0 0 .5rem; + padding: .4rem; } h4 { font-size: 1rem; - margin: 1.33rem 0; + margin: 0 0 .5rem; + padding: .3rem; } h5 { font-size: .85rem; - margin: 1.386rem 0; + margin: 0 0 .5rem; + padding: .2rem; } h6 { font-size: .67rem; - margin: 1.561rem 0; + margin: 0 0 .5rem; + padding: .1rem; +} + +header { + margin: 0 0 .5rem; +} + +header h2 { + margin: 0; + padding: .5rem .5rem .3rem; + border-bottom: 0 none; +} + +nav strong { + display: block; + font-size: 1.17rem; + margin: 0 0 .5rem; + padding: .4rem; +} + +h2, h3, h4, h5, header, nav strong { + background-color: #cff; + border-bottom: .1rem solid #00c3f9; +} + +strong { + font-weight: bold; +} + +p { + margin: 0 .5rem .3rem; + font-size: .9rem; +} + +pre { + margin: 0 .5rem .3rem; + font-size: .8rem; +} + +dl { + margin: 0 .5rem .5rem; +} + +dl:first-child, +dl:only-child, +dl:first-of-type { + margin-top: .5rem; } -p, dt { - font-size: 1rem; + font-size: .9rem; + font-weight: bold; } dd { font-size: .9rem; + margin-left: 1rem; } body { @@ -81,6 +132,33 @@ body { color: #066; } +nav, +section, +article { + margin: 0 .5rem .5rem; + border: .1rem solid #00c3f9; + border-radius: .3rem; +} + +ul { + display: grid; + margin: 0 .5rem .3rem; + font-size: .9rem; + list-style: ' - ' inside none; + gap: .3rem; +} + +nav ul { + list-style: none inside none; + margin-bottom: .5rem; + gap: .5rem; +} + +nav ul ul { + margin-top: .5rem; + margin-bottom: 0; +} + /* Form */ label { font-size: .8rem; @@ -98,25 +176,26 @@ textarea { font-size: .75rem; color: #066; background-color: transparent; + box-sizing: border-box; } form { display: flex; flex-direction: column; flex-wrap: wrap; - line-height: normal; + margin: 0 .5rem .5rem; text-align: center; } -form header { - margin-bottom: .5rem; -} - -form header .message { - margin: 0; +form .row { + flex-direction: row; } form div { + display: flex; + align-content: space-around; + justify-content: center; + flex-direction: column; margin-bottom: .5rem; } @@ -126,21 +205,9 @@ form div:last-of-type { margin-bottom: 0; } -form section div { - display: flex; - flex-direction: row; - align-content: space-around; - justify-content: center; -} - -form section section { - display: flex; - flex-direction: column; -} - form label { width: 12rem; - padding: .2rem 1rem .2rem 0; + padding-right: 1rem; text-align: right; } @@ -148,103 +215,119 @@ form input, form option, form optgroup, form select, -form textarea { +form textarea, +form section section { width: 24rem; padding: .1rem; + margin: 0 auto; } form select { - box-sizing: content-box; padding: 0 .1rem .1rem .1rem; } form button { width: 10rem; - margin: .5rem auto 0 auto; + /*margin: .5rem auto 0 auto;*/ + margin: 0 auto; padding: 0 .1rem .2rem .1rem; } -form section .message { +form .message { + margin: 0 0 .5rem 0; +} + +form div .message { margin: .25rem 0 0 0; } /* Vertical form */ -form.col label { +.col label { width: 8rem; - padding: .2rem 0; + padding-right: 0; + padding-bottom: .2rem; text-align: center; + margin: 0 auto; } -form.col input, -form.col option, -form.col optgroup, -form.col select, -form.col textarea { +.col input, +.col option, +.col optgroup, +.col select, +.col textarea { width: 8rem; } -form.col button { +.col button { width: 8rem; } -form.col div { +.col .row { flex-direction: column; } -form.col div.date { +.col div.date { flex-direction: row; justify-content: space-between; } /* Header */ #header { + background-color: transparent; border: .1rem solid #00c3f9; border-top: 0; border-radius: 0 0 .5rem .5rem; - margin: .5rem; - margin-top: 0; - padding: .5rem; - left: 0; - right: 0; + margin: 0 .5rem .5rem; display: flex; + flex-direction: row; + flex-wrap: nowrap; justify-content: space-between; - min-width: 180px; + line-height: 32px; + font-size: 32px; + padding: .5rem; + gap: .5rem; } #header h1 { - order: 0; padding: 0; - margin: 0; - vertical-align: middle; + margin: auto; white-space: nowrap; + width: 171px; + height: 32px; } -#header h1 a { - display: flex; +#header h2 { + display: none; } #header nav { - order: 3; - margin-left: auto; display: flex; + flex: 1 1 auto; + border-style: none; + margin: 0; +} + +#header ul { + display: flex; + flex: 1 1 auto; flex-direction: row; flex-wrap: wrap; - align-items: center; - justify-content: flex-end; + margin: 0; + gap: .5rem; } -#header nav h2 { - display: none; +#header li { + display: flex; + flex: 1 1 auto; + border-radius: .2rem; + border: .1rem solid #00c3f9; + background-color: #cff; + justify-content: center; } -#header nav a { +#header ul a { text-align: center; - border-radius: .25rem; - padding: .375rem .5rem .25rem .5rem; - margin: 0 0 .1rem .5rem; - border: .1rem solid #00c3f9; font-weight: bold; - background-color: #cff; } /* Message */ @@ -262,13 +345,30 @@ form.col div.date { .message::before, .message::after { - line-height: 100%; margin: auto 0; padding: 0 .25rem; } -p.message { +.message ul { margin: 0; + list-style: none inside none; + gap: .1rem; +} + +.mortal, +.mortal button, +.mortal select { + /*border-color: #c33333; + color: #c33333;*/ + border-color: #930; + background-color: #f9c3c3; + color: #930; +} + +.dangerous, +.mortal { + border-radius: .2rem; + padding: .5rem 0; } .error { @@ -299,6 +399,17 @@ p.message { /*content: "⌘";*/ } +.dangerous, +.dangerous button, +.dangerous select { + /*border-color: #c39333; + background-color: #f9c333; + color: #936333;*/ + border-color: #930; + background-color: #fc9; + color: #930; +} + .warning { border-color: #c39333; background-color: #f9c333; @@ -316,304 +427,264 @@ p.message { /* Dashboard */ #dashboard, -#regulation, -#form { - border: .1rem solid #00c3f9; +#form, +#recover, +#regulation { border-radius: .5rem; + /*border: .1rem solid #00c3f9; margin: .5rem; margin-top: 0; - overflow: hidden; - padding: .5rem; display: flex; - flex-direction: column; + flex-direction: column;*/ } -#dashboard h2, -#regulation h2, -#form h2 { - background-color: #cff; - border-bottom: .1rem solid #00c3f9; - margin: -.5rem; - margin-bottom: .5rem; - padding: .5rem; - padding-bottom: .5rem; +.panel { + display: flex; + flex-direction: row; + margin: 0 .5rem .5rem; + gap: .5rem; } -#dashboard h3 { - background-color: #cff; +.grid { + display: grid; + border-style: solid; + border-color: #00c3f9; + border-radius: .2rem; + box-sizing: border-box; + border-collapse: collapse; + grid-gap: .1rem; + flex: 1 1 auto; +} + +.grid article, +.grid section { + border-collapse: inherit; + border-color: inherit; + border-radius: inherit; + border-style: inherit; + border-width: .1rem; + box-sizing: inherit; + flex-grow: inherit; margin: 0; - margin: -.3rem -.1rem; - margin-bottom: .3rem; - padding: .3rem; - border-bottom: .1rem solid #00c3f9; + min-height: 5rem; + overflow: hidden; } -#dashboard h4 { - background-color: #cff; +.grid h3 { margin: 0; - padding: .3rem; - border-bottom: .1rem solid #00c3f9; + overflow: hidden; + text-overflow: ellipsis; + white-space: nowrap; } -#form .recover { - border: .1rem solid #00c3f9; - border-radius: .3rem; - margin-top: 1rem; - padding: .5rem; +.grid ul { + display: block; + margin: .1rem; + font-size: .8rem; + list-style: none inside none; } -#form h3 { - background-color: #cff; - margin: -.5rem; - margin-bottom: .5rem; - padding: .3rem; +.grid li { + border-width: .1rem; + border-style: solid; + border-radius: .2rem; + white-space: nowrap; + padding: .1rem; + display: flex; + margin: 0 0 .1rem; + flex-direction: row; + justify-content: space-between; } -#form h3, -#dashboard h3, -#dashboard h4 { +.grid li a:first-letter { + color: inherit; } -#dashboard .location h3 { +/*XXX: required by ul display:block for overflow:hidden*/ +.grid li:only-child, +.grid li:last-child, +.grid li:last-of-type { margin: 0; - border-bottom: 0; } -#dashboard .location .cell { - padding: 0; +.grid a { + overflow-x: hidden; + text-overflow: ellipsis; } -/*#dashboard .calendar h3 { - margin: -.3rem; - margin-bottom: .3rem; -}*/ - -#dashboard .subgrid .cell { - padding: .3rem; +.grid p { + margin: 0 0 .3rem; } -#dashboard .subgrid h4 { - margin: -.3rem; - margin-bottom: .3rem; +.grid p:only-child, +.grid p:last-child, +.grid p:last-of-type { + margin: 0; } -/*#dashboard h4 { - background-color: #cff; - border-bottom: .1rem solid #00c3f9; - margin: -.5rem; - margin-bottom: .5rem; - padding: .1rem; -}*/ - -#dashboard .panel { - display: flex; - flex-direction: row; - flex-wrap: nowrap; - place-content: space-between; - border: 0; - margin: 0 0 .5rem 0; - padding: 0; +.current, +.current h3 { + background-color: #cfc; + border-color: #008000; + color: #008000; } -#dashboard .panel:only-child, -#dashboard .panel:last-child, -#dashboard .panel:last-of-type { - margin-bottom: 0; +.current h3:first-letter { + color: #00b000; } -#dashboard .grid { - display: flex; - flex-flow: row wrap; - border-style: solid; +.granted, +.granted a { + background-color: #cff; border-color: #00c3f9; - border-radius: .2rem; - border-width: .1rem 0 0 .1rem; - line-height: normal; - flex-grow: 1; - box-sizing: inherit; - box-sizing: border-box; - border-collapse: collapse; - /*box-sizing: border-box; - display: table; - line-height: normal; - padding: 0; - flex-grow: 1; - table-layout: fixed; - border: 0 none; - width: fit-content; - border-collapse: collapse;*/ - /*width: calc(100% - 12rem); - border-collapse: collapse;*/ - /*width: calc(100% - 12rem);*/ -} - -#dashboard .grid:only-child, -#dashboard .grid:last-child, -#dashboard .grid:last-of-type { - margin-bottom: 0; } -#dashboard .subgrid { - display: flex; - flex-flow: row wrap; - border-style: solid; - border-color: #00c3f9; - border-width: .1rem 0 0 .1rem; - border-radius: .2rem; - line-height: normal; - flex-grow: 1; - box-sizing: inherit; - box-sizing: border-box; - border-collapse: collapse; - margin: .5rem; +.disputed, +.disputed a { + border-color: #930; + background-color: #fc9; + color: #930; } -#dashboard .subgrid:only-child, -#dashboard .subgrid:last-child, -#dashboard .subgrid:last-of-type { - margin-bottom: 0; +.canceled, +.canceled a, +.canceled h2, +.canceled header { + color: #963; + background-color: #fddddd; + border-color: #963; } -#dashboard .cell { - border-color: inherit; - border-style: inherit; - border-width: 0 .1rem .1rem 0; - border-radius: .2rem; - flex-grow: inherit; - box-sizing: inherit; - border-collapse: inherit; - font-size: .8rem; - padding: .3rem .1rem; +.locked, +.locked a { + border-color: #930; + background-color: #f9c3c3; + color: #930; } -#dashboard .cell:only-child, -#dashboard .cell:last-child, -#dashboard .cell:last-of-type { - border-radius: inherit; +.pending, +.pending a { + background-color: #ccc; + border-color: #066; } -#dashboard .subgrid .cell { - border-radius: 0; - border-width: 0 .1rem .1rem 0; +.highlight, +.highlight a { + border-color: #3333c3; + background-color: #c3c3f9; + color: #3333c3; } -#dashboard .subgrid .cell:only-child, -#dashboard .subgrid .cell:last-child, -#dashboard .subgrid .cell:last-of-type { - border-radius: inherit; + +.disabled { + filter: grayscale(66%); } -#dashboard .fourth { - min-height: 5rem; - width: calc(100% / 4); +.calendar a { + display: grid; + /*grid-template-columns: 1fr auto fit-content(1fr);*/ + grid-template-columns: max-content 1fr max-content; + flex: 1 1 auto; + grid-gap: .1rem; } -#dashboard .seventh { - min-height: 5rem; - width: calc(100% / 7); +.calendar .reducible { + overflow-x: hidden; + text-overflow: ellipsis; + text-align: center; } -#dashboard .third { - min-height: 5rem; - width: calc(100% / 3); +.calendar .info { + line-height: 1rem; + text-align: right; } -#dashboard .session { - border: .1rem solid #00c3f9; - border-radius: .2rem; - padding: .1rem; - margin: .1rem; - overflow-x: hidden; - white-space: nowrap; - text-overflow: ellipsis; +.calendar .pseudonym { + grid-column: span 2; } -#dashboard .session:only-child, -#dashboard .session:last-child, -#dashboard .session:last-of-type { - margin-bottom: 0; +.seven { + grid-template-columns: repeat(7, 1fr); } -#dashboard .disabled { - color: #acc; - background-color: #bee; +.four { + grid-template-columns: repeat(4, 1fr); } -#dashboard .current { - background-color: #cff; +.three { + grid-template-columns: repeat(3, 1fr); } -#dashboard .next { - background-color: #eff; +.two { + grid-template-columns: repeat(2, 1fr); } -#dashboard .pending { - background-color: #ccc; +.location h3 { + border-style: none; + flex: 1 1 auto; + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; } -#dashboard .granted { - background-color: #cff; - /*background-color: #33b679; - border-color: #33b679;*/ +.location p { + margin: 0 .5rem .5rem; } -#dashboard .disputed { - background-color: #fcc; +.location .grid article, +.location .grid section { + min-height: auto; } -#dashboard .orphaned { - background-color: #fc9; +.location form { + margin: .5rem auto; } -#dashboard .highlight { - border-color: #3333c3; - background-color: #c3c3f9; - color: #3333c3; +.location form .row { + flex-direction: column; } -#dashboard .form { - border: .1rem solid #00c3f9; - border-radius: .2rem; - padding: .5rem; - margin-left: .5rem; +.location form div { + margin-left: auto; + margin-right: auto; } -/* Regulation */ -#regulation { +.location label { + width: 20rem; + padding-right: 0; + text-align: center; } -#regulation dl { - /*display: flex; - flex-direction: row; - justify-content: space-around; - padding-bottom: .5rem;*/ - padding: .25rem; - margin-bottom: .5rem; +.location input, +.location textarea { + width: 20rem; + margin: 0 .1rem; } -#regulation dt { - font-size: .9rem; - font-weight: bold; - padding-bottom: .2rem; +.form { + margin: 0; + display: flex; + flex-direction: column; + gap: .5rem; } -#regulation dd { - font-size: .9rem; - margin-left: 1.5rem; +.form h2 { + font-size: 1.17rem; + padding: .4rem; } -#regulation dd:before { +.form a { + white-space: nowrap; } -#regulation dl:only-child, -#regulation dl:last-child, -#regulation dl:last-of-type, -#regulation dt:only-child, -#regulation dt:last-child, -#regulation dt:last-of-type, -#regulation dd:only-child, -#regulation dd:last-child, -#regulation dd:last-of-type { - margin-bottom: 0; +.form section { + margin: 0; + border: .05rem solid #00c3f9; + border-radius: .2rem; + width: 100%; +} + +.form form { + gap: .5rem; } /* Footer */ @@ -630,10 +701,6 @@ p.message { background-color: #cff; } -#footer details { - font-weight: bold; -} - #footer summary::after { display: none; } @@ -642,41 +709,185 @@ p.message { display: none; } -/* viewport responsive hack */ -@media ( max-width: 850px ) { - #header { - flex-wrap: wrap; - } +#footer ul { + list-style: none inside none; + margin: 0; +} - #dashboard .calendar { - place-content: center; - flex-direction: column; - flex-wrap: wrap; +/* viewport responsive hack */ +@media ( max-width: 1400px ) { + .location label, + .location input, + .location textarea { + width: 12rem; } +} - #dashboard .panel:only-child, - #dashboard .panel:last-child, - #dashboard .panel:last-of-type { - margin-bottom: .5rem; +@media ( max-width: 900px ) { + .panel { + flex-flow: column wrap; } - #dashboard .form { - margin: .5rem auto 0 auto; + .form { + flex-direction: row; } form label { width: 6rem; + line-height: 2rem; } form input, form option, form optgroup, form select, - form textarea { + form textarea, + form section section { width: 20rem; + line-height: 2rem; } form button { width: 6rem; + line-height: 2rem; + } + + .col label, + .col input, + .col option, + .col optgroup, + .col select, + .col textarea { + width: 12rem; + } + + .col button { + width: 12rem; + } + + .seven { + grid-template-columns: repeat(4, 1fr); + } + + .calendar .sunday { + grid-column: span 2; + } + + /*.grid section:nth-child(7n) { + grid-column: span 2; + }*/ + + .four { + grid-template-columns: repeat(3, 1fr); + } + + /*#dashboard .seventh:nth-child(7n+1), + #dashboard .seventh:nth-child(7n+2), + #dashboard .seventh:nth-child(7n+3), + #dashboard .seventh:nth-child(7n+4) { + width: calc(100% / 4 - (3/4*.1rem)); + } + + #dashboard .seventh:nth-child(7n+5), + #dashboard .seventh:nth-child(7n+6), + #dashboard .seventh:nth-child(7n+7) { + width: calc(100% / 3 - (2/3*.1rem)); + }*/ +} + +@media ( max-width: 600px ) { + form label { + margin: 0 auto; + } + + form input, + form option, + form optgroup, + form select, + form textarea, + form section section { + width: 14rem; + margin: 0 auto; + } + + #header { + flex-direction: column; + } + + .seven { + grid-template-columns: repeat(2, 1fr); + } + + /*.grid section:nth-child(7n) { + grid-column: span 2; + margin-bottom: .5rem; + } + + .grid section:only-child, + .grid section:last-child, + .grid section:last-of-type { + margin-bottom: 0; + }*/ + + .calendar .sunday { + margin-bottom: .5rem; + } + + .calendar .sunday:only-child, + .calendar .sunday:last-child { + margin-bottom: 0; + } + + .four, + .three { + grid-template-columns: repeat(2, 1fr); + } + + /*#dashboard .seventh:nth-child(n) { + width: calc(100% / 2 - .1rem); + } + + #dashboard .seventh:nth-child(7n) { + width: calc(100%); + }*/ +} + +@media ( max-width: 450px ) { + form .row, + .grid, + .form, + #footer { + flex-direction: column; + } + + .seven { + grid-template-columns: repeat(1, 1fr); + } + + /*.grid section:nth-child(n) { + grid-column: auto; + }*/ + .calendar .sunday { + grid-column: auto; + } + + .four, + .three { + grid-template-columns: repeat(1, 1fr); + } +} + +@media ( max-width: 260px ) { + .col label, + .col input, + .col option, + .col optgroup, + .col select, + .col textarea { + width: 10rem; + } + + .col button { + width: 10rem; } }