html, body {
    margin: 0;
    padding: 0;
    height: 100%;
    background: transparent !important;
    font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
    color: #fff;
}

.metro-wrap {
    position: relative;
    height: 100vh;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    z-index: 1;
}

.metro-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-auto-rows: calc(100vh / 3);
    gap: 0;
}

.metro-tile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 18px;
    text-align: center;
    opacity: 0;
    transform: translateY(60px) scale(0.9);
    animation: tileIn 0.8s forwards ease-out;
}
@keyframes tileIn { 
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* DB’den gelen tile_size değerine göre (masaüstü) */
.medium { grid-column: span 2; }
.large  { grid-column: span 2; grid-row: span 2; }

/* --- MOBİL OVERRIDE --- */
@media (max-width: 768px) {
    .metro-grid {
        grid-template-columns: repeat(2, 1fr);   /* 2 sütun */
        grid-auto-rows: auto;                   /* otomatik yükseklik */
    }

    .metro-tile {
        font-size: 14px;
    }

    /* Mobilde tüm kutular eşit boy olsun */
    .metro-tile.medium,
    .metro-tile.large {
        grid-column: span 1 !important;
        grid-row: span 1 !important;
    }
}

.metro-tile {
  text-decoration: none;  /* Alt çizgi olmasın */
  color: #fff;            /* Yazı rengi sabit */
}

.metro-tile:hover {
  text-decoration: none;  /* Hover’da da çizgi çıkmasın */
  filter: brightness(1.1); /* İstersen hover efekti */
}
