/* Dushkhaven static layout (HTML+CSS)
   Palette from colors.txt:
   - Accent: #F9C5F9
   - Muted:  #9B859F
   - Active: #FF6DFF
*/

:root{
  --accent:#F9C5F9;
  --muted:#9B859F;
  --active:#FF6DFF;
  --text:#FFFFFF;
  --bg:#0f0b12;
  --card-bg:rgba(30,20,29,.55);
  --card-border:rgba(249,197,249,.55);
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --radius:14px;
  --container:1160px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Georgia, 'Times New Roman', serif;
  color:var(--text);
  background-color:var(--bg);
  line-height:1.35;
}

img{max-width:100%;height:auto;display:block}

a{color:inherit;text-decoration:none}

a:hover{color:var(--accent)}

.container{
  width:min(var(--container), calc(100% - 32px));
  margin:0 auto;
}

/* Page backgrounds */
body.page-main{background:url('../img/bg-main.png') top center / cover no-repeat fixed}
body.page-news{background:url('../img/bg-news.png') top center / cover no-repeat fixed}
body.page-connect{background:url('../img/bg-connect.png') top center / cover no-repeat fixed}
body.page-auth{background:url('../img/bg-auth.png') top center / cover no-repeat fixed}
body.page-cabinet{background:url('../img/bg-cabinet.png') top center / cover no-repeat fixed}

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:20;
  height:81px;
  background:url('../img/header.png') top center / cover no-repeat;
}

.site-header .nav{
  height:81px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:28px;
  font-size:16px;
}

.site-header .nav a{
  color:#fff;
  padding:6px 2px;
  text-shadow:0 2px 10px rgba(0,0,0,.8);
}

.site-header .nav a.active{
  border-bottom:2px solid var(--active);
}

/* Footer */
.site-footer{
  margin-top:80px;
  background:url('../img/footer.png') bottom center / cover no-repeat;
  min-height:162px;
  color:var(--muted);
}

.site-footer .footer-inner{
  min-height:162px;
  display:grid;
  grid-template-columns: 260px 1fr 260px;
  align-items:center;
  gap:18px;
}

.footer-logo{display:flex;align-items:center;gap:12px}
.footer-logo img{width:160px}

.footer-links{
  display:flex;
  justify-content:center;
  gap:28px;
  font-size:14px;
}

.footer-right{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
}

.footer-icons{
  display:flex;
  gap:10px;
  align-items:center;
}
.footer-icons img{height:16px;opacity:.95}

/* Headings */
.h1{
  text-align:center;
  color:var(--accent);
  font-size:56px;
  letter-spacing:1px;
  margin:36px 0 24px;
  text-shadow:0 6px 22px rgba(0,0,0,.55);
}

.h2{
  text-align:center;
  color:var(--accent);
  font-size:34px;
  margin:70px 0 24px;
  text-shadow:0 6px 22px rgba(0,0,0,.55);
}

.lead{
  text-align:center;
  max-width:760px;
  margin:0 auto 22px;
  color:#e9e0ef;
  font-size:15px;
}

.muted{color:var(--muted)}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 26px;
  border:0;
  cursor:pointer;
  user-select:none;
  text-transform:uppercase;
  letter-spacing:.8px;
  color:var(--accent);
  text-shadow:0 2px 10px rgba(0,0,0,.8);
}

.btn--main{
  width:360px;
  height:110px;
  background:url('../img/btn-main.png') center / 100% 100% no-repeat;
}

.btn--small{
  width:85px;
  height:21px;
  font-size:10px;
  background:url('../img/btn-news.png') center / 100% 100% no-repeat;
  padding:0;
}

.btn--all-news{
  width:300px;
  height:92px;
  background:url('../img/btn-all-news.png') center / 100% 100% no-repeat;
}

.btn--auth{
  width:160px;
  height:40px;
  font-size:14px;
  background:url('../img/btn-auth.png') center / 100% 100% no-repeat;
  color:var(--accent);
}

.btn--ghost{
  background:transparent;
  border:1px solid var(--card-border);
  border-radius:999px;
  padding:10px 18px;
  color:var(--accent);
}

.center{display:flex;justify-content:center}

/* Hero (Main) */
.hero{
  padding-top:26px;
  position:relative;
}

.hero-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
}

.hero-logo{
  width:min(880px, 95vw);
  filter: drop-shadow(0 18px 40px rgba(0,0,0,.55));
}

.hero-elf{
  position:absolute;
  right:-10px;
  top:30px;
  width:320px;
  opacity:.95;
  pointer-events:none;
}

/* Section blocks */
.panel{
  background:rgba(16,10,18,.55);
  border:1px solid rgba(255,255,255,.05);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
}

.kem-byt{
  margin-top:42px;
  padding:26px 18px 8px;
}

.kem-byt .title-top{
  text-align:center;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:1px;
  color:#e9e0ef;
  opacity:.9;
}

.kem-byt .title-big{
  text-align:center;
  margin-top:6px;
  font-size:28px;
  color:var(--accent);
}

.kem-byt .grid{
  display:grid;
  grid-template-columns: 1fr 520px;
  gap:22px;
  align-items:center;
  padding:18px 18px 22px;
}

.oval{
  aspect-ratio: 16/9;
  border-radius:999px;
  overflow:hidden;
  border:1px solid var(--card-border);
  background: linear-gradient(180deg, rgba(249,197,249,.18), rgba(0,0,0,.2));
  box-shadow:0 14px 36px rgba(0,0,0,.45);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-size:14px;
}

/* News cards */
.news-grid{
  display:grid;
  grid-template-columns: repeat(3, 404px);
  justify-content:center;
  gap:34px 44px;
  margin-top:20px;
}

.news-card{
  width:404px;
  height:372px;
  background:url('../img/news-card.png') center / 100% 100% no-repeat;
  position:relative;
  padding:12px 12px 10px;
}

.news-card .badge{
  position:absolute;
  top:14px;
  right:16px;
  width:54px;
  height:54px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  color:#fff;
  background: radial-gradient(circle at 30% 30%, rgba(249,197,249,.85), rgba(74,38,82,.95));
  border:1px solid rgba(255,255,255,.18);
  text-shadow:0 2px 10px rgba(0,0,0,.85);
}

.news-card .image{
  border-radius:10px;
  overflow:hidden;
  width:400px;
  height:176px;
  margin:4px auto 0;
}

.news-card h3{
  margin:10px 10px 6px;
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--accent);
}

.news-card p{
  margin:0 10px;
  font-size:12px;
  color:#d8cfde;
  max-height:46px;
  overflow:hidden;
}

.news-card .meta{
  position:absolute;
  left:16px;
  right:16px;
  bottom:10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  font-size:10px;
  color:var(--muted);
}

.news-card .meta .btn{margin-left:auto}

/* Pagination */
.pagination{
  margin:34px 0 0;
  display:flex;
  justify-content:center;
  gap:10px;
  align-items:center;
  color:var(--muted);
  font-size:14px;
}

.pagination a{padding:4px 6px;color:var(--muted)}
.pagination a.active{color:var(--active)}

/* How to start playing (4 boxes) */
.start-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:20px;
  margin-top:24px;
}

.start-card{
  padding:16px 14px;
  border:1px solid var(--card-border);
  border-radius:10px;
  background:rgba(24,16,28,.55);
  min-height:120px;
}

.start-card h4{
  margin:0 0 8px;
  font-size:13px;
  color:#fff;
}

.start-card p{margin:0;color:var(--muted);font-size:11px}

.gnome-row{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:28px;
  margin-top:22px;
}

.gnome-row img{width:200px;filter:drop-shadow(0 18px 40px rgba(0,0,0,.55))}

/* Auth forms */
.auth-wrap{
  padding:64px 0 90px;
}

.auth-card{
  width:min(520px, 100%);
  margin:0 auto;
  padding:26px 22px;
  background:rgba(24,16,28,.7);
  border:1px solid rgba(249,197,249,.28);
  border-radius:18px;
  box-shadow:var(--shadow);
}

.auth-card h1{
  margin:0 0 14px;
  text-align:center;
  color:var(--accent);
  font-size:32px;
}

.form-row{display:flex;flex-direction:column;gap:8px;margin:12px 0}

label{font-size:12px;color:var(--muted)}

input{
  height:44px;
  border-radius:10px;
  border:1px solid rgba(249,197,249,.25);
  background:rgba(12,8,14,.55);
  color:#fff;
  padding:0 12px;
  outline:none;
}

input:focus{border-color:rgba(255,109,255,.8); box-shadow:0 0 0 3px rgba(255,109,255,.15)}

.check{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
  font-size:12px;
  margin:14px 0;
}

.check input{width:18px;height:18px;margin-top:2px}

/* Cabinet */
.cabinet{
  padding:30px 0 80px;
}

.cabinet-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:18px;
}

.cabinet-top .logo{
  display:flex;
  align-items:center;
  gap:12px;
}

.cabinet-top .logo img{width:160px}

.userbox{
  display:flex;
  gap:18px;
  align-items:center;
  color:var(--accent);
  font-size:13px;
}

.userbox .crystal{display:flex;align-items:center;gap:8px}
.userbox .crystal img{width:22px}

.cabinet-layout{
  display:grid;
  grid-template-columns: 290px 1fr;
  gap:18px;
}

.sidebar{
  padding:14px;
  border:1px solid rgba(249,197,249,.22);
  border-radius:16px;
  background:rgba(18,12,22,.55);
}

.side-title{color:var(--accent);font-size:14px;margin:0 0 10px}

.menu{display:flex;flex-direction:column;gap:6px}

.menu a{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 10px;
  border-radius:12px;
  color:var(--muted);
  border:1px solid transparent;
}

.menu a.active{color:var(--active); border-color:rgba(255,109,255,.35); background:rgba(255,109,255,.08)}
.menu a:hover{border-color:rgba(249,197,249,.25); color:#fff}

.menu img{width:18px;height:18px}

.content{
  padding:18px;
  border:1px solid rgba(249,197,249,.22);
  border-radius:16px;
  background:rgba(18,12,22,.55);
}

.content h1{margin:0 0 10px;color:var(--accent);font-size:26px}

.note{
  padding:12px 14px;
  border:1px dashed rgba(249,197,249,.35);
  border-radius:12px;
  color:#e9e0ef;
  background:rgba(0,0,0,.12);
}

/* Responsive */
@media (max-width: 1320px){
  .news-grid{grid-template-columns: repeat(2, 404px)}
  .hero-elf{display:none}
}

@media (max-width: 920px){
  .news-grid{grid-template-columns: 404px}
  .kem-byt .grid{grid-template-columns:1fr}
  .start-grid{grid-template-columns: repeat(2, 1fr)}
  .site-footer .footer-inner{grid-template-columns:1fr;justify-items:center;padding:18px 0}
  .footer-right{align-items:center}
  .cabinet-layout{grid-template-columns:1fr}
}

@media (max-width: 520px){
  .h1{font-size:42px}
  .h2{font-size:28px}
  .start-grid{grid-template-columns:1fr}
  .news-card,.news-grid{width:100%}
  .news-card{transform:scale(.92); transform-origin: top center}
}
