:root {
--clr-bg: #1e272e;
--clr-surface: #2f3640;
--clr-surface-alt: #353b48;
--clr-text: #f5f6fa;
--clr-text-muted: #dcdde1;
--clr-primary: #1dd1a1;
--clr-secondary: #1dd1a1;
--clr-accent: #feca57;
--clr-card-new: #15314b;
--clr-card-featured: #4b3115;
--font-size-base: clamp(1rem, 0.9rem + 0.5vw, 1.1rem);
--font-size-h1: clamp(1rem, 0.8rem + 2vw, 2rem);
--spacing-sm: 0.5rem;
--spacing-md: 1.5rem;
--spacing-lg: 3rem;
--radius: 1rem;
--shadow: 0 10px 20px rgba(0,0,0,0.4);
--transition: 0.3s ease-in-out;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
background-color: var(--clr-bg);
color: var(--clr-text);
font-size: var(--font-size-base);
line-height: 1.6;
transition: background-color var(--transition), color var(--transition);
overflow-x: hidden;
}
ul, ol { list-style: none; }
a { text-decoration: none; color: inherit;}
.scroll-watcher { position: absolute; top: 0; width: 100%; height: 1px; }
.icon, .svg-icon { width: 1.2em; height: 1.2em; fill: currentColor; display: inline-block; vertical-align: middle; }
.shine-effect {
position: relative;
overflow: hidden;
border-radius: calc(var(--radius) / 2);
}
.shine-effect::after {
content: "";
position: absolute;
top: 120%;
left: -120%;
width: 200%;
height: 200%;
background: linear-gradient(
45deg,
transparent 45%,
rgba(255,255,255,0.6) 48%,
rgba(255,255,255,0.9) 50%,
rgba(255,255,255,0.6) 52%,
transparent 55%
);
transform: rotate(0deg);
transition: top 0.8s cubic-bezier(.25,.8,.25,1), left 0.8s cubic-bezier(.25,.8,.25,1);
pointer-events: none;
z-index: 10;
}
.shine-effect:hover::after {
top: -120%;
left: 120%;
}
.header {
position: relative;
padding-block: 0.4rem;
padding-inline: 1%;
background-color: var(--clr-surface);
transition: all var(--transition);
z-index: 1000;
}
.header--sticky {
position: fixed;
top: 0;
left: 0;
width: 100%;
box-shadow: var(--shadow);
animation: slideDown 0.5s ease-out;
}
@keyframes slideDown {
from { transform: translateY(-100%); }
to { transform: translateY(0); }
}
.header__content {
display: flex;
justify-content: space-between;
align-items: center;
width: 100%;
transition: opacity 0.3s;
}
.header__group {
display: flex;
align-items: center;
gap: 0.4rem;
}
.header__logo img {
height: 50px;
width: auto;
display: block;
}
@media (min-width: 600px) {
.header {
padding-inline: 5%;
}
}
.icon-btn {display: flex; align-items: center; justify-content: center; background-color: var(--clr-surface-alt); border: none; color: var(--clr-text); padding: 0.4rem; border-radius: calc(var(--radius) / 2); cursor: pointer; font-weight: bold; transition: var(--transition); font-size: 1.4rem; }
.icon-btn:hover { background-color: var(--clr-primary); color: white; box-shadow: var(--shadow); }
@media (max-width: 600px) {
.desktop-only { display: none !important; }
}
.header__search {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: var(--clr-surface);
display: flex;
align-items: center;
justify-content: space-between;
padding-inline: 5%;
opacity: 0;
visibility: hidden;
pointer-events: none;
transition: opacity 0.3s, visibility 0.3s;
z-index: 2;
}

.header__search form {
flex-grow: 1;
display: flex;
width: 100%;
}

.header__search-input {
width: 100%;
flex-grow: 1;
border: none;
background: transparent;
font-size: 1.2rem;
color: var(--clr-text);
outline: none;
padding: 0.5rem;
margin-right: 1rem;
}
.header.search-active .header__content, .header__game.search-active .header__content { opacity: 0; pointer-events: none; }
.header.search-active .header__search, .header__game.search-active .header__search { opacity: 1; visibility: visible; pointer-events: all; }
.modal {
margin: 0; margin-left: auto; padding: var(--spacing-md); border: none;
background-color: var(--clr-surface); color: var(--clr-text);
height: 100vh; max-height: 100vh; width: 100%; max-width: 100%; box-shadow: -10px 0 20px rgba(0,0,0,0.1);
}
@media (min-width: 768px) { .modal { width: 500px; } }
.modal::backdrop { background: rgba(0, 0, 0, 0.5); backdrop-filter: blur(3px); animation: fadeIn 0.3s ease forwards; }
.modal[open] { animation: slideInRight 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
.modal.closing { animation: slideOutRight 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
@keyframes slideInRight { from { transform: translateX(100%); } to { transform: translateX(0); } }
@keyframes slideOutRight { from { transform: translateX(0); } to { transform: translateX(100%); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.modal__header { display: flex; justify-content: space-between; margin-bottom: 1.5rem; align-items: center; }
.modal__title { font-size: 1.5rem; font-weight: bold; color: var(--clr-text); }
.modal__close { background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--clr-primary); display: flex; align-items: center; justify-content: center;}
.modal__actions { display: flex; gap: 1rem; margin-bottom: 1.5rem; padding-bottom: 1.5rem; border-bottom: 2px solid var(--clr-surface-alt); }
.action-btn { flex: 1; display: flex; align-items: center; justify-content: center; gap: 0.5rem; padding: 0.8rem; background-color: var(--clr-surface-alt); border: none; color: var(--clr-text); font-size: 1.1rem; font-weight: bold; border-radius: calc(var(--radius) / 2); cursor: pointer; transition: var(--transition); }
.action-btn:hover { background-color: var(--clr-primary); color: white; transform: translateY(-2px); box-shadow: var(--shadow); }
.action-btn .icon { font-size: 1.3rem; }
.tabs-wrapper { margin-bottom: 1.5rem; }
.tab-group { display: flex; background-color: var(--clr-surface-alt); border-radius: var(--radius); padding: 0.3rem; }
.tab-btn { flex: 1; padding: 0.6rem; border: none; background: transparent; font-weight: bold; color: var(--clr-text-muted); cursor: pointer; transition: var(--transition); border-radius: calc(var(--radius) - 0.3rem); }
.tab-btn.active { background-color: var(--clr-surface); color: var(--clr-primary); box-shadow: var(--shadow); }
.tab-pane { display: none; }
.tab-pane.active { display: block; animation: fadeIn 0.3s ease; }
.category-list { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.8rem; }
.category-list__item {
display: flex; align-items: center; gap: 0.5rem; height: 60px;
background-color: var(--clr-surface-alt);
border-radius: 0.5rem; cursor: pointer; transition: var(--transition);
font-size: 1rem; font-weight: bold; position: relative; overflow: hidden;
}
.category-list__item:hover { background-color: var(--clr-primary); color: white; transform: translateY(-3px); }
.category-list__item img { width: 60px; height: 60px; object-fit: cover; border-radius: 5px; }
.modal-games-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.modal-games-grid .game-link { width: 100%; max-width: 212px; aspect-ratio: 1 / 1; height: auto; margin: 0 auto; }
.section-title { color: var(--clr-primary); font-size: 1.2rem; margin-bottom: 1.5rem; padding-bottom: 0.5rem; border-bottom: 2px solid var(--clr-surface-alt); padding-inline: 5%; }
.section-header {
display: flex; justify-content: space-between; align-items: flex-end;
margin-bottom: 1.5rem; padding-bottom: 0.5rem; border-bottom: 2px solid var(--clr-surface-alt);
padding-inline: 5%;
}
.section-header .section-title { margin: 0; padding: 0; border: none; padding-inline: 0; }
.section-more { color: var(--clr-text-muted); font-weight: bold; font-size: 0.95rem; transition: color 0.3s; margin-bottom: 0.3rem; }
.section-more:hover { color: var(--clr-primary); }
.header-more { display: none; }
.card-more__icon {
background-color: var(--clr-surface-alt); width: 100%; height: 100%; border-radius: calc(var(--radius) / 2);
display: flex; align-items: center; justify-content: center; font-size: 3rem; color: var(--clr-text-muted);
transition: color 0.3s, transform 0.3s;
}
.card-more:hover .card-more__icon { color: var(--clr-primary); transform: scale(1.05); }
.game-card__title--more { position: static !important; background: transparent !important; color: var(--clr-text) !important; padding: 0 !important; margin-top: 0.5rem; }
@media (min-width: 984px) {
.header-more { display: block; }
.card-more { display: none !important; }
}
.game-card__img img, .game-link__placeholder img, .showcase-hero img, .cat-box__img img, .media-item__img-placeholder img {
width: 100%; height: 100%; object-fit: cover; border-radius: calc(var(--radius) / 2); display: block;
}
.games-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
@media (min-width: 600px) { .games-grid { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--spacing-md); }
.section-title { font-size: 1.8rem;}
}
.game-card {
position: relative; border-radius: calc(var(--radius) / 2); box-shadow: var(--shadow); transition: transform 0.3s;
aspect-ratio: 1 / 1; overflow: hidden;
}
.game-card:hover { transform: translateY(-5px); }
.game-card__img { width: 100%; height: 100%; }
.game-card__title {
position: absolute; bottom: 0; left: 0; width: 100%; padding: 2.5rem 1rem 1rem;
background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0) 100%);
color: white; font-size: 1.1em; font-weight: bold; text-align: center;
white-space: nowrap; overflow: hidden; text-overflow: ellipsis; z-index: 2; margin: 0;
}
.slider-wrapper {  border-radius: var(--radius); background: rgba(47, 54, 64, 0.6); padding: 0.625rem; position: relative; grid-area: slider; min-width: 0; }
.games-slider { display: flex; gap: 1rem; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; scrollbar-width: none; -ms-overflow-style: none; }
.games-slider::-webkit-scrollbar { display: none; }
.game-link { flex-shrink: 0; position: relative; display: block; width: 212px; height: 212px; border-radius: calc(var(--radius) / 2); overflow: hidden; scroll-snap-align: start; transition: transform var(--transition); }
.game-link__placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background-color: transparent; }
.game-link__title { position: absolute; bottom: 0; left: 0; width: 100%; padding: 2.5rem 1rem 1rem; background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0) 100%); color: white; font-size: 1rem; font-weight: bold; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; z-index: 2;}
.slider-btn { display: flex; position: absolute; top: 0; width: 50px; height: 232px; background: rgba(47, 54, 64, 0.6); backdrop-filter: blur(5px); border: none; color: var(--clr-primary); font-size: 3rem; cursor: pointer; z-index: 10; align-items: center; justify-content: center; transition: all 0.3s ease; opacity: 1; }
.slider-btn:hover { background: rgba(47, 54, 64, 0.9); }
.slider-btn--left { left: 0;  border-radius: calc(var(--radius) / 2) 0 0 calc(var(--radius) / 2); box-shadow: 5px 0 15px rgba(0,0,0,0.1); }
.slider-btn--right { right: 0; border-radius: 0 calc(var(--radius) / 2) calc(var(--radius) / 2) 0; box-shadow: -5px 0 15px rgba(0,0,0,0.1); }
.showcase { display: flex; flex-direction: column; gap: 3rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
.showcase-row { display: grid; grid-template-columns: 50px 1fr; grid-template-areas: "hero header" "slider slider"; gap: 1rem; align-items: center; }
.showcase-hero { grid-area: hero; width: 50px; height: 50px; border-radius: var(--spacing-sm); box-shadow: var(--shadow); display: block; transition: transform 0.3s;}
.showcase-hero:hover { transform: scale(1.02); }
.showcase-header { grid-area: header; }
.showcase-title { font-size: 1.2rem; color: var(--clr-text); }
@media (min-width: 1024px) {
.showcase-row { grid-template-columns: 325px 1fr; grid-template-areas: "hero header" "hero slider"; gap: 1rem 2rem; align-items: start; }
.showcase-hero { width: 325px; height: 325px; border-radius: var(--radius); }
.showcase-header { border-bottom: 2px solid var(--clr-surface-alt); padding-bottom: 0.5rem; }
.showcase-title { font-size: 1.6rem; }
}
.category-boxes { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1.5rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
.cat-box { display: flex; align-items: center; gap: 1rem; background-color: var(--clr-surface); padding: 0.4rem;  border-radius: var(--radius); box-shadow: var(--shadow); transition: transform 0.3s; border: 2px solid transparent; }
.cat-box:hover { transform: scale(1.03); border-color: var(--clr-secondary); }
.cat-box__img { width: 100px; height: 100px; flex-shrink: 0; background-color: transparent; border-radius: calc(var(--radius) / 2); display: block; }
.cat-box__title { font-size: 1.2rem; color: var(--clr-text); }
.collections-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.5rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
.collection-card { background-color: var(--brand-color, #333); color: white; padding: 2rem 1rem; border-radius: var(--radius); text-align: center; font-size: 1.4rem; font-weight: 900; box-shadow: var(--shadow); transition: transform 0.3s; display: flex; align-items: center; justify-content: center; min-height: 120px; }
.collection-card:hover { transform: translateY(-5px) scale(1.02); }
.seo-article { background-color: var(--clr-surface); padding: 2rem; border-radius: var(--radius); box-shadow: var(--shadow); margin-inline: 5%; margin-bottom: var(--spacing-lg); }
.seo-article h1, .seo-article h2, .seo-article h3, .seo-article h4 { color: var(--clr-primary); margin-block: 1.5rem 0.8rem; }
.seo-article h1 { font-size: 2.2rem; margin-top: 0; }
.seo-article h2 { font-size: 1.8rem; }
.seo-article h3 { font-size: 1.4rem; color: var(--clr-secondary); }
.seo-article p { margin-bottom: 1rem; line-height: 1.8; }
.seo-article ul { margin-left: 2rem; margin-bottom: 1rem; list-style-type: disc; }
.seo-article li { margin-bottom: 0.5rem; }
.media-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
.media-item { background-color: var(--clr-surface); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.media-item__img-placeholder { width: 100%; aspect-ratio: 16 / 9; background-color: transparent; display: block; }
.media-item figcaption { padding: 1rem; text-align: center; font-size: 0.95rem; color: var(--clr-text-muted); font-style: italic; }
.top-lists-section { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--spacing-md); padding-inline: 5%; margin-bottom: var(--spacing-lg); }
.top-list { background-color: var(--clr-surface); padding: var(--spacing-md); border-radius: var(--radius); box-shadow: var(--shadow); }
.top-list__title { color: var(--clr-secondary); margin-bottom: 1rem; border-bottom: 2px solid var(--clr-surface-alt); padding-bottom: 0.5rem; font-size: 1.1rem;}
.top-list__item { padding: 0.8rem 0; border-bottom: 1px solid var(--clr-surface-alt); display: flex; align-items: center; gap: 0.5rem; }
.top-list__item:before { content: "⭐"; font-size: 0.8rem; }
.top-list__item:last-child { border-bottom: none; }
.footer { background-color: var(--clr-surface-alt); padding-block: var(--spacing-lg) var(--spacing-md); }
.footer__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
@media (min-width: 800px) {
.footer__grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 2rem; }
.footer__col:first-child { padding-right: 2rem; border-right: 2px solid rgba(255,255,255,0.05); }
}
.footer__logo { font-size: 1.8em; font-weight: 900; color: var(--clr-primary); text-transform: uppercase; letter-spacing: 2px; display: block; margin-bottom: 0.5rem; }
.footer__logo img { height: 90px; width: auto; display: block; }
.footer__desc { color: var(--clr-text-muted); font-size: 0.95rem; margin-bottom: 1.5rem; }
.footer__lang-select {
width: 100%; max-width: 200px; padding: 0.6rem 1rem;
border-radius: calc(var(--radius) / 2); border: 2px solid var(--clr-surface-alt);
background-color: var(--clr-bg); color: var(--clr-text);
font-size: 1rem; font-family: inherit; cursor: pointer; outline: none; transition: border-color var(--transition);
}
.footer__lang-select:focus { border-color: var(--clr-primary); }
.footer__col-title { color: var(--clr-primary); margin-bottom: 1rem; font-size: 1.2rem; }
.footer__link { display: block; margin-bottom: 0.5rem; color: var(--clr-text-muted); transition: color 0.2s; }
.footer__link:hover { color: var(--clr-secondary); text-decoration: underline; }
.footer__bottom { text-align: center; border-top: 1px solid rgba(255,255,255,0.1); padding-top: 1.5rem; color: var(--clr-text-muted); font-size: 0.9rem; }
.page-intro { padding-inline: 5%; margin-top: var(--spacing-md); margin-bottom: var(--spacing-md); }
.breadcrumb { display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem; color: var(--clr-text-muted); font-size: 0.95rem; margin-bottom: 0.5rem; }
.breadcrumb a { transition: color var(--transition); display: inline; }
.breadcrumb a:hover { color: var(--clr-primary); text-decoration: underline; }
.breadcrumb span { opacity: 0.6; }
.category-main-title { font-size: var(--font-size-h1); color: var(--clr-text); font-weight: 900; line-height: 1.2; }
.category-grid-section { margin-bottom: var(--spacing-lg); }
.category-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 0.8rem;
justify-content: center;
margin-bottom: 2rem;
}
.category-grid .game-link {
width: 100%;
max-width: 212px;
height: auto;
aspect-ratio: 1 / 1;
margin: 0 auto;
}
@media (min-width: 600px) {
.category-grid {
grid-template-columns: repeat(auto-fit, minmax(160px, 212px));
gap: 1.2rem;
}
}
.pagination { display: flex; justify-content: center; align-items: center; gap: 0.5rem; margin-top: 2rem; flex-wrap: wrap;}
.page-btn { display: flex; align-items: center; justify-content: center; min-width: 45px; height: 45px; padding-inline: 0.5rem; border-radius: calc(var(--radius) / 2); background-color: var(--clr-surface); color: var(--clr-text); font-weight: bold; font-size: 1.1rem; border: 2px solid transparent; cursor: pointer; transition: all var(--transition); }
.page-btn:hover:not(:disabled) { background-color: var(--clr-surface-alt); border-color: var(--clr-primary); color: var(--clr-primary); transform: translateY(-3px); }
.page-btn.active { background-color: var(--clr-primary); color: white; box-shadow: var(--shadow); border-color: var(--clr-primary); }
.page-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.seo-article { background-color: var(--clr-surface); padding: 2rem; border-radius: var(--radius); box-shadow: var(--shadow); margin-inline: 5%; margin-bottom: var(--spacing-lg); }
.seo-article::after { content: ""; display: table; clear: both; }
.seo-article__image { width: 100%; border-radius: calc(var(--radius) / 1.5); overflow: hidden; box-shadow: var(--shadow); margin-bottom: 1.5rem; display: block; }
.seo-article__image img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; display: block; }
@media (min-width: 768px) {
.seo-article__image { float: right; width: 40%; max-width: 512px; margin-left: 2rem; margin-bottom: 1rem; }
}
.seo-article h1, .seo-article h2, .seo-article h3 { color: var(--clr-primary); margin-block: 1.5rem 0.8rem; }
.seo-article h1 { font-size: 2.2rem; margin-top: 0; }
.seo-article h2 { font-size: 1.8rem; }
.seo-article p { margin-bottom: 1rem; line-height: 1.8; color: var(--clr-text-muted); }
.seo-article ul { margin-left: 1.5rem; margin-bottom: 1rem; list-style-type: none; }
.seo-article li { margin-bottom: 0.5rem; position: relative; color: var(--clr-text-muted); }
.seo-article li::before { content: "🎮"; position: absolute; left: -1.5rem; font-size: 0.9rem; }
.article-tags-wrapper { margin-top: 2rem; border-top: 2px solid var(--clr-surface-alt); clear: both; }
h3.article-tags-title { font-size: 1.4rem; color: var(--clr-secondary); font-weight: 900; margin-bottom: 1.5rem; }
.article-tags { display: flex; flex-wrap: wrap; gap: 1rem; }
.article-tag-btn { background-color: var(--clr-surface); color: var(--clr-text); padding: 0.6rem 0.8rem; border-radius: calc(var(--radius) / 2); font-weight: bold; transition: var(--transition); border: 1px solid rgba(255,255,255,0.05); }
.article-tag-btn:hover { background-color: var(--clr-primary); color: white; transform: scale(1.02); box-shadow: var(--shadow); border-color: transparent; }
.media-gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 1.5rem; padding-inline: 5%; margin-bottom: var(--spacing-lg); }
.media-item { background-color: var(--clr-surface); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
.media-item__img-placeholder { width: 100%; aspect-ratio: 16 / 9; background-color: transparent; display: block; }
.media-item figcaption { padding: 1rem; text-align: center; font-size: 0.95rem; color: var(--clr-text-muted); font-style: italic; }

.all-categories {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 1rem;
padding-inline: 5%;
margin-bottom: var(--spacing-lg);
}
.cat-box {
display: flex;
align-items: center;
gap: 0.8rem;
background-color: var(--clr-surface);
padding: 0.4rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
transition: transform 0.3s, border-color 0.3s;
border: 2px solid transparent;
}
.cat-box:hover {
transform: scale(1.03);
border-color: var(--clr-secondary);
}
.cat-box__img {
width: 100px;
height: 100px;
flex-shrink: 0;
background-color: transparent;
border-radius: calc(var(--radius) / 2);
display: block;
overflow: hidden;
}
.cat-box__img img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.cat-box__title {
font-size: 1rem;
color: var(--clr-text);
font-weight: bold;
}
@media (max-width: 768px) {
.all-categories {
grid-template-columns: repeat(2, 1fr);
gap: 1rem;
}
.cat-box {
flex-direction: column;
text-align: center;
padding: 0.4rem 0.2rem;
gap: 0.8rem;
}
.cat-box__img {
width: 80px;
height: 80px;
}
.cat-box__title {
font-size: 1rem;
line-height: 1.2;
}
}
.error-section {
display: flex;
align-items: center;
justify-content: center;
min-height: 60vh;
padding-inline: 5%;
margin-block: var(--spacing-lg);
text-align: center;
}
.error-container {
background-color: var(--clr-surface);
padding: 4rem 2rem;
border-radius: var(--radius);
box-shadow: var(--shadow);
max-width: 650px;
width: 100%;
position: relative;
border: 1px solid rgba(255,255,255,0.05);
}
.error-code {
font-size: clamp(6rem, 15vw, 10rem);
font-weight: 900;
line-height: 1;
color: var(--clr-surface-alt);
text-shadow:
4px 4px 0px var(--clr-primary),
-4px -4px 0px var(--clr-secondary);
margin-bottom: 1.5rem;
letter-spacing: -2px;
font-family: 'Arial Black', sans-serif;
}
.error-container h1 {
font-size: clamp(1.5rem, 4vw, 2.5rem);
color: var(--clr-text);
margin-bottom: 1rem;
font-weight: 900;
}
.error-container p {
color: var(--clr-text-muted);
font-size: 1.1rem;
margin-bottom: 0.5rem;
line-height: 1.6;
}
.error-actions {
display: flex;
flex-wrap: wrap;
gap: 1rem;
justify-content: center;
margin-top: 2.5rem;
}
.error-section .btn-error {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
padding: 1rem 2rem;
border-radius: 50px;
font-weight: bold;
font-size: 1.1rem;
transition: transform 0.2s, background-color 0.2s, box-shadow 0.2s;
border: none;
cursor: pointer;
text-decoration: none;
}
.error-section .btn-random {
background-color: var(--clr-secondary);
color: #000;
box-shadow: 0 5px 15px rgba(29, 209, 161, 0.3);
}
.error-section .btn-random:hover {
transform: scale(1.05) translateY(-3px);
background-color: #12a880;
box-shadow: 0 8px 20px rgba(29, 209, 161, 0.4);
}
.error-section .btn-home {
background-color: var(--clr-surface-alt);
color: var(--clr-text);
border: 1px solid rgba(255,255,255,0.1);
}
.error-section .btn-home:hover {
background-color: var(--clr-primary);
color: white;
transform: scale(1.05) translateY(-3px);
border-color: transparent;
box-shadow: 0 8px 20px rgba(255, 107, 129, 0.3);
}
@media (max-width: 480px) {
.error-container { padding: 3rem 1.5rem; }
.error-section .btn-error { width: 100%; }
}
.page__section {
background-color: var(--clr-surface); padding: var(--spacing-lg) 5%; border-radius: var(--radius); box-shadow: var(--shadow);
margin-inline: 5%; margin-top: var(--spacing-lg); margin-bottom: var(--spacing-lg);
}
.page__content h1 {
color: var(--clr-text);
font-size: var(--font-size-h1);
margin-bottom: 1rem;
font-weight: 900;
}
.page__content h2 {
color: var(--clr-primary);
font-size: 1.5rem;
margin-top: 2rem;
margin-bottom: 1rem;
}
.page__content p {
margin-bottom: 1rem;
line-height: 1.8;
}
.page__content ul {
margin-left: 1.5rem;
margin-bottom: 1.5rem;
}
.page__content ul li {
margin-bottom: 0.5rem;
list-style-type: disc;
}
.contact-form-wrapper {
background-color: var(--clr-surface-alt);
padding: 2.5rem;
border-radius: var(--radius);
margin-top: 3rem;
border: 1px solid rgba(255,255,255,0.05);
box-shadow: inset 0 2px 10px rgba(0,0,0,0.1);
}
.contact-form-wrapper h2 {
font-size: 1.8rem;
margin-top: 0;
margin-bottom: 1.5rem;
text-align: center;
color: var(--clr-text);
}
.contact-form-wrapper form {
display: flex;
flex-direction: column;
gap: 1.2rem;
}
.contact-form-wrapper label {
display: block;
font-weight: bold;
margin-bottom: 0.4rem;
color: var(--clr-text-muted);
font-size: 0.95rem;
}
.contact-form-wrapper input[type="text"],
.contact-form-wrapper input[type="url"],
.contact-form-wrapper input[type="email"],
.contact-form-wrapper select,
.contact-form-wrapper textarea {
width: 100%;
background: rgba(0,0,0,0.2);
color: var(--clr-text);
border: 1px solid rgba(255,255,255,0.1);
padding: 0.8rem 1rem;
border-radius: calc(var(--radius) / 2);
font-size: 1rem;
font-family: inherit;
transition: border-color 0.2s ease, background 0.2s ease;
outline: none;
}
.contact-form-wrapper select option {
background: var(--clr-surface);
color: var(--clr-text);
}
.contact-form-wrapper input:focus,
.contact-form-wrapper select:focus,
.contact-form-wrapper textarea:focus {
border-color: var(--clr-primary);
background: rgba(0,0,0,0.3);
}
.contact-form-wrapper textarea {
resize: vertical;
min-height: 120px;
}
.contact-form-wrapper button {
background: var(--clr-primary);
color: white;
border: none;
padding: 1rem;
border-radius: calc(var(--radius) / 2);
cursor: pointer;
font-size: 1.1rem;
font-weight: bold;
transition: opacity 0.2s, transform 0.2s;
margin-top: 0.5rem;
}
.contact-form-wrapper button:hover {
opacity: 0.85;
transform: translateY(-2px);
}
.form-message {
padding: 1rem;
border-radius: calc(var(--radius) / 2);
margin-bottom: 1.5rem;
font-weight: bold;
text-align: center;
}
.form-message.success {
background-color: rgba(29, 209, 161, 0.1);
color: var(--clr-secondary);
border: 1px solid var(--clr-secondary);
}
.form-message.error {
background-color: rgba(255, 107, 129, 0.1);
color: var(--clr-primary);
border: 1px solid var(--clr-primary);
}
@media (max-width: 768px) {
.contact-form-wrapper { padding: 1.5rem; }
}
.sr-only {
position: absolute;
width: 1px;
height: 1px;
margin: -1px;
padding: 0;
overflow: hidden;
clip: rect(0 0 0 0);
border: 0;
}
:root {
--pwa-bg: #ffffff;
--pwa-text: #202124;
--pwa-shadow: rgba(60, 64, 67, 0.3);
--pwa-btn-primary: #1a73e8;
--pwa-btn-text: #ffffff;
--pwa-btn-secondary: #f1f3f4;
--pwa-secondary-text: #5f6368;
}
@media (prefers-color-scheme: dark) {
:root {
--pwa-bg: #2d2e31;
--pwa-text: #e8eaed;
--pwa-shadow: rgba(0, 0, 0, 0.5);
--pwa-btn-primary: #8ab4f8;
--pwa-btn-text: #202124;
--pwa-btn-secondary: #3c4043;
--pwa-secondary-text: #9aa0a6;
}
}
.pwa-banner {
position: fixed;
bottom: 20px;
left: 50%;
transform: translateX(-50%);
width: calc(100% - 40px);
max-width: 450px;
background: var(--pwa-bg);
color: var(--pwa-text);
padding: 10px;
border-radius: 12px;
box-shadow: 0 4px 12px var(--pwa-shadow);
z-index: 9999;
font-family: 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
display: none;
box-sizing: border-box;
}
.pwa-content {
display: flex;
flex-direction: column;
gap: 15px;
}
.pwa-text {
font-size: 1rem;
font-weight: 500;
line-height: 1.4;
}
.buttons-container {
display: flex;
justify-content: flex-end;
gap: 12px;
}
.pwa-banner button {
padding: 8px 20px;
border: none;
border-radius: 6px;
cursor: pointer;
font-size: 0.9rem;
font-weight: 600;
transition: background 0.2s;
}
.pwa-banner .btn-primary {
background: var(--pwa-btn-primary);
color: var(--pwa-btn-text);
}
.pwa-banner .btn-secondary {
background: var(--pwa-btn-secondary);
color: var(--pwa-text);
}
.pwa-banner .btn-primary:hover { opacity: 0.9; }
.pwa-banner .btn-secondary:hover { filter: brightness(0.9); }