/* ========== VARIABLES ========== */
:root {
  --background-color: #eeedc7;
  --content-background-color: #f1fffe;
  --sidebar-background-color: #fff194;

  --text-color: #0a2f09;
  --sidebar-text-color: #b64811;

  --link-color: #131da7;
  --link-color-hover: #406a4d;

  --font: Arial, sans-serif;
  --heading-font: Garamond, serif;
  --font-size: 14px;

  --margin: 6px;
  --padding: 22px;

  --border: 2px solid #ff9b59;
  --round-borders: 4px;

  --sidebar-width: 208px;
}

@font-face {
  font-family: "PixelFont7";
  src:
    url("/fonts/PixelFont7.woff2") format("woff2"),
    url("/fonts/PixelFont7.woff") format("woff");

  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* ========== BASICS ========== */
* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: var(--margin);
  min-height: 100vh;
  font: var(--font-size) / 1.5 var(--font);
  color: var(--text-color);
  background-image: url("backtexture.gif");
  background-repeat: repeat;
}

a {
  text-decoration: underline;
}

a,
a:visited {
  color: var(--link-color);
}

a:hover,
a:focus {
  color: var(--link-color-hover);
  text-decoration: none;
}

/* ========== LAYOUT (GRID) ========== */
.layout {
  width: 1000px;
  margin: 0 auto; /* ← ВОТ ЭТО */
  display: grid;
  gap: var(--margin);
  grid-template:
    "header header header" auto
    "ticker ticker ticker" auto
    "leftSidebar main rightSidebar" auto
    "footer footer footer" auto
    / var(--sidebar-width) 1fr var(--sidebar-width);
}

/* ========== HEADER / FOOTER (FAKE FRAME) ========== */
:root {
  --header-height: 220px; /* ← под это рисуй PNG */
  --footer-height: 120px; /* ← под это рисуй PNG */
}

/* Header */
.site-header {
  grid-area: header;
  position: relative;
  height: var(--header-height);
  background: transparent;
  overflow: hidden;
}

/* рамка */
.site-header::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: url("border.png") center / 100% 100% no-repeat;
  image-rendering: pixelated;
  z-index: 1;
}

/* контент */
.site-header .header-content {
  margin-top: -4px;
  position: relative;
  z-index: 2;
  height: 100%;
  padding: var(--padding);

  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr; /* слева кнопки, справа свободное место */
  align-items: start;
  gap: 18px;
}

.site-header .header-nav {
  align-self: start;
}

.news-panel{
  border: 0px solid #f4f177;
  position: relative;
  width: min(465px, 100%);    /* чтоб не раздувалось на всю ширину */
  height: 160px;              /* подбери под твой header */
  margin-top: 10px;           /* чтобы не прилипало к верху */
  margin-left: -120px;
  padding: 14px 14px 12px 14px;

  background: #ffe985;
  border-radius: 10px;
  overflow: visible; /* чтобы внутренний скролл не вылезал */
}

.news-panel__frame{
  position: absolute;
  border-radius: 6px;
  inset: 0;
  pointer-events: none;
  background: url("updates_window_trans.png") center / 100% 100% no-repeat; /* твоя рамочка */
  image-rendering: pixelated; /* если рамка пиксельная */
  z-index: 2;
}

.news-panel__title{
  margin: 0 0 8px 0;
  font-family: "PixelFont7", sans-serif;
  font-size: 14px;
  color: #0a2f09;
  opacity: 0.9;
  position: relative;
  z-index: 1;
}

.news-panel__scroll{
  overflow-y: scroll;   /* ВСЕГДА показывать */
  overflow-x: hidden;
  position: relative;
  z-index: 1;

  height: calc(100% - 22px); /* место под заголовок */
  overflow: auto;
  padding-right: 10px;       /* чтобы текст не залезал под скроллбар */
}

.news-panel__scroll::-webkit-scrollbar {
  width: 18px; /* ширина скролла */
}

.news-panel__scroll::-webkit-scrollbar-track {
  background: url("scroll2.png") repeat-y;
  background-size: 100% auto;
}

.news-panel__scroll::-webkit-scrollbar-thumb {
  background: url("scroll1.png") no-repeat center;
  background-repeat: no-repeat;
  background-size: 12px auto; /* ширина фикс, высота сама */
  border-radius: 0; /* если пиксельный */
}

/* простенький стиль элементов */
.news-item{
  padding: 6px 6px;
  border-radius: 6px;
}

.news-item + .news-item{
  margin-top: 6px;
}

.news-item__date{
  font-family: "PixelFont7", sans-serif;
  font-size: 12px;
  color: #0a2f09;
  opacity: 0.75;
  display: block;
  margin-bottom: 2px;
}

.news-item__text{
  margin: 0;
  font-family: "PixelFont7", sans-serif;
  font-size: 13px;
  color: #0a2f09;
  line-height: 1.2;
}

.ticker {
  grid-area: ticker;
  position: relative;
  height: 28px;
  overflow: hidden;
  background: none;
}

.ticker__inner {
  display: flex;
  width: max-content;
  gap: 24px;                 /* вместо margin-left на втором span */
  animation: ticker-move 18s linear infinite;
  will-change: transform;
}

.ticker__text {
  outline: 4px solid #f4f177;
  outline-offset: -4px;

  display: inline-block;
  padding: 4px 16px;         /* убери эти 40px справа, они и делают “хвост” */
  background: url("tile_text_ticker.png") repeat;
  border-radius: 6px;

  font-family: "PixelFont7", sans-serif;
  font-size: 14px;
  color: #0a2f09;
  white-space: nowrap;
}

@keyframes ticker-move {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}


@keyframes ticker-move {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}


/* Footer */
.site-footer {
  grid-area: footer;
  position: relative;
  height: var(--footer-height);
  background: transparent;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85em;
}

/* рамка */
.site-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: url("footer.png") center / 100% 100% no-repeat;
  image-rendering: pixelated;
  z-index: 1;
}

/* текст поверх рамки */
.site-footer > * {
  position: relative;
  z-index: 2;
}

/* ========== SIDEBARS ========== */
.left-sidebar,
.right-sidebar {
  background: var(--sidebar-background-color);
  border: var(--border);
  border-radius: var(--round-borders);
  padding: var(--padding);
  color: var(--sidebar-text-color);
}

.left-sidebar {
  grid-area: leftSidebar;
}

.right-sidebar {
  grid-area: rightSidebar;
}

.tiled-frame {
  /* толщина рамки (лучше кратно размеру тайла) */
  --frame: 16px;
  /* твой tile = 64x64, так идеально */
  --tile: 16px;

  border: var(--frame) solid transparent;

  /* 
    2 слоя фона:
    1) заливка контента (padding-box)
    2) тайл рамки (border-box)
  */
  background:
    linear-gradient(
      var(--sidebar-background-color),
      var(--sidebar-background-color)
    ) padding-box,
    url("tile_small_orange.png") 0 0 / var(--tile) var(--tile) repeat border-box;

  border-radius: 0; /* если нужны скругления — можно аккуратно добавить */
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 90px;
  font-family: "PixelFont7", sans-serif;
  font-size: 14px;
  color: #15642a;

  padding: 8px 14px;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;

  background-image: url("button_normal.png");

  border: none;
  outline: none;
  background-color: transparent;

  cursor: pointer;

  transition:
    background 0.15s ease,
    transform 0.05s ease;
}

.btn:hover {
  background-image: url("button_hover.png");
}

.btn:active {
  background-image: url("button_active.png");
  transform: translateY(2px);
}

.btn:focus-visible {
  outline: none;
}

.nav-list {
  display: flex;
  flex-direction: column;
  gap: 0px;
  list-style: none;
  padding: 0;
  margin: 0;
  align-items: flex-start; /* ключ */
}





/* ========== MAIN CONTENT ========== */
main {
  grid-area: main;
  background: var(--content-background-color);
  border: var(--border);
  border-radius: var(--round-borders);
  padding: var(--padding);
  min-width: 0;
}

/* ========== ACCESSIBILITY (keep) ========== */
#skip-to-content-link {
  position: fixed;
  top: 0;
  left: 0;
  display: inline-block;
  padding: 0.375rem 0.75rem;
  line-height: 1;
  font-size: 1rem;
  background: var(--content-background-color);
  color: var(--text-color);
  transform: translateY(-3rem);
  transition: transform 0.1s ease-in;
  z-index: 999999;
}

#skip-to-content-link:focus {
  transform: translateY(0);
}

/* ========== MOBILE ========== */
@media (max-width: 800px) {
  .layout {
    width: 100%;
    grid-template:
      "header" auto
      "leftSidebar" auto
      "main" auto
      "footer" auto
      / 1fr;
  }

  .right-sidebar {
    display: none;
  }

  .left-sidebar,
  main {
    padding: 15px;
  }

  .site-header nav ul {
    gap: 8px;
  }
}
