/* =========================================
   RTP RESORTSLOT - Full Green Theme
   ========================================= */

@import url('https://fonts.googleapis.com/css2?family=LatoWeb:wght@400;500;600;700;800&family=DM+Sans:wght@400;500;600&display=swap');

:root {
    --green-50:  #f0fdf4;
    --green-100: #dcfce7;
    --green-200: #bbf7d0;
    --green-300: #86efac;
    --green-400: #4ade80;
    --green-500: #22c55e;
    --green-600: #16a34a;
    --green-700: #15803d;
    --green-800: #166534;
    --green-900: #14532d;
    --green-950: #052e16;
    --accent:    #00ff87;
    --dark:      #0a1a0f;
    --card-bg:   #ffffff;
    --text-main: #0f1f14;
    --text-sub:  #4b7a5a;
    --border:    #d1fae5;
    --shadow:    0 2px 16px rgba(22, 163, 74, 0.10);
}

* { box-sizing: border-box; }

body {
    background: linear-gradient(135deg, #e8f5e9 0%, #f0fdf4 50%, #e0f2fe 100%);
    background-attachment: fixed;
    font-family: 'DM Sans', sans-serif;
    color: var(--text-main);
    min-height: 100vh;
}

/* ---- HEADER ---- */
header {
    background: linear-gradient(90deg, var(--green-950) 0%, var(--green-800) 60%, var(--green-700) 100%) !important;
    box-shadow: 0 2px 24px rgba(0,0,0,0.25) !important;
    border-bottom: 2px solid var(--green-500);
}

header a, header .bx-menu {
    color: #fff !important;
}

header .text-lg {
    font-family: 'LatoWeb', sans-serif;
    font-weight: 800;
    font-size: 1.2rem;
    letter-spacing: 0.03em;
    background: linear-gradient(90deg, #fff 0%, var(--accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

header nav ul li a {
    color: #b6f5c8 !important;
    font-weight: 500;
    font-size: 0.97rem;
    transition: color 0.2s;
    letter-spacing: 0.01em;
}

header nav ul li a:hover {
    color: var(--accent) !important;
}

/* ---- MAIN CONTAINER ---- */
.main-container {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 1rem;
}

/* ---- DROPDOWN ---- */
.dropdown {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: var(--green-950);
    border: 1px solid var(--green-700);
    box-shadow: 0 8px 24px rgba(0,0,0,0.3);
    border-radius: 8px;
    min-width: 190px;
    z-index: 20;
    margin-top: 6px;
    overflow: hidden;
}

.nav-item:hover .dropdown,
.nav-item:focus-within .dropdown {
    display: block;
}

.dropdown li a {
    display: block;
    padding: 10px 18px;
    color: #b6f5c8;
    font-size: 0.92rem;
    font-family: 'DM Sans', sans-serif;
    transition: background 0.15s, color 0.15s;
}

.dropdown li a:hover {
    background: var(--green-800);
    color: var(--accent);
}

/* ---- BREADCRUMB ---- */
.breadcrumb {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    margin-bottom: 1.2rem;
    background: var(--green-100);
    padding: 0.5rem 1rem;
    border-radius: 8px;
    border-left: 4px solid var(--green-500);
}

.breadcrumb a {
    color: var(--green-700);
    text-decoration: none;
    font-weight: 500;
}

.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb i { color: var(--green-400); }

/* ---- SEARCH ---- */
input[type="text"] {
    background: #fff;
    border: 2px solid var(--green-200) !important;
    border-radius: 10px !important;
    transition: border 0.2s, box-shadow 0.2s;
    font-family: 'DM Sans', sans-serif;
    color: var(--text-main);
}

input[type="text"]:focus {
    border-color: var(--green-500) !important;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15) !important;
    outline: none;
}

/* ---- PROVIDER CARDS ---- */
.provider-card {
    background: #fff;
    border: 1.5px solid var(--green-100);
    border-radius: 12px !important;
    transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s;
    overflow: hidden;
}

.provider-card:hover {
    box-shadow: 0 6px 28px rgba(22, 163, 74, 0.18) !important;
    border-color: var(--green-400);
    transform: translateY(-2px);
}

.provider-card img {
    height: 80px;
    object-fit: contain;
    padding: 10px;
}

.provider-card h5 {
    color: var(--green-800);
    font-family: 'LatoWeb', sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    padding: 0 6px 8px;
}

/* ---- ADS ---- */
.space-y-4 img {
    border-radius: 10px;
    border: 2px solid var(--green-200);
}

/* ---- SLOT CARDS ---- */
#slot-cont .bg-white {
    background: #fff !important;
    border: 1.5px solid var(--green-100);
    border-radius: 14px !important;
    transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s;
    overflow: hidden;
}

#slot-cont .bg-white:hover {
    box-shadow: 0 8px 32px rgba(22, 163, 74, 0.18) !important;
    border-color: var(--green-400);
    transform: translateY(-3px);
}

.game-img {
    width: 100%;
    height: 140px;
    object-fit: cover;
}

/* player count badge */
#slot-cont .bg-black\/60 {
    background: rgba(5, 46, 22, 0.75) !important;
    border: 1px solid rgba(74, 222, 128, 0.3);
    backdrop-filter: blur(4px);
}

/* game title */
#slot-cont h5.font-semibold {
    font-family: 'LatoWeb', sans-serif;
    font-size: 0.82rem;
    font-weight: 700;
    color: var(--green-900);
    line-height: 1.3;
}

/* provider label */
#slot-cont .text-gray-500 {
    color: var(--green-600) !important;
    font-size: 0.72rem;
    font-weight: 500;
}

/* RTP label */
#slot-cont .text-sm.font-medium span:first-child {
    color: var(--green-700);
    font-weight: 600;
}

#slot-cont .text-sm.font-medium span:last-child {
    color: var(--green-800);
    font-weight: 700;
}

/* RTP bar track */
#slot-cont .bg-gray-200 {
    background-color: var(--green-100) !important;
    height: 6px;
    border-radius: 99px;
}

/* RTP bar fill - high */
.bg-emerald-500 { background-color: var(--green-500) !important; }
/* RTP bar fill - medium (amber replaced with lime-green) */
.bg-amber-500  { background-color: #84cc16 !important; }

/* ---- BUTTONS ---- */
/* Pola Gacor */
button.pola_gacor,
.bg-gray-600 {
    background: linear-gradient(135deg, var(--green-800), var(--green-700)) !important;
    border: none;
    color: #fff !important;
    font-family: 'DM Sans', sans-serif;
    font-weight: 600;
    font-size: 0.8rem;
    border-radius: 8px;
    cursor: pointer;
    transition: filter 0.2s, transform 0.15s;
}

button.pola_gacor:hover,
.hover\:bg-gray-700:hover {
    background: linear-gradient(135deg, var(--green-700), var(--green-600)) !important;
    filter: brightness(1.08);
}

/* Betting (red → dark green) */
.bg-red-600, a.bg-red-600 {
    background: linear-gradient(135deg, var(--green-900), var(--green-800)) !important;
    color: #fff !important;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.8rem;
    transition: filter 0.2s;
}
.bg-red-600:hover, .hover\:bg-red-700:hover {
    filter: brightness(1.12);
}

/* Demo (emerald) */
.bg-emerald-600, a.bg-emerald-600 {
    background: linear-gradient(135deg, var(--green-600), var(--green-500)) !important;
    color: #fff !important;
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.8rem;
    transition: filter 0.2s;
}
.bg-emerald-600:hover, .hover\:bg-emerald-700:hover, .bg-emerald-700 {
    background: linear-gradient(135deg, var(--green-700), var(--green-600)) !important;
    filter: brightness(1.08);
}

/* Load More */
.more_slot_games {
    background: linear-gradient(135deg, var(--green-600), var(--green-500)) !important;
    color: #fff !important;
    font-family: 'LatoWeb', sans-serif;
    font-weight: 700;
    border-radius: 10px;
    padding: 0.65rem 2.5rem;
    font-size: 0.95rem;
    letter-spacing: 0.02em;
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 18px rgba(22, 163, 74, 0.3);
    transition: box-shadow 0.2s, transform 0.15s, filter 0.2s;
}
.more_slot_games:hover {
    box-shadow: 0 6px 28px rgba(22, 163, 74, 0.45);
    transform: translateY(-2px);
    filter: brightness(1.06);
}
.more_slot_games.opacity-50 {
    background: var(--green-200) !important;
    color: var(--green-600) !important;
    box-shadow: none;
    transform: none;
    cursor: not-allowed;
}

/* ---- MODAL ---- */
.modal {
    transition: all 0.25s ease;
}
.modal:not(.hidden) {
    opacity: 1;
    visibility: visible;
}

/* modal overlay */
.modal.fixed {
    background: rgba(5, 46, 22, 0.55) !important;
    backdrop-filter: blur(4px);
}

/* modal card */
.modal .bg-white.rounded-xl {
    border: 1.5px solid var(--green-200);
    box-shadow: 0 20px 60px rgba(5, 46, 22, 0.25);
}

/* modal title */
.modal h5.font-bold {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
    font-size: 1rem;
}

/* modal info panel */
.modal .bg-gray-50 {
    background: var(--green-50) !important;
    border: 1px solid var(--green-100);
    border-radius: 10px;
}

/* modal close btn */
.close-btn {
    color: var(--green-700) !important;
    transition: color 0.2s;
}
.close-btn:hover { color: var(--green-900) !important; }

/* modal text */
.modal .text-gray-500 { color: var(--green-600) !important; }

/* modal jam gacor, pola gacor labels */
.modal strong { color: var(--green-800); }

/* modal Play Now btn */
.modal a.bg-red-600 {
    background: linear-gradient(135deg, var(--green-700), var(--green-500)) !important;
    color: #fff !important;
    border-radius: 10px;
    font-weight: 700;
    font-family: 'LatoWeb', sans-serif;
    box-shadow: 0 4px 16px rgba(22, 163, 74, 0.3);
    transition: filter 0.2s;
}
.modal a.bg-red-600:hover { filter: brightness(1.1); }

/* ---- FOOTER ---- */
footer {
    background: linear-gradient(90deg, var(--green-950) 0%, var(--green-900) 100%) !important;
    border-top: 2px solid var(--green-700);
    color: var(--green-300) !important;
    font-family: 'LatoWeb', sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    letter-spacing: 0.02em;
}

/* ---- UTILITY OVERRIDES ---- */
.bg-gray-100 { background: transparent !important; }
.text-emerald-600 { color: var(--green-600); }
.text-emerald-800 { color: var(--green-800); }
.hover\:text-emerald-800:hover { color: var(--green-800); }
.focus\:border-emerald-500:focus { border-color: var(--green-500); }
.focus\:ring-emerald-500:focus { --tw-ring-color: var(--green-500); }

/* section heading style */
main h2, main h3 {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
}

/* no-slot message */
.text-red-600 {
    color: var(--green-700) !important;
    background: var(--green-50);
    border: 1px solid var(--green-200);
    border-radius: 10px;
    font-family: 'LatoWeb', sans-serif;
}

/* scrollbar */
::-webkit-scrollbar { width: 7px; }
::-webkit-scrollbar-track { background: var(--green-50); }
::-webkit-scrollbar-thumb { background: var(--green-400); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--green-600); }

/* =========================================
   GAME.PHP - Slot Detail Page
   ========================================= */

/* header logo xl variant (game.php uses text-xl) */
header .text-xl {
    font-family: 'LatoWeb', sans-serif;
    font-weight: 800;
    letter-spacing: 0.03em;
    background: linear-gradient(90deg, #fff 0%, var(--accent) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

/* blue links → green (nav, provider link, game number) */
.text-blue-500, a.text-blue-500 {
    color: var(--green-600) !important;
}
.text-blue-500:hover, a.text-blue-500:hover {
    color: var(--green-800) !important;
}

/* bg-blue-500 → green (Play Demo button, game-btn-play) */
.bg-blue-500, button.bg-blue-500 {
    background: linear-gradient(135deg, var(--green-600), var(--green-500)) !important;
    color: #fff !important;
    border: none;
    transition: filter 0.2s;
}
.bg-blue-500:hover, button.bg-blue-500:hover {
    filter: brightness(1.1);
}

/* bg-red-500 → deep green (Situs Slot button) */
.bg-red-500, a.bg-red-500 {
    background: linear-gradient(135deg, var(--green-900), var(--green-800)) !important;
    color: #fff !important;
    border: none;
    transition: filter 0.2s;
}
.bg-red-500:hover { filter: brightness(1.12); }

/* bg-gray-500 → green-700 (Fullscreen, Pola Gacor buttons) */
.bg-gray-500, button.bg-gray-500 {
    background: linear-gradient(135deg, var(--green-800), var(--green-700)) !important;
    color: #fff !important;
    border: none;
    transition: filter 0.2s;
}
.bg-gray-500:hover { filter: brightness(1.1); }

/* game.php - slot iframe container */
.slot-iframe {
    border-radius: 14px;
    overflow: hidden;
    border: 2px solid var(--green-300);
    box-shadow: 0 8px 32px rgba(5, 46, 22, 0.18);
    position: relative;
}

.slot-iframe-con {
    background: rgba(5, 46, 22, 0.55);
    backdrop-filter: blur(6px);
    min-height: 320px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.slot-play {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem 0;
}

.slot-play-cont {
    background: rgba(5, 46, 22, 0.7);
    border: 1px solid var(--green-500);
    border-radius: 14px;
    padding: 1.5rem 2rem;
    gap: 1.5rem;
}

.slot-iframe-img img {
    border: 2px solid var(--green-400);
    box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}

.slot-iframe-bottom {
    background: rgba(5, 46, 22, 0.6);
    border-top: 1px solid var(--green-700);
    padding: 0.5rem;
    border-radius: 0 0 12px 12px;
}

/* user online badge - game.php */
.user-online {
    background: rgba(5, 46, 22, 0.8) !important;
    border: 1px solid var(--green-500);
    border-radius: 20px;
    backdrop-filter: blur(4px);
}

/* ratio / iframe */
.ratio { position: relative; }
.ratio-16x9 { padding-bottom: 56.25%; }
.ratio iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

/* game.php - sidebar */
.sidebar {
    background: #fff;
    border: 1.5px solid var(--green-100);
    border-radius: 14px;
    padding: 1.25rem;
    box-shadow: var(--shadow);
}

.sidebar h5.font-bold, .sidebar h5 {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
    font-weight: 700;
}

/* top game cards */
.top-game-card {
    display: flex;
    margin-bottom: 0.75rem;
    border: 1.5px solid var(--green-100) !important;
    border-radius: 12px !important;
    transition: box-shadow 0.2s, border-color 0.2s, transform 0.15s;
    text-decoration: none;
}

.top-game-card:hover {
    box-shadow: 0 4px 20px rgba(22, 163, 74, 0.18) !important;
    border-color: var(--green-400) !important;
    transform: translateX(3px);
}

.game-btn-play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(5, 46, 22, 0.55);
    opacity: 0;
    transition: opacity 0.2s;
    border-radius: 8px;
}

.game-img:hover .game-btn-play { opacity: 1; }

.top-game-card h5 {
    font-family: 'LatoWeb', sans-serif;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--green-900);
}

.top-game-card .text-gray-500 {
    color: var(--green-600) !important;
    font-size: 0.78rem;
}

.game-number {
    color: var(--green-500) !important;
    font-family: 'LatoWeb', sans-serif;
    font-size: 1.2rem !important;
}

/* game.php - stats panel */
.game-stats-con {
    font-size: 0.9rem;
}

.game-stats {
    padding-bottom: 0.6rem;
    border-bottom: 1px solid var(--green-100);
    margin-bottom: 0.6rem;
}

.game-stats strong.text-gray-500 {
    color: var(--green-700) !important;
    font-weight: 600;
}

.progress-con {
    background: var(--green-100);
    border-radius: 99px;
    height: 6px;
    margin-top: 4px;
    overflow: hidden;
}

.progress-bar {
    height: 6px;
    border-radius: 99px;
    background: linear-gradient(90deg, var(--green-500), var(--green-400));
}

/* game.php - article section */
.content_article h1 {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
    font-size: 1.4rem;
    font-weight: 800;
    line-height: 1.3;
}

.content_article p {
    color: #2d4a35;
    line-height: 1.8;
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.content_article a {
    color: var(--green-600);
    font-weight: 600;
    text-decoration: underline;
}

.content_article strong {
    color: var(--green-800);
}

/* loading spinner */
.lds-ellipsis {
    display: inline-block;
    position: relative;
    width: 80px;
    height: 80px;
}
.lds-ellipsis div {
    position: absolute;
    top: 33px;
    width: 13px;
    height: 13px;
    border-radius: 50%;
    background: var(--green-500);
    animation-timing-function: cubic-bezier(0, 1, 1, 0);
}
.lds-ellipsis div:nth-child(1) { left: 8px; animation: lds-e1 0.6s infinite; }
.lds-ellipsis div:nth-child(2) { left: 8px; animation: lds-e2 0.6s infinite; }
.lds-ellipsis div:nth-child(3) { left: 32px; animation: lds-e2 0.6s infinite; }
.lds-ellipsis div:nth-child(4) { left: 56px; animation: lds-e3 0.6s infinite; }
@keyframes lds-e1 { 0% { transform: scale(0); } 100% { transform: scale(1); } }
@keyframes lds-e2 { 0% { transform: translate(0,0); } 100% { transform: translate(24px,0); } }
@keyframes lds-e3 { 0% { transform: scale(1); } 100% { transform: scale(0); } }

/* modal - rounded-lg variant (game.php modals use rounded-lg not rounded-xl) */
.modal .bg-white.rounded-lg {
    border: 1.5px solid var(--green-200);
    box-shadow: 0 20px 60px rgba(5, 46, 22, 0.25);
}

/* =========================================
   SEARCH.PHP - Search Results Page
   ========================================= */

/* search.php uses container mx-auto, not main-container */
.container { max-width: 1180px; }

/* search result slot cards (not inside #slot-cont wrapper with same bg) */
#slot-cont .bg-white.p-4.rounded {
    border: 1.5px solid var(--green-100) !important;
    border-radius: 12px !important;
    transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s;
    padding: 0 !important;
    overflow: hidden;
}

#slot-cont .bg-white.p-4.rounded:hover {
    box-shadow: 0 8px 28px rgba(22, 163, 74, 0.2) !important;
    border-color: var(--green-400) !important;
    transform: translateY(-3px);
}

/* search page inner card padding */
#slot-cont .bg-white.p-4.rounded > .relative img {
    border-radius: 0;
}

#slot-cont .bg-white.p-4.rounded > .mt-2,
#slot-cont .bg-white.p-4.rounded > .flex,
#slot-cont .bg-white.p-4.rounded > .h-2,
#slot-cont .bg-white.p-4.rounded > .mt-3 {
    padding: 0 0.75rem;
}

#slot-cont .bg-white.p-4.rounded > .mt-3 {
    padding-bottom: 0.75rem;
}

/* search "no results" text */
#slot-cont > p {
    color: var(--green-700);
    font-family: 'LatoWeb', sans-serif;
    padding: 1rem;
    background: var(--green-50);
    border-radius: 10px;
    border: 1px solid var(--green-200);
    grid-column: 1 / -1;
}

/* search page heading */
main h1 {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
    font-weight: 800;
}

/* =========================================
   PROVIDER.PHP - Provider Detail Page
   ========================================= */

/* provider hero image */
.provider-img {
    max-height: 100px;
    object-fit: contain;
    filter: drop-shadow(0 4px 12px rgba(22, 163, 74, 0.2));
}

/* provider description */
.provider-description {
    color: #2d4a35;
    font-size: 0.95rem;
    line-height: 1.7;
    background: var(--green-50);
    border: 1px solid var(--green-200);
    border-radius: 10px;
    padding: 1rem 1.25rem;
}

/* provider.php slot cards (use same .bg-white.p-4.rounded pattern) */
#slot-cont .bg-white.p-4.rounded.shadow {
    border: 1.5px solid var(--green-100) !important;
    border-radius: 12px !important;
    padding: 0 !important;
    overflow: hidden;
    transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s;
}

#slot-cont .bg-white.p-4.rounded.shadow:hover {
    box-shadow: 0 8px 28px rgba(22, 163, 74, 0.2) !important;
    border-color: var(--green-400) !important;
    transform: translateY(-3px);
}

/* provider.php h1 */
main h1.text-2xl {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
    font-weight: 800;
}

/* provider.php h3 headings */
main h3.text-xl {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
}

/* "No slots available" error text */
.text-red-500 {
    color: var(--green-700) !important;
    background: var(--green-50);
    border: 1px solid var(--green-200);
    border-radius: 10px;
    padding: 1rem;
}

/* =========================================
   SITUS.PHP - Site Listing Page
   ========================================= */

/* situs card */
.site-card {
    background: #fff;
    border: 1.5px solid var(--green-100) !important;
    border-radius: 14px !important;
    transition: box-shadow 0.2s, border-color 0.2s, transform 0.2s;
    overflow: hidden;
}

.site-card:hover {
    box-shadow: 0 8px 32px rgba(22, 163, 74, 0.18) !important;
    border-color: var(--green-400) !important;
    transform: translateY(-3px);
}

.site-card h5 {
    font-family: 'LatoWeb', sans-serif;
    font-weight: 700;
    color: var(--green-900);
    font-size: 0.9rem;
}

/* "Kunjungi Situs" button (bg-blue-500) already covered, + hover */
.hover\:bg-blue-600:hover {
    filter: brightness(1.1);
}

/* progress bars in situs.php */
.site-card .progress-bar {
    background: var(--green-100);
    border-radius: 99px;
    height: 6px;
    margin-top: 3px;
    overflow: hidden;
    /* override any misuse of class as fill */
    width: 100% !important;
}

.site-card .progress-fill {
    height: 6px;
    border-radius: 99px;
    background: linear-gradient(90deg, var(--green-600), var(--green-400));
    transition: width 0.5s ease;
}

/* situs stat labels */
.site-card .flex.justify-between span:first-child {
    color: var(--green-700);
    font-size: 0.8rem;
    font-weight: 500;
}

.site-card .flex.justify-between span:last-child {
    color: var(--green-800);
    font-size: 0.8rem;
    font-weight: 700;
}

/* collapsible buttons */
.collapsible-btn {
    background: var(--green-50) !important;
    color: var(--green-800) !important;
    border: 1px solid var(--green-200);
    border-radius: 8px;
    font-weight: 600;
    font-size: 0.82rem;
    font-family: 'DM Sans', sans-serif;
    transition: background 0.15s, border-color 0.15s;
    cursor: pointer;
}

.collapsible-btn:hover {
    background: var(--green-100) !important;
    border-color: var(--green-400);
}

.collapsible-btn i {
    color: var(--green-500);
    transition: transform 0.2s;
}

/* collapsible content */
.collapsible-content {
    display: none;
    font-size: 0.85rem;
    color: #2d4a35;
    line-height: 1.6;
    padding: 0.5rem 0.25rem;
}

.collapsible-content.active { display: block; }

.collapsible-content ul { padding-left: 1.25rem; }
.collapsible-content li { margin-bottom: 0.2rem; color: #2d4a35; }

/* alt links */
.collapsible-content a {
    color: var(--green-600) !important;
    text-decoration: underline;
    font-weight: 500;
}

/* situs.php h1 */
main h1.text-3xl {
    font-family: 'LatoWeb', sans-serif;
    color: var(--green-900);
    font-weight: 800;
}

/* gray text in situs */
.text-gray-600 { color: #2d4a35 !important; }