html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
    display: block;
}

body {
    line-height: 1.0;
    line-height: 1;
    -webkit-text-size-adjust: none;
    min-height: var(--viewport-height);
    min-width: 320px;
    overflow-x: hidden;
    word-wrap: break-word;
    background-color: #FFFFFF;
    overflow: auto !important;
}

body:after {
    background-color: #1B2024;
    content: '';
    display: none !important;
    height: 100%;
    left: 0;
    opacity: 0;
    pointer-events: none;
    position: fixed;
    top: 0;
    transform: scale(1);
    transition: opacity 0.5s ease-in-out 0s, visibility 0.5s 0s;
    visibility: hidden;
    width: 100%;
    z-index: 1;
}

body.is-loading:after {
    opacity: 1;
    visibility: visible;
}

body.is-loading #main {
    opacity: 0;
    transform: perspective(1000px) rotateY(16.875deg);
}

body.is-instant #main,
body.is-instant #main>.inner>*,
body.is-instant #main>.inner>section>* {
    transition: none !important;
}

body.is-instant:after {
    display: none !important;
    transition: none !important;
}

ol,
ul {
    list-style: none;
}

blockquote,
q {
    quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

mark {
    background-color: rgba(144, 144, 144, 0.25);
    color: inherit
}

input::-moz-focus-inner {
    border: 0;
    padding: 0
}

input[type="text"],
input[type="email"],
select,
textarea {
    -moz-appearance: none;
    -webkit-appearance: none;
    -ms-appearance: none;
    appearance: none
}

*,
*:before,
*:after {
    box-sizing: border-box;
}

:root {
    --background-height: 100vh;
    --site-language-alignment: left;
    --site-language-direction: ltr;
    --site-language-flex-alignment: flex-start;
    --site-language-indent-left: 1;
    --site-language-indent-right: 0;
    --viewport-height: 100vh;
}

html {
    font-size: 15pt;
}

u {
    text-decoration: underline;
}

strong {
    color: inherit;
    font-weight: bolder;
}

em {
    font-style: italic;
}

code {
    background-color: rgba(144, 144, 144, 0.25);
    border-radius: 0.25em;
    font-family: 'Lucida Console', 'Courier New', monospace;
    font-size: 0.9em;
    font-weight: normal;
    letter-spacing: 0;
    margin: 0 0.25em;
    padding: 0.25em 0.5em;
    text-indent: 0;
}

spoiler-text {
    -webkit-text-stroke: 0;
    background-color: rgba(32, 32, 32, 0.75);
    text-shadow: none;
    -webkit-text-stroke: 0;
    color: transparent;
    cursor: pointer;
    transition: color 0.1s ease-in-out;
}

spoiler-text.active {
    color: #FFFFFF;
    cursor: text;
}

s {
    text-decoration: line-through;
}

sub {
    font-size: smaller;
    vertical-align: sub;
}

sup {
    font-size: smaller;
    vertical-align: super;
}

a {
    color: inherit;
    text-decoration: underline;
    transition: color 0.25s ease;
}

h1,
h2,
h3,
p {
    direction: var(--site-language-direction);
    position: relative;
}

h1 span.p,
h2 span.p,
h3 span.p,
p span.p {
    display: block;
    position: relative;
}

h1 span[style],
h2 span[style],
h3 span[style],
p span[style],
h1 strong,
h2 strong,
h3 strong,
p strong,
h1 a,
h2 a,
h3 a,
p a,
h1 code,
h2 code,
h3 code,
p code,
h1 mark,
h2 mark,
h3 mark,
p mark,
h1 spoiler-text,
h2 spoiler-text,
h3 spoiler-text,
p spoiler-text {
    -webkit-text-fill-color: currentcolor;
}

#wrapper {
    -webkit-overflow-scrolling: touch;
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: var(--viewport-height);
    overflow: hidden;
    position: relative;
    z-index: 2;
    padding: 1.5rem 1.5rem 1.5rem 1.5rem;
}

#wrapper02 {
    -webkit-overflow-scrolling: touch;
    align-items: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
    position: center;
    z-index: 2;
    padding: 5px;
}

#main {
    --alignment: left;
    --flex-alignment: flex-start;
    --indent-left: 1;
    --indent-right: 0;
    --border-radius-tl: 0.25rem;
    --border-radius-tr: 0.25rem;
    --border-radius-br: 0.25rem;
    --border-radius-bl: 0.25rem;
    align-items: center;
    display: flex;
    flex-grow: 0;
    flex-shrink: 0;
    justify-content: center;
    max-width: 100%;
    position: relative;
    text-align: var(--alignment);
    z-index: 1;
    background-color: transparent;
    border-radius: var(--border-radius-tl) var(--border-radius-tr) var(--border-radius-br) var(--border-radius-bl);
    transform: perspective(1000px) rotateY(0deg);
    transform-origin: 50% 50%;
    transition: opacity 0.75s ease 0s, transform 0.75s ease 0s;
    opacity: 1.0 !important;
    transform: none !important;
    transition: none !important;
    filter: none !important;
}

#main>.inner {
    --padding-horizontal: 3rem;
    --padding-vertical: 0rem;
    --spacing: 0rem;
    --width: 35rem;
    border-radius: var(--border-radius-tl) var(--border-radius-tr) var(--border-radius-br) var(--border-radius-bl);
    max-width: 100%;
    position: relative;
    width: var(--width);
    z-index: 1;
    padding: var(--padding-vertical) var(--padding-horizontal);
    opacity: 1.0 !important;
}

#main>.inner>* {
    margin-top: var(--spacing);
    margin-bottom: var(--spacing);
}

#main>.inner>.full {
    margin-left: calc(var(--padding-horizontal) * -1);
    max-width: calc(100% + calc(var(--padding-horizontal) * 2) + 0.4725px);
    width: calc(100% + calc(var(--padding-horizontal) * 2) + 0.4725px);
}


#main .container.full:first-child>.wrapper {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

#main .container.full:last-child>.wrapper {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

#main .container.full:first-child>.wrapper>.inner {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

#main .container.full:last-child>.wrapper>.inner {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

.video {
    position: relative;
}

.video video {
    display: inline-block;
    max-width: 100%;
    vertical-align: top;
}

.video .frame {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    position: relative;
    vertical-align: top;
}

.video .frame:before {
    content: '';
    display: block;
    width: 100%;
}

.video .frame iframe {
    bottom: 0px;
    height: 100%;
    left: 0px;
    position: absolute;
    right: 0px;
    top: 0px;
    width: 100%;
    background-color: #000000;
}

.video.full video {
    display: block;
}

.video.full:first-child video {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

.video.full:last-child video {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

.video.full .frame {
    display: block;
}

.video.full:first-child .frame {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

.video.full:last-child .frame {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

.icons {
    display: flex;
    flex-wrap: wrap;
    justify-content: var(--flex-alignment);
    letter-spacing: 0;
    padding: 0;
}

.icons li {
    position: relative;
    z-index: 1;
}

.icons li a {
    align-items: center;
    display: flex;
    justify-content: center;
}

.icons li a svg {
    display: block;
    position: relative;
}

.icons li a+svg {
    display: block;
    height: 100%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: -1;
}

.icons li a .label {
    display: none;
}

.image {
    display: block;
    line-height: 0;
    max-width: 100%;
    position: relative;
}

.image .frame {
    backface-visibility: hidden;
    transform: translate3d(0, 0, 0);
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    vertical-align: top;
    width: 100%;
}

.image .frame img {
    border-radius: 0 !important;
    max-width: 100%;
    vertical-align: top;
    width: inherit;
}

.image.full .frame {
    display: block;
}

.image.full:first-child .frame {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

.image.full:last-child .frame {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

#image01 {
    text-align: center;
}

#image01:not(:first-child) {
    margin-top: 1.5rem !important;
}

#image01:not(:last-child) {
    margin-bottom: 1.5rem !important;
}

#image01 .frame {
    width: 7rem;
    transition: none;
}

#image01 .frame img {
    transition: none;
}

.text {
    justify-content: var(--flex-alignment);
    letter-spacing: 0;
    padding: 0;
    font-family: 'Sora', sans-serif;
}

.text li {
    max-width: 100%;
}

.text p {
    align-items: center;
    justify-content: center;
    max-width: 100%;
    text-decoration: none;
    vertical-align: middle;
    text-transform: uppercase;
    white-space: nowrap;
}

.text li a {
    align-items: center;
    justify-content: center;
    max-width: 100%;
    text-decoration: none;
    vertical-align: middle;
    text-transform: uppercase;
    border-radius: 2rem;
    white-space: nowrap;
}

.text mark {
    color: #FFFFFF;
    background-color: transparent;
}

.text a {
    text-decoration: none;
}

.text a:hover {
    text-decoration: underline;
}

.text:not(:first-child) {
    margin-top: 1rem;
}

.text:not(:last-child) {
    margin-bottom: 1rem;
}

.text li a:hover {
    transform: scale(1.025);
}

.text span.p:nth-child(n + 2) {
    margin-top: 1rem;
}

#textmaintitle {
    font-size: 3em;
    font-weight: 900;
    text-align: center;
    text-transform: uppercase;
    color: #ff00ff;
}

#textmaintitle2 {
    font-size: 2em;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
    color: #4c00ff;
}

#texttitle {
    font-size: 2em;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
    color: #000000;
}

#texttitle2 {
    font-size: 1.5em;
    font-weight: 600;
    text-transform: uppercase;
    color: #000000;
}

#texttitle3 {
    font-size: 1.5em;
    font-weight: 600;
    text-align: center;
    text-transform: uppercase;
    color: #ff0000;
}

#texttos1 {
    font-size: 1.8em;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
    color: #000000;
}

#texttos2 {
    font-size: 1.5em;
    font-weight: 600;
    text-align: center;
    text-transform: uppercase;
    color: #000000;
}

#texttos3 {
    font-size: 1em;
    font-weight: 400;
    color: #000000;
}

#textnav {
    font-size: 1.25em;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
    color: #6b6767;
}

#textp {
    font-size: 1em;
    font-weight: 200;
    color: #000000;
}

#textprice {
    font-size: 1em;
    font-weight: bold;
    color: #ff0000;
}

#textfooter {
    font-size: 1.75em;
    font-weight: 700;
    text-align: center;
    text-transform: uppercase;
    color: #000000;
}

.buttons {
    cursor: default;
    display: flex;
    justify-content: var(--flex-alignment);
    letter-spacing: 0;
    padding: 0;
    font-size: 1.125em;
    font-weight: 400;
    font-family: 'Sora', sans-serif;
}

.buttons li {
    max-width: 100%;
}

.buttons li a {
    align-items: center;
    justify-content: center;
    max-width: 100%;
    text-align: center;
    text-decoration: none;
    vertical-align: middle;
    text-transform: uppercase;
    border-radius: 2rem;
    white-space: nowrap;
}

.buttons:not(:first-child) {
    margin-top: 2.0rem !important;
}

.buttons:not(:last-child) {
    margin-bottom: 2.0rem !important;
}

.buttons li a:hover {
    transform: scale(1.025);
}

#buttons01 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons01 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons01 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons01 .button {
    background-color: #40A376;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(95, 100, 217, 0.769) 0%, rgba(64, 163, 118, 0.008) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons01 .button:hover {
    background-color: #30D98B !important;
}

#buttons02 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons02 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons02 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons02 .button {
    background-color: #C28730;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(201, 50, 50, 0.769) 0%, rgba(194, 135, 48, 0.008) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons02 .button:hover {
    background-color: #EBC43D !important;
}

#buttons03 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons03 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons03 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons03 .button {
    background-color: #8340A3;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(217, 95, 95, 0.769) 0%, rgba(131, 64, 163, 0.008) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons03 .button:hover {
    background-color: #D930AA !important;
}

#buttons04 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons04 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    direction: var(--site-language-direction);
    overflow: hidden;
    text-overflow: ellipsis;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons04 .button {
    background-color: #E3AC22;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(163, 227, 59, 0.769) 0%, rgba(227, 172, 34, 0.008) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons04 .button:hover {
    background-color: #EBE33D !important;
}

#buttons05 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons05 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons05 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons05 .button {
    background-color: #4240a3;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(95, 168, 217, 0.769) 0%, rgba(64, 163, 163, 0.008) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons05 .button:hover {
    background-color: #0c21df !important;
}

#buttons06 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons06 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons06 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons06 .button {
    background-color: #e91296;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(234, 41, 41, 0.719) 0%, rgba(184, 22, 103, 0.836) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons06 .button:hover {
    background-color: #81055e !important;
}

#buttons07 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons07 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons07 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons07 .button {
    background-color: #00ffff;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(0, 255, 157, 0.719) 0%, rgba(184, 22, 103, 0.836) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons07 .button:hover {
    background-color: #00ff95 !important;
}

#buttons08 {
    gap: 2.0rem;
    flex-direction: row;
    flex-wrap: wrap;
}

#buttons08 li a {
    display: inline-flex;
    width: 100vw;
    height: 3.75rem;
    line-height: 3.75rem;
    padding: 0 1.875rem;
    transition: transform 0.25s ease, color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#buttons08 li a svg {
    display: block;
    fill: #FFFFFF;
    flex-grow: 0;
    flex-shrink: 0;
    height: 100%;
    min-width: 18px;
    width: 2.5em;
    margin-left: -0.125em;
    margin-right: calc(0.5em + 0rem);
    transition: fill 0.25s ease;
}

#buttons08 .button {
    background-color: #b700ff;
    color: #FFFFFF;
    background-image: linear-gradient(45deg, rgba(255, 0, 191, 0.719) 0%, rgba(184, 22, 103, 0.836) 75%);
    background-position: 0% 0%;
    background-repeat: repeat;
    background-size: cover;
}

#buttons08 .button:hover {
    background-color: #81055e !important;
}

.container>.wrapper {
    vertical-align: top;
    position: relative;
    max-width: 100%;
    border-radius: inherit;
}

.container>.wrapper>.inner {
    vertical-align: top;
    position: relative;
    max-width: 100%;
    border-radius: inherit;
    text-align: var(--alignment);
}

.image-column {
    width: 20%;
}

.content-column {
    width: 80%;
}

.container {
    position: relative;
    display: flex;
}

.interior-section01 {
    background-color: #838383;
    padding: 15px;
    border-radius: 10px;
    margin: 8px 0;
}

.interior-section02 {
    padding: 15px;
    border-radius: 10px;
    margin: 8px 0;
}

.content-block {
    margin-top: 15px;
    padding: 5px;
    border: 0.5px solid #0004ff;
    border-radius: 10px;
}

.column {
    flex: 1;
    margin: 10px;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
}

.section {
    width: 45%;
    padding: 10px;
}

.section h2 {
    color: #333;
    margin-bottom: 10px;
}

.section p {
    line-height: 1.6;
    color: #555;
}

.section ul li {
    list-style: none;
    padding: 0;
    margin-bottom: 5px;
}

nav {
    background-color: #ff00ff;
    overflow: hidden;
}

nav ul {
    list-style-type: none;
}

nav li {
    float: left;
}

nav li a {
    display: block;
    color: white;
    text-align: center;
    padding: 10px 10px;
    text-decoration: none;
}

nav li a:hover {
    background-color: transparent;
    color: black;
}

form {
    display: flex;
    justify-content: var(--flex-alignment);
}

form .inner {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    max-width: 100%;
}

form label {
    direction: var(--site-language-direction);
    display: block;
}

form .field button {
    align-items: center;
    background-color: transparent;
    border: 0;
    cursor: pointer;
    display: flex;
    justify-content: center;
}

form .field button>svg {
    height: 50%;
    min-width: 100%;
}

form input[type="text"],
form input[type="email"],
form input[type="tel"],
form input[type="number"],
form textarea,
form select,
form .file {
    background-color: transparent;
    border: 0;
    direction: var(--site-language-direction);
    display: block;
    outline: 0;
    text-align: var(--site-language-alignment);
    width: 100%;
}

form input[type="tel"] {
    appearance: none;
}

form textarea {
    height: 10rem;
    line-height: normal;
}

form select {
    background-repeat: no-repeat;
    background-size: 1rem;
    text-overflow: ellipsis;
    appearance: none;
}

form select option {
    background-color: white;
    color: black;
}

form select::-ms-expand {
    display: none;
}

form input[type="checkbox"] {
    appearance: none;
    display: block;
    float: left;
    margin-right: -2rem;
    opacity: 0;
    width: 1rem;
    z-index: -1;
}

form input[type="checkbox"]+label {
    align-items: center;
    display: inline-flex;
    line-height: 1.6;
    text-align: left;
}

form input[type="checkbox"]+label:before {
    background-position: center;
    background-repeat: no-repeat;
    content: '';
    cursor: pointer;
    display: inline-block;
    flex-grow: 0;
    flex-shrink: 0;
    vertical-align: middle;
}

form input[type="number"] {
    appearance: none;
    -moz-appearance: textfield;
}

form input[type="number"]::-webkit-inner-spin-button,
form input[type="number"]::-webkit-outer-spin-button {
    -webkit-appearance: none;
}

form .number {
    position: relative;
}

form .number>input[type="number"] {
    text-align: center;
}

form .number>button {
    position: absolute;
}

form .field .number>button>svg {
    height: 40%;
}

form .file {
    position: relative;
}

form .file>button {
    position: absolute;
}

form .file>input[type="file"] {
    cursor: pointer;
    height: 100%;
    left: 0;
    opacity: 0;
    position: absolute;
    top: 0;
    width: 100%;
}

form .file[data-filename]:before {
    background-repeat: no-repeat;
    content: attr(data-filename);
    display: block;
    height: 100%;
    overflow: hidden;
    position: absolute;
    text-overflow: ellipsis;
    top: 0;
    white-space: nowrap;
}

form .file[data-filename=""]:before {
    background-image: none !important;
    content: attr(data-placeholder);
    padding-left: 0 !important;
}

form .field .file>button>svg {
    height: 53%;
}

form .actions {
    max-width: 100%;
}

form .actions button {
    align-items: center;
    background-color: transparent;
    border: 0;
    cursor: pointer;
    display: inline-flex;
    justify-content: center;
    max-width: 100%;
    text-align: center;
    vertical-align: middle;
    white-space: nowrap;
}

form .actions button:disabled {
    cursor: default;
    opacity: 0.35;
    pointer-events: none;
}

@keyframes button-spinner {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

#form02 .inner>* {
    margin: 1rem 0 0 0;
    max-width: 100%;
}

#form02 .inner> :first-child {
    margin: 0;
}

#form02 .inner {
    width: 100%;
}

#form02 label:first-child {
    margin: 0.25rem 0 0.75rem 0;
    text-transform: uppercase;
    font-size: 1em;
    line-height: 1.5;
    font-family: 'Source Sans Pro', sans-serif;
    font-weight: 400;
    color: #474747;
}

#form02 .field button {
    background-size: 0.9rem;
    height: 1.8rem;
    line-height: 1.8rem;
    width: 1.8rem;
    border-radius: 1.04rem;
    border: solid 1px #CCCCCC;
    transition: color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
}

#form02 .field button:hover {
    border-color: #309EDB;
}

#form02 .field button svg {
    fill: #CCCCCC;
    transition: fill 0.25s ease;
}

#form02 .field button:hover svg {
    fill: #309EDB;
}

#form02 input[type="text"],
#form02 input[type="email"],
#form02 input[type="tel"],
#form02 input[type="number"],
#form02 textarea,
#form02 select,
#form02 input[type="checkbox"]+label,
#form02 .file {
    text-transform: uppercase;
    font-size: 1em;
    font-family: 'Source Sans Pro', sans-serif;
    letter-spacing: 0.025rem;
    font-weight: 200;
    border-radius: 1.625rem;
}

#form02 input[type="text"],
#form02 input[type="email"],
#form02 input[type="tel"],
#form02 input[type="number"],
#form02 textarea,
#form02 select,
#form02 .file {
    padding-left: calc(0.025rem + 0.7875rem);
    color: #474747;
    border: solid 1px #CCCCCC;
}

#form02 input[type="checkbox"]+label {
    color: #474747;
}

#form02 input[type="text"],
#form02 input[type="email"],
#form02 input[type="tel"],
#form02 input[type="number"],
#form02 select,
#form02 .file {
    height: 2.25rem;
    padding: 0 0.7875rem;
    line-height: calc(2.25rem - 2px);
}

#form02 textarea {
    padding: 0.7875rem;
    height: 20rem;
    line-height: 1.5;
    padding-top: 0.525rem;
}

#form02 select {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='504' height='552' preserveAspectRatio='none' viewBox='0 0 504 552'%3E%3Cpath d='M483.9,210.9L252,442.9L20.1,210.9l67.9-67.9L252,307.1l164.1-164.1L483.9,210.9z' fill='%23CCCCCC' /%3E%3C/svg%3E");
    background-position: calc(100% - 0.7875rem) center;
    padding-right: 2.4375rem;
}

#form02 input[type="checkbox"]+label:before {
    border-radius: 1.625rem;
    color: #474747;
    border: solid 1px #CCCCCC;
    background-size: 0.95625rem;
    height: 1.6875rem;
    width: 1.6875rem;
    margin-right: 0.875rem;
}

#form02 input[type="checkbox"]:checked+label:before {
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='648' height='552' preserveAspectRatio='none' viewBox='0 0 648 552'%3E%3Cpath d='M225.3,517.7L2.1,293.1l68.1-67.7L226,382.3L578.1,35.6l67.4,68.4L225.3,517.7z' fill='%23474747' /%3E%3C/svg%3E");
}

#form02 .number>input[type="number"] {
    padding-left: 2.3rem;
    padding-right: 2.3rem;
}

#form02 .number>button.decrement {
    bottom: calc(0.225rem - 0px);
    left: calc(0.225rem - 0px);
}

#form02 .number>button.increment {
    bottom: calc(0.225rem - 0px);
    right: calc(0.225rem - 0px);
}

#form02 .file:before {
    width: calc(100% - 3.0375rem);
    background-image: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40' preserveAspectRatio='none' viewBox='0 0 40 40'%3E%3Cpath d='M27.4,4.5c-0.4-0.4-0.8-0.7-1.5-0.9c-0.6-0.3-1.2-0.4-1.7-0.4H7.1c-0.5,0-0.9,0.2-1.3,0.5S5.3,4.5,5.3,5.1v30.7 c0,0.5,0.2,0.9,0.5,1.3c0.4,0.4,0.8,0.5,1.3,0.5h25.8c0.5,0,0.9-0.2,1.3-0.5c0.4-0.4,0.5-0.8,0.5-1.3V13.7c0-0.5-0.1-1.1-0.4-1.7 c-0.3-0.6-0.6-1.1-0.9-1.5L27.4,4.5z M25.7,6.2l6,6c0.2,0.2,0.3,0.4,0.4,0.8h-7.2V5.8C25.3,5.9,25.5,6.1,25.7,6.2z M7.7,35.2V5.7 h14.7v8c0,0.5,0.2,0.9,0.5,1.3c0.4,0.4,0.8,0.5,1.3,0.5h8v19.7H7.7z' style='opacity: 0.375' fill='%23474747' /%3E%3C/svg%3E");
    background-size: 1rem;
    background-position: left;
    padding-left: 1.4rem;
}

#form02 .file>button {
    bottom: calc(0.225rem - 1px);
    right: calc(0.225rem - 1px);
}

#form02 .actions button {
    display: inline-block;
    width: 6.5rem;
    height: 2.25rem;
    line-height: calc(2.25rem - 2px);
    padding: 0 0.5rem;
    text-transform: uppercase;
    font-size: 0.625em;
    font-family: 'Source Sans Pro', sans-serif;
    letter-spacing: 0.225rem;
    padding-left: calc(0.225rem + 0.5rem);
    font-weight: 400;
    border-radius: 1.625rem;
    direction: var(--site-language-direction);
    overflow: hidden;
    text-overflow: ellipsis;
    color: #CCCCCC;
    border: solid 1px #CCCCCC;
    transition: color 0.25s ease, background-color 0.25s ease, border-color 0.25s ease;
    position: relative;
}

#form02 .actions button:hover {
    border-color: #309EDB;
    color: #309EDB;
}

#form02 .inner> :first-child>label:first-child {
    margin-top: 0;
}

#form02 .actions button:before {
    animation: button-spinner 1s infinite linear;
    background-image: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB3aWR0aD0iOTZweCIgaGVpZ2h0PSI5NnB4IiB2aWV3Qm94PSIwIDAgOTYgOTYiIHpvb21BbmRQYW49ImRpc2FibGUiPjxzdHlsZT5jaXJjbGUge2ZpbGw6IHRyYW5zcGFyZW50OyBzdHJva2U6ICNDQ0NDQ0M7IHN0cm9rZS13aWR0aDogMnB4OyB9PC9zdHlsZT48ZGVmcz48Y2xpcFBhdGggaWQ9ImNvcm5lciI+PHBvbHlnb24gcG9pbnRzPSIwLDAgNDgsMCA0OCw0OCA5Niw0OCA5Niw5NiAwLDk2IiAvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjb3JuZXIpIj48Y2lyY2xlIGN4PSI0OCIgY3k9IjQ4IiByPSIzMiIvPjwvZz48L3N2Zz4=');
    background-position: center;
    background-repeat: no-repeat;
    background-size: 1.6875rem;
    content: '';
    display: block;
    height: 1.6875rem;
    left: 50%;
    margin: -0.84375rem 0 0 -0.84375rem;
    opacity: 0;
    pointer-events: none;
    position: absolute;
    top: 50%;
    transition: opacity 0.25s ease;
    transition-delay: 0s;
    width: 1.6875rem;
}

#form02 .actions button.waiting {
    color: transparent;
}

#form02 .actions button.waiting svg {
    fill: transparent;
}

#form02 .actions button.waiting:before {
    opacity: 1.0;
    transition-delay: 0.125s;
}

#form02 ::-webkit-input-placeholder {
    color: #474747;
    opacity: 0.55;
}

#form02 :-moz-placeholder {
    color: #474747;
    opacity: 0.55;
}

#form02 ::-moz-placeholder {
    color: #474747;
    opacity: 0.55;
}

#form02 :-ms-input-placeholder {
    color: #474747;
    opacity: 0.55;
}

#form02 .file[data-filename=""]:before {
    color: #474747;
    opacity: 0.55;
}

:root {
    --bg: #0b0c10;
    --panel: rgba(255, 255, 255, .06);
    --panel-2: rgba(255, 255, 255, .10);
    --stroke: rgba(255, 255, 255, .14);
    --text: rgba(255, 255, 255, .92);
    --muted: rgba(255, 255, 255, .68);
    --soft: rgba(255, 255, 255, .10);
    --accent: #e9ff70;
    /* lima suave */
    --accent-2: #7cf7ff;
    /* cian suave */
    --danger: #ff5c7a;
    --shadow: 0 20px 60px rgba(0, 0, 0, .55);
    --radius: 18px;
    --radius-lg: 26px;
    --container: min(1120px, calc(100% - 40px));
}

* {
    box-sizing: border-box;
}

html,
body {
    height: 100%;
}

.body {
    margin: 0;
    color: var(--text);
    font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    background:
        radial-gradient(900px 500px at 10% 5%, rgba(233, 255, 112, .14), transparent 60%),
        radial-gradient(700px 450px at 92% 18%, rgba(124, 247, 255, .14), transparent 62%),
        radial-gradient(900px 600px at 40% 95%, rgba(255, 92, 122, .10), transparent 60%),
        linear-gradient(180deg, #07080b 0%, #0b0c10 40%, #07080b 100%);
    overflow-x: hidden;
}

/* Subtle noise overlay (pure CSS) */
.body:before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    opacity: .08;
    background-image:
        linear-gradient(0deg, rgba(255, 255, 255, .04), rgba(255, 255, 255, .04)),
        repeating-linear-gradient(90deg, rgba(255, 255, 255, .02) 0 1px, transparent 1px 3px);
    mix-blend-mode: overlay;
}

button {
    font-family: inherit;
}

.wrap {
    width: var(--container);
    margin: 0 auto;
    padding: 26px 0 70px;
}

header {
    display: grid;
    grid-template-columns: 1.2fr .8fr;
    gap: 22px;
    align-items: end;
    padding: 22px 0 18px;
}

.brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.mark {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    background:
        radial-gradient(18px 18px at 30% 35%, rgba(233, 255, 112, .95), rgba(233, 255, 112, .0) 70%),
        radial-gradient(22px 22px at 70% 65%, rgba(124, 247, 255, .95), rgba(124, 247, 255, .0) 72%),
        linear-gradient(145deg, rgba(255, 255, 255, .12), rgba(255, 255, 255, .02));
    border: 1px solid rgba(255, 255, 255, .16);
    box-shadow: 0 16px 34px rgba(0, 0, 0, .45);
    position: relative;
    overflow: hidden;
}

.mark:after {
    content: "";
    position: absolute;
    inset: -1px;
    background: linear-gradient(120deg, transparent 0 35%, rgba(255, 255, 255, .18) 45%, transparent 60%);
    transform: translateX(-40%);
    opacity: .9;
    animation: sheen 7s ease-in-out infinite;
}

@keyframes sheen {

    0%,
    45% {
        transform: translateX(-55%);
        opacity: .0;
    }

    55% {
        opacity: .8;
    }

    100% {
        transform: translateX(55%);
        opacity: .0;
    }
}

h1 {
    margin: 0;
    font-family: Fraunces, serif;
    letter-spacing: -0.02em;
    font-weight: 700;
    font-size: clamp(28px, 4.2vw, 46px);
    line-height: 1.05;
}

.lead {
    margin: 8px 0 0;
    color: var(--muted);
    font-size: 14.5px;
    line-height: 1.6;
    max-width: 64ch;
}

.controls {
    display: grid;
    gap: 10px;
    justify-items: end;
}

.toolbar {
    width: 100%;
    display: flex;
    gap: 10px;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.chipset {
    display: flex;
    gap: 8px;
    background: rgba(255, 255, 255, .04);
    border: 1px solid rgba(255, 255, 255, .10);
    border-radius: 999px;
    padding: 6px;
    backdrop-filter: blur(10px);
}

.chip {
    appearance: none;
    border: 0;
    color: rgba(255, 255, 255, .76);
    background: transparent;
    padding: 9px 12px;
    border-radius: 999px;
    font-size: 13px;
    letter-spacing: .01em;
    cursor: pointer;
    transition: transform .12s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
    position: relative;
}

.chip:hover {
    background: rgba(255, 255, 255, .08);
    color: rgba(255, 255, 255, .92);
}

.chip[aria-pressed="true"] {
    background: linear-gradient(120deg, rgba(233, 255, 112, .18), rgba(124, 247, 255, .10));
    color: rgba(255, 255, 255, .94);
    box-shadow: 0 10px 22px rgba(0, 0, 0, .35);
}

.chip:active {
    transform: scale(.98);
}

.search {
    display: flex;
    gap: 10px;
    width: 100%;
    justify-content: flex-end;
    align-items: center;
}

.field {
    flex: 1 1 260px;
    max-width: 440px;
    position: relative;
}

.field input {
    width: 100%;
    border: 1px solid rgba(255, 255, 255, .12);
    background: rgba(255, 255, 255, .04);
    color: rgba(255, 255, 255, .9);
    border-radius: 999px;
    padding: 11px 42px 11px 40px;
    outline: none;
    font-size: 14px;
    transition: border-color .18s ease, background .18s ease, box-shadow .18s ease;
    backdrop-filter: blur(10px);
}

.field input:focus {
    border-color: rgba(233, 255, 112, .40);
    box-shadow: 0 0 0 4px rgba(233, 255, 112, .10);
    background: rgba(255, 255, 255, .05);
}

.field svg {
    position: absolute;
    left: 14px;
    top: 50%;
    transform: translateY(-50%);
    opacity: .75;
}

.clearBtn {
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    border: 0;
    border-radius: 999px;
    width: 28px;
    height: 28px;
    background: rgba(255, 255, 255, .06);
    color: rgba(255, 255, 255, .85);
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: background .18s ease, transform .12s ease;
}

.clearBtn:hover {
    background: rgba(255, 255, 255, .10);
}

.clearBtn:active {
    transform: translateY(-50%) scale(.97);
}

.meta {
    display: flex;
    gap: 10px;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    color: var(--muted);
    font-size: 13px;
}

.pill {
    border: 1px solid rgba(255, 255, 255, .12);
    background: rgba(255, 255, 255, .04);
    padding: 7px 10px;
    border-radius: 999px;
    backdrop-filter: blur(10px);
}

main {
    margin-top: 18px;
}

.gallery {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(12, 1fr);
    align-items: stretch;
}

.tile {
    grid-column: span 4;
    min-height: 180px;
    border-radius: var(--radius-lg);
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, .12);
    background: rgba(255, 255, 255, .03);
    box-shadow: 0 14px 40px rgba(0, 0, 0, .45);
    cursor: pointer;
    outline: none;
    isolation: isolate;
    transform: translateZ(0);
    transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, filter .18s ease;
}

.tile:hover {
    transform: translateY(-2px);
    border-color: rgba(233, 255, 112, .20);
    box-shadow: 0 18px 55px rgba(0, 0, 0, .55);
}

.tile:active {
    transform: translateY(0px) scale(.995);
}

.tile:focus-visible {
    box-shadow: 0 0 0 4px rgba(124, 247, 255, .14), 0 18px 55px rgba(0, 0, 0, .55);
    border-color: rgba(124, 247, 255, .32);
}

.tile .media {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* CSS-only “media” for demo: data-URI inline SVGs */
.tile .media[data-kind="image"] {
    filter: saturate(1.05) contrast(1.02);
}

.tile:before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(0, 0, 0, .00) 0%, rgba(0, 0, 0, .18) 40%, rgba(0, 0, 0, .62) 100%),
        radial-gradient(900px 280px at 20% 20%, rgba(233, 255, 112, .14), transparent 55%),
        radial-gradient(700px 240px at 90% 5%, rgba(124, 247, 255, .12), transparent 55%);
    z-index: 1;
}

.cap {
    position: absolute;
    inset: auto 0 0 0;
    padding: 14px 14px 12px;
    z-index: 2;
    display: flex;
    gap: 10px;
    align-items: flex-end;
    justify-content: space-between;
}

.cap h3 {
    margin: 0;
    font-size: 15px;
    letter-spacing: .01em;
    line-height: 1.2;
    font-weight: 600;
}

.cap p {
    margin: 6px 0 0;
    color: rgba(255, 255, 255, .70);
    font-size: 12.5px;
    line-height: 1.35;
    max-width: 52ch;
}

.badge {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 8px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, .14);
    background: rgba(0, 0, 0, .22);
    backdrop-filter: blur(10px);
    color: rgba(255, 255, 255, .85);
    font-size: 12px;
    white-space: nowrap;
}

.dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--accent);
    box-shadow: 0 0 0 3px rgba(233, 255, 112, .12);
}

.dot.video {
    background: var(--accent-2);
    box-shadow: 0 0 0 3px rgba(124, 247, 255, .12);
}

/* Mosaic variations */
.tile.is-wide {
    grid-column: span 6;
    min-height: 230px;
}

.tile.is-tall {
    grid-column: span 3;
    min-height: 280px;
}

.tile.is-hero {
    grid-column: span 7;
    min-height: 320px;
}

.reveal {
    opacity: 0;
    transform: translateY(10px);
    animation: in .7s cubic-bezier(.2, .9, .2, 1) forwards;
}

@keyframes in {
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.lightbox {
    position: fixed;
    inset: 0;
    display: none;
    place-items: center;
    z-index: 50;
    padding: 18px;
}

.lightbox[aria-hidden="false"] {
    display: grid;
}

.lb-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, .72);
    backdrop-filter: blur(10px);
}

.lb-panel {
    position: relative;
    width: min(1040px, 100%);
    border-radius: 22px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, .14);
    background: rgba(15, 16, 20, .72);
    box-shadow: var(--shadow);
    display: grid;
    grid-template-rows: auto 1fr auto;
    isolation: isolate;
}

.lb-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 12px 12px 10px;
    border-bottom: 1px solid rgba(255, 255, 255, .10);
    background: linear-gradient(180deg, rgba(255, 255, 255, .06), rgba(255, 255, 255, .02));
}

.lb-title {
    display: flex;
    gap: 10px;
    align-items: center;
    min-width: 0;
}

.lb-title strong {
    font-weight: 600;
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 56vw;
}

.lb-title span {
    color: rgba(255, 255, 255, .65);
    font-size: 12.5px;
    white-space: nowrap;
}

.lb-actions {
    display: flex;
    gap: 8px;
    align-items: center;
}

.iconBtn {
    border: 1px solid rgba(255, 255, 255, .12);
    background: rgba(255, 255, 255, .05);
    color: rgba(255, 255, 255, .88);
    width: 38px;
    height: 38px;
    border-radius: 12px;
    cursor: pointer;
    display: grid;
    place-items: center;
    transition: transform .12s ease, background .18s ease, border-color .18s ease;
}

.iconBtn:hover {
    background: rgba(255, 255, 255, .08);
    border-color: rgba(255, 255, 255, .18);
}

.iconBtn:active {
    transform: scale(.98);
}

.iconBtn:focus-visible {
    outline: none;
    box-shadow: 0 0 0 4px rgba(124, 247, 255, .14);
    border-color: rgba(124, 247, 255, .30);
}

.lb-media {
    position: relative;
    background:
        radial-gradient(700px 380px at 20% 20%, rgba(233, 255, 112, .10), transparent 65%),
        radial-gradient(700px 380px at 80% 10%, rgba(124, 247, 255, .10), transparent 65%),
        linear-gradient(180deg, rgba(0, 0, 0, .25), rgba(0, 0, 0, .35));
    min-height: min(62vh, 560px);
    display: grid;
    place-items: center;
    padding: 14px;
}

.lb-media img,
.lb-media video {
    width: 100%;
    height: 100%;
    max-height: min(62vh, 560px);
    border-radius: 18px;
    object-fit: contain;
    background: rgba(0, 0, 0, .25);
    border: 1px solid rgba(255, 255, 255, .10);
}

.lb-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    padding: 10px 12px 12px;
    border-top: 1px solid rgba(255, 255, 255, .10);
    color: rgba(255, 255, 255, .70);
    font-size: 12.5px;
}

.navBtn {
    border: 1px solid rgba(255, 255, 255, .12);
    background: rgba(255, 255, 255, .05);
    color: rgba(255, 255, 255, .88);
    border-radius: 999px;
    padding: 10px 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    transition: transform .12s ease, background .18s ease, border-color .18s ease;
    white-space: nowrap;
}

.navBtn:hover {
    background: rgba(255, 255, 255, .08);
    border-color: rgba(255, 255, 255, .18);
}

.navBtn:active {
    transform: scale(.99);
}

.hint {
    color: rgba(255, 255, 255, .55);
}

/* Responsive */
@media (max-width: 980px) {
    header {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .controls {
        justify-items: start;
    }

    .toolbar,
    .search,
    .meta {
        justify-content: flex-start;
    }

    .lb-title strong {
        max-width: 60vw;
    }
}

@media (max-width: 720px) {
    .gallery {
        gap: 12px;
    }

    .tile {
        grid-column: span 12;
        min-height: 210px;
        border-radius: 22px;
    }

    .tile.is-wide,
    .tile.is-tall,
    .tile.is-hero {
        grid-column: span 12;
        min-height: 240px;
    }

    .lb-media {
        min-height: 52vh;
    }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
    .reveal {
        animation: none;
        opacity: 1;
        transform: none;
    }

    .mark:after {
        animation: none;
    }

    * {
        scroll-behavior: auto !important;
    }
}

kbd {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    border: 1px solid rgba(255, 255, 255, .16);
    background: rgba(255, 255, 255, .06);
    padding: 2px 6px;
    border-radius: 7px;
    color: rgba(255, 255, 255, .80);
    font-size: 12px;
}