2011-11-26 06:34:55 +01:00
|
|
|
// Responsive.less
|
|
|
|
// For phone and tablet devices
|
|
|
|
// -------------------------------------------------------------
|
2011-10-16 12:15:36 +02:00
|
|
|
|
|
|
|
|
2012-01-25 19:02:52 +01:00
|
|
|
// REPEAT VARIABLES & MIXINS
|
|
|
|
// -------------------------
|
|
|
|
// Required since we compile the responsive stuff separately
|
|
|
|
|
|
|
|
@import "variables.less"; // Modify this for custom colors, font-sizes, etc
|
|
|
|
@import "mixins.less";
|
|
|
|
|
|
|
|
|
2011-12-09 20:32:07 +01:00
|
|
|
// RESPONSIVE CLASSES
|
|
|
|
// ------------------
|
|
|
|
|
|
|
|
// Hide from screenreaders and browsers
|
2012-01-28 01:26:55 +01:00
|
|
|
// Credit: HTML5 Boilerplate
|
2011-12-09 20:32:07 +01:00
|
|
|
.hidden {
|
|
|
|
display: none;
|
|
|
|
visibility: hidden;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-01-30 01:35:55 +01:00
|
|
|
|
2011-10-16 20:35:24 +02:00
|
|
|
// UP TO LANDSCAPE PHONE
|
|
|
|
// ---------------------
|
|
|
|
|
2011-10-16 12:15:36 +02:00
|
|
|
@media (max-width: 480px) {
|
2012-01-08 12:00:06 +01:00
|
|
|
|
2012-01-28 09:29:38 +01:00
|
|
|
// Block level the page header small tag for readability
|
|
|
|
.page-header h1 small {
|
|
|
|
display: block;
|
|
|
|
line-height: @baseLineHeight;
|
|
|
|
}
|
|
|
|
|
2012-01-28 23:30:45 +01:00
|
|
|
// Make span* classes full width
|
|
|
|
input[class*="span"],
|
|
|
|
select[class*="span"],
|
|
|
|
textarea[class*="span"],
|
|
|
|
.uneditable-input {
|
|
|
|
display: block;
|
|
|
|
width: 100%;
|
|
|
|
height: 28px; /* Make inputs at least the height of their button counterpart */
|
|
|
|
/* Makes inputs behave like true block-level elements */
|
|
|
|
-webkit-box-sizing: border-box; /* Older Webkit */
|
|
|
|
-moz-box-sizing: border-box; /* Older FF */
|
|
|
|
-ms-box-sizing: border-box; /* IE8 */
|
|
|
|
box-sizing: border-box; /* CSS3 spec*/
|
|
|
|
}
|
|
|
|
// But don't let it screw up prepend/append inputs
|
|
|
|
.input-prepend input[class*="span"],
|
|
|
|
.input-append input[class*="span"] {
|
|
|
|
width: auto;
|
|
|
|
}
|
|
|
|
|
2012-01-28 22:07:01 +01:00
|
|
|
// Update checkboxes for iOS
|
|
|
|
input[type="checkbox"],
|
|
|
|
input[type="radio"] {
|
|
|
|
border: 1px solid #ccc;
|
|
|
|
}
|
|
|
|
|
2011-10-16 20:35:24 +02:00
|
|
|
// Remove the horizontal form styles
|
2012-01-15 06:28:47 +01:00
|
|
|
.form-horizontal .control-group > label {
|
2011-10-16 20:35:24 +02:00
|
|
|
float: none;
|
|
|
|
width: auto;
|
|
|
|
padding-top: 0;
|
|
|
|
text-align: left;
|
|
|
|
}
|
|
|
|
// Move over all input controls and content
|
2012-01-15 06:28:47 +01:00
|
|
|
.form-horizontal .controls {
|
2011-10-16 20:35:24 +02:00
|
|
|
margin-left: 0;
|
|
|
|
}
|
|
|
|
// Move the options list down to align with labels
|
2012-01-15 06:28:47 +01:00
|
|
|
.form-horizontal .control-list {
|
2011-10-16 20:35:24 +02:00
|
|
|
padding-top: 0; // has to be padding because margin collaspes
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
2011-10-16 20:35:24 +02:00
|
|
|
// Move over buttons in .form-actions to align with .controls
|
2012-01-15 06:28:47 +01:00
|
|
|
.form-horizontal .form-actions {
|
2012-01-28 21:58:26 +01:00
|
|
|
padding-left: 10px;
|
|
|
|
padding-right: 10px;
|
2011-10-16 20:35:24 +02:00
|
|
|
}
|
2011-12-27 22:40:58 +01:00
|
|
|
|
|
|
|
// Modals
|
|
|
|
.modal {
|
2012-01-23 22:50:55 +01:00
|
|
|
position: absolute;
|
2012-01-28 09:39:22 +01:00
|
|
|
top: 10px;
|
|
|
|
left: 10px;
|
|
|
|
right: 10px;
|
2011-12-27 22:40:58 +01:00
|
|
|
width: auto;
|
2012-01-23 22:50:55 +01:00
|
|
|
margin: 0;
|
2012-01-08 22:21:44 +01:00
|
|
|
&.fade.in { top: auto; }
|
2011-12-27 22:40:58 +01:00
|
|
|
}
|
2012-01-08 22:21:44 +01:00
|
|
|
.modal-header .close {
|
|
|
|
padding: 10px;
|
2012-01-28 09:39:22 +01:00
|
|
|
margin: -10px;
|
2012-01-08 22:21:44 +01:00
|
|
|
}
|
|
|
|
|
2012-01-28 09:43:25 +01:00
|
|
|
// Carousel
|
|
|
|
.carousel-caption {
|
|
|
|
position: static;
|
|
|
|
}
|
|
|
|
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-01-30 01:35:55 +01:00
|
|
|
|
2011-10-16 20:35:24 +02:00
|
|
|
// LANDSCAPE PHONE TO SMALL DESKTOP & PORTRAIT TABLET
|
|
|
|
// --------------------------------------------------
|
|
|
|
|
2011-12-09 20:32:07 +01:00
|
|
|
@media (max-width: 768px) {
|
2012-01-28 01:26:55 +01:00
|
|
|
// GRID & CONTAINERS
|
|
|
|
// -----------------
|
2011-10-16 12:15:36 +02:00
|
|
|
// Remove width from containers
|
|
|
|
.container {
|
|
|
|
width: auto;
|
2011-12-09 20:32:07 +01:00
|
|
|
padding: 0 20px;
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
2012-01-29 22:06:57 +01:00
|
|
|
// Fluid rows
|
|
|
|
.row-fluid {
|
|
|
|
width: 100%;
|
|
|
|
}
|
2011-10-23 00:49:42 +02:00
|
|
|
// Undo negative margin on rows
|
|
|
|
.row {
|
|
|
|
margin-left: 0;
|
|
|
|
}
|
2011-10-16 12:15:36 +02:00
|
|
|
// Make all columns even
|
2011-12-22 02:31:01 +01:00
|
|
|
.row > [class*="span"] {
|
2011-10-16 12:15:36 +02:00
|
|
|
float: none;
|
|
|
|
display: block;
|
|
|
|
width: auto;
|
|
|
|
margin: 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-01-30 01:35:55 +01:00
|
|
|
|
2011-10-16 20:35:24 +02:00
|
|
|
// PORTRAIT TABLET TO DEFAULT DESKTOP
|
|
|
|
// ----------------------------------
|
2011-10-16 12:15:36 +02:00
|
|
|
|
|
|
|
@media (min-width: 768px) and (max-width: 940px) {
|
|
|
|
|
|
|
|
// Reset grid variables
|
2012-01-29 03:25:05 +01:00
|
|
|
@gridColumns: 12;
|
|
|
|
@gridColumnWidth: 42px;
|
2011-10-16 12:15:36 +02:00
|
|
|
@gridGutterWidth: 20px;
|
2012-01-29 03:25:05 +01:00
|
|
|
@siteWidth: 724px;
|
2011-10-16 12:15:36 +02:00
|
|
|
|
|
|
|
// Bring grid mixins to recalculate widths
|
2012-01-25 19:48:08 +01:00
|
|
|
.columns(@columns: 1) {
|
|
|
|
width: (@gridColumnWidth * @columns) + (@gridGutterWidth * (@columns - 1));
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
2012-01-25 19:48:08 +01:00
|
|
|
.offset(@columns: 1) {
|
|
|
|
margin-left: (@gridColumnWidth * @columns) + (@gridGutterWidth * (@columns - 1)) + (@gridGutterWidth * 2);
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
|
|
|
|
2012-01-29 03:25:05 +01:00
|
|
|
// 12cols at 44px wide with 20px gutters
|
2011-10-16 12:15:36 +02:00
|
|
|
.container {
|
|
|
|
width: @siteWidth;
|
2012-01-29 03:25:05 +01:00
|
|
|
padding-left: 20px;
|
|
|
|
padding-right: 20px;
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Default columns
|
|
|
|
.span1 { .columns(1); }
|
|
|
|
.span2 { .columns(2); }
|
|
|
|
.span3 { .columns(3); }
|
|
|
|
.span4 { .columns(4); }
|
|
|
|
.span5 { .columns(5); }
|
|
|
|
.span6 { .columns(6); }
|
|
|
|
.span7 { .columns(7); }
|
|
|
|
.span8 { .columns(8); }
|
|
|
|
.span9 { .columns(9); }
|
|
|
|
.span10 { .columns(10); }
|
|
|
|
.span11 { .columns(11); }
|
|
|
|
.span12 { .columns(12); }
|
|
|
|
|
|
|
|
// Offset column options
|
|
|
|
.offset1 { .offset(1); }
|
|
|
|
.offset2 { .offset(2); }
|
|
|
|
.offset3 { .offset(3); }
|
|
|
|
.offset4 { .offset(4); }
|
|
|
|
.offset5 { .offset(5); }
|
|
|
|
.offset6 { .offset(6); }
|
|
|
|
.offset7 { .offset(7); }
|
|
|
|
.offset8 { .offset(8); }
|
|
|
|
.offset9 { .offset(9); }
|
|
|
|
.offset10 { .offset(10); }
|
|
|
|
.offset11 { .offset(11); }
|
|
|
|
|
2012-01-29 22:06:57 +01:00
|
|
|
// FLUID GRID
|
|
|
|
// ----------
|
|
|
|
.row-fluid {
|
|
|
|
@gridColumnWidth: 5.801104972%;
|
|
|
|
@gridGutterWidth: 2.762430939%;
|
|
|
|
@gridRowWidth: (@gridColumns * @gridColumnWidth) + (@gridGutterWidth * (@gridColumns - 1));
|
|
|
|
@gridTotalWidth: @gridRowWidth;
|
|
|
|
|
|
|
|
width: 100% * ((@gridGutterWidth + @gridRowWidth)/@gridRowWidth);
|
|
|
|
margin-left: 0 - @gridGutterWidth;
|
|
|
|
|
|
|
|
// Redeclare the mixins
|
|
|
|
.gridColumn() {
|
|
|
|
float: left;
|
|
|
|
margin-left: @gridGutterWidth;
|
|
|
|
}
|
|
|
|
[class*="span"] {
|
|
|
|
.gridColumn();
|
|
|
|
}
|
|
|
|
.fluidColumns(@columns: 1) {
|
|
|
|
width: @gridTotalWidth * ((((@gridGutterWidth+@gridColumnWidth)*@columns)-@gridGutterWidth)/(@gridRowWidth+@gridGutterWidth));
|
|
|
|
}
|
|
|
|
// Redeclare the columns
|
|
|
|
.span1 { .fluidColumns(1); }
|
|
|
|
.span2 { .fluidColumns(2); }
|
|
|
|
.span3 { .fluidColumns(3); }
|
|
|
|
.span4 { .fluidColumns(4); }
|
|
|
|
.span5 { .fluidColumns(5); }
|
|
|
|
.span6 { .fluidColumns(6); }
|
|
|
|
.span7 { .fluidColumns(7); }
|
|
|
|
.span8 { .fluidColumns(8); }
|
|
|
|
.span9 { .fluidColumns(9); }
|
|
|
|
.span10 { .fluidColumns(10); }
|
|
|
|
.span11 { .fluidColumns(11); }
|
|
|
|
.span12 { .fluidColumns(12); }
|
|
|
|
}
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
|
|
|
|
2012-01-28 01:26:55 +01:00
|
|
|
|
2012-01-30 01:35:55 +01:00
|
|
|
|
2012-01-28 01:26:55 +01:00
|
|
|
// TABLETS AND BELOW
|
|
|
|
// -----------------
|
|
|
|
@media (max-width: 940px) {
|
|
|
|
|
|
|
|
// UNFIX THE TOPBAR
|
|
|
|
// ----------------
|
|
|
|
// Remove any padding from the body
|
|
|
|
body {
|
|
|
|
padding-top: 0;
|
|
|
|
}
|
|
|
|
// Unfix the navbar
|
|
|
|
.navbar-fixed-top {
|
|
|
|
position: static;
|
2012-01-29 22:06:57 +01:00
|
|
|
margin-bottom: @baseLineHeight;
|
2012-01-28 01:26:55 +01:00
|
|
|
}
|
2012-01-29 23:07:14 +01:00
|
|
|
.navbar-fixed-top .navbar-inner {
|
2012-01-29 03:11:31 +01:00
|
|
|
padding: 5px;
|
2012-01-28 01:26:55 +01:00
|
|
|
background-image: none;
|
|
|
|
}
|
|
|
|
.navbar .container {
|
|
|
|
padding: 0;
|
|
|
|
}
|
|
|
|
// Account for brand name
|
|
|
|
.navbar .brand {
|
2012-01-29 03:11:31 +01:00
|
|
|
padding-left: 10px;
|
|
|
|
padding-right: 10px;
|
|
|
|
margin: 0 0 0 -5px;
|
|
|
|
}
|
|
|
|
// Nav collapse clears brand
|
|
|
|
.navbar .nav-collapse {
|
|
|
|
clear: left;
|
2012-01-28 01:26:55 +01:00
|
|
|
}
|
|
|
|
// Block-level the nav
|
|
|
|
.navbar .nav {
|
|
|
|
float: none;
|
2012-01-29 03:11:31 +01:00
|
|
|
margin: 0 0 (@baseLineHeight / 2);
|
2012-01-28 01:26:55 +01:00
|
|
|
}
|
|
|
|
.navbar .nav > li {
|
|
|
|
float: none;
|
|
|
|
}
|
|
|
|
.navbar .nav > li > a {
|
|
|
|
margin-bottom: 2px;
|
|
|
|
}
|
|
|
|
.navbar .nav > .vertical-divider {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
// Nav and dropdown links in navbar
|
|
|
|
.navbar .nav > li > a,
|
|
|
|
.navbar .dropdown-menu a {
|
|
|
|
padding: 6px 15px;
|
|
|
|
font-weight: bold;
|
|
|
|
color: @navbarLinkColor;
|
|
|
|
.border-radius(3px);
|
|
|
|
}
|
|
|
|
.navbar .dropdown-menu li + li a {
|
|
|
|
margin-bottom: 2px;
|
|
|
|
}
|
|
|
|
.navbar .nav > li > a:hover,
|
|
|
|
.navbar .dropdown-menu a:hover {
|
|
|
|
background-color: @navbarBackground;
|
|
|
|
}
|
|
|
|
// Dropdowns in the navbar
|
|
|
|
.navbar .dropdown-menu {
|
|
|
|
position: static;
|
2012-01-29 03:11:31 +01:00
|
|
|
top: auto;
|
|
|
|
left: auto;
|
2012-01-28 01:26:55 +01:00
|
|
|
float: none;
|
2012-01-29 03:11:31 +01:00
|
|
|
display: block;
|
2012-01-28 01:26:55 +01:00
|
|
|
max-width: none;
|
|
|
|
margin: 0 15px;
|
|
|
|
padding: 0;
|
|
|
|
background-color: transparent;
|
|
|
|
border: none;
|
|
|
|
.border-radius(0);
|
|
|
|
.box-shadow(none);
|
|
|
|
}
|
|
|
|
.navbar .dropdown-menu:before,
|
|
|
|
.navbar .dropdown-menu:after {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
.navbar .dropdown-menu .divider {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
// Forms in navbar
|
|
|
|
.navbar-form,
|
|
|
|
.navbar-search {
|
|
|
|
float: none;
|
|
|
|
padding: (@baseLineHeight / 2) 15px;
|
|
|
|
margin: (@baseLineHeight / 2) 0;
|
|
|
|
border-top: 1px solid @navbarBackground;
|
|
|
|
border-bottom: 1px solid @navbarBackground;
|
|
|
|
@shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.1);
|
|
|
|
.box-shadow(@shadow);
|
|
|
|
}
|
|
|
|
// Pull right (secondary) nav content
|
|
|
|
.navbar .nav.pull-right {
|
|
|
|
float: none;
|
|
|
|
margin-left: 0;
|
|
|
|
}
|
|
|
|
// Static navbar
|
|
|
|
.navbar-static .navbar-inner {
|
|
|
|
padding-left: 10px;
|
|
|
|
padding-right: 10px;
|
|
|
|
}
|
2012-01-29 00:42:07 +01:00
|
|
|
// Navbar button
|
|
|
|
.btn-navbar {
|
|
|
|
display: block;
|
|
|
|
}
|
|
|
|
|
2012-01-29 03:25:05 +01:00
|
|
|
// Hide everything in the navbar save .brand and toggle button */
|
2012-01-30 01:35:55 +01:00
|
|
|
.nav-collapse {
|
2012-01-29 00:42:07 +01:00
|
|
|
overflow: hidden;
|
|
|
|
height: 0;
|
|
|
|
}
|
2012-01-30 01:35:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// DEFAULT DESKTOP
|
|
|
|
// ---------------
|
2012-01-28 01:26:55 +01:00
|
|
|
|
2012-01-30 01:35:55 +01:00
|
|
|
@media (min-width: 940px) {
|
|
|
|
.nav-collapse.collapse {
|
|
|
|
height: auto !important;
|
|
|
|
}
|
2012-01-28 01:26:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-01-30 01:35:55 +01:00
|
|
|
|
2011-10-16 20:35:24 +02:00
|
|
|
// LARGE DESKTOP & UP
|
|
|
|
// ------------------
|
2012-01-29 03:11:31 +01:00
|
|
|
|
2012-01-29 05:34:07 +01:00
|
|
|
@media (min-width: 1200px) {
|
2011-10-16 12:15:36 +02:00
|
|
|
|
|
|
|
// Reset grid variables
|
|
|
|
@gridColumns: 12;
|
|
|
|
@gridColumnWidth: 70px;
|
|
|
|
@gridGutterWidth: 30px;
|
|
|
|
@siteWidth: 1170px;
|
|
|
|
|
2012-01-29 22:06:57 +01:00
|
|
|
// Thumbnails
|
|
|
|
.thumbnails {
|
|
|
|
margin-left: @gridGutterWidth * -1;
|
|
|
|
}
|
|
|
|
.thumbnails > li {
|
|
|
|
margin-left: @gridGutterWidth;
|
|
|
|
}
|
|
|
|
|
2011-10-16 12:15:36 +02:00
|
|
|
// Bring grid mixins to recalculate widths
|
2012-01-25 19:48:08 +01:00
|
|
|
.columns(@columns: 1) {
|
|
|
|
width: (@gridColumnWidth * @columns) + (@gridGutterWidth * (@columns - 1));
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
2012-01-25 19:48:08 +01:00
|
|
|
.offset(@columns: 1) {
|
|
|
|
margin-left: (@gridColumnWidth * @columns) + (@gridGutterWidth * (@columns - 1)) + (@gridGutterWidth * 2);
|
2011-10-16 12:15:36 +02:00
|
|
|
}
|
|
|
|
.container {
|
|
|
|
width: @siteWidth;
|
|
|
|
}
|
2012-01-07 09:29:36 +01:00
|
|
|
.row {
|
|
|
|
margin-left: @gridGutterWidth * -1;
|
|
|
|
}
|
2011-10-16 12:15:36 +02:00
|
|
|
[class*="span"] {
|
|
|
|
margin-left: @gridGutterWidth;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Default columns
|
|
|
|
.span1 { .columns(1); }
|
|
|
|
.span2 { .columns(2); }
|
|
|
|
.span3 { .columns(3); }
|
|
|
|
.span4 { .columns(4); }
|
|
|
|
.span5 { .columns(5); }
|
|
|
|
.span6 { .columns(6); }
|
|
|
|
.span7 { .columns(7); }
|
|
|
|
.span8 { .columns(8); }
|
|
|
|
.span9 { .columns(9); }
|
|
|
|
.span10 { .columns(10); }
|
|
|
|
.span11 { .columns(11); }
|
|
|
|
.span12 { .columns(12); }
|
|
|
|
|
|
|
|
// Offset column options
|
|
|
|
.offset1 { .offset(1); }
|
|
|
|
.offset2 { .offset(2); }
|
|
|
|
.offset3 { .offset(3); }
|
|
|
|
.offset4 { .offset(4); }
|
|
|
|
.offset5 { .offset(5); }
|
|
|
|
.offset6 { .offset(6); }
|
|
|
|
.offset7 { .offset(7); }
|
|
|
|
.offset8 { .offset(8); }
|
|
|
|
.offset9 { .offset(9); }
|
|
|
|
.offset10 { .offset(10); }
|
|
|
|
.offset11 { .offset(11); }
|
|
|
|
|
2012-01-29 07:48:25 +01:00
|
|
|
|
2012-01-29 22:06:57 +01:00
|
|
|
// FLUID GRID
|
|
|
|
// ----------
|
|
|
|
.row-fluid {
|
|
|
|
@gridColumnWidth: 5.982%;
|
|
|
|
@gridGutterWidth: 2.56%;
|
|
|
|
@gridRowWidth: (@gridColumns * @gridColumnWidth) + (@gridGutterWidth * (@gridColumns - 1));
|
|
|
|
@gridTotalWidth: @gridRowWidth;
|
|
|
|
|
|
|
|
width: 100% * ((@gridGutterWidth + @gridRowWidth)/@gridRowWidth);
|
|
|
|
margin-left: 0 - @gridGutterWidth;
|
|
|
|
|
|
|
|
// Redeclare the mixins
|
|
|
|
.gridColumn() {
|
|
|
|
float: left;
|
|
|
|
margin-left: @gridGutterWidth;
|
|
|
|
}
|
|
|
|
[class*="span"] {
|
|
|
|
.gridColumn();
|
|
|
|
}
|
|
|
|
.fluidColumns(@columns: 1) {
|
|
|
|
width: @gridTotalWidth * ((((@gridGutterWidth+@gridColumnWidth)*@columns)-@gridGutterWidth)/(@gridRowWidth+@gridGutterWidth));
|
|
|
|
}
|
|
|
|
// Redeclare the columns
|
|
|
|
.span1 { .fluidColumns(1); }
|
|
|
|
.span2 { .fluidColumns(2); }
|
|
|
|
.span3 { .fluidColumns(3); }
|
|
|
|
.span4 { .fluidColumns(4); }
|
|
|
|
.span5 { .fluidColumns(5); }
|
|
|
|
.span6 { .fluidColumns(6); }
|
|
|
|
.span7 { .fluidColumns(7); }
|
|
|
|
.span8 { .fluidColumns(8); }
|
|
|
|
.span9 { .fluidColumns(9); }
|
|
|
|
.span10 { .fluidColumns(10); }
|
|
|
|
.span11 { .fluidColumns(11); }
|
|
|
|
.span12 { .fluidColumns(12); }
|
|
|
|
}
|
2011-10-16 21:11:48 +02:00
|
|
|
}
|