:root{
--bg:#0f1115;
--card:#151822;
--mint:#7EE0C2;
--mint-2:#3ec9a0;
--text:#E9EEF2;
--muted:#A8B0B8;
--border:#222736;
--accent:#89B4FA;
--danger:#ff6b6b;
--shadow: 0 10px 30px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{
margin:0;
padding:0;
background:linear-gradient(180deg,#0f1115 0%, #0f1218 100%);
color:var(--text);
font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;
line-height:1.6;
position: relative;
overflow-x: hidden;
}

/* 🌠 Soft Random Starfield */
body::before {
content: "";
position: fixed;
inset: 0;
z-index: -2;
background: radial-gradient(2px 2px at 20% 30%, white, transparent),
radial-gradient(1.5px 1.5px at 70% 80%, white, transparent),
radial-gradient(2px 2px at 50% 10%, white, transparent),
radial-gradient(1px 1px at 80% 50%, white, transparent),
radial-gradient(1.5px 1.5px at 30% 70%, white, transparent);
background-size: 100% 100%;
animation: driftStars 80s linear infinite;
opacity: 0.18;
pointer-events: none;
}

body::after {
content: "";
position: fixed;
inset: 0;
z-index: -1;
background: radial-gradient(1px 1px at 10% 20%, rgba(255,255,255,0.9), transparent),
radial-gradient(1.5px 1.5px at 60% 40%, rgba(255,255,255,0.7), transparent),
radial-gradient(1px 1px at 90% 70%, rgba(255,255,255,0.8), transparent),
radial-gradient(1px 1px at 40% 90%, rgba(255,255,255,0.6), transparent);
animation: floatStars 120s ease-in-out infinite alternate;
opacity: 0.15;
pointer-events: none;
}

@keyframes driftStars {
0% { transform: translate3d(0, 0, 0) rotate(0deg); }
50% { transform: translate3d(-2%, 1%, 0) rotate(1deg); }
100% { transform: translate3d(2%, -1%, 0) rotate(-1deg); }
}
@keyframes floatStars {
0% { transform: translate(0px, 0px) scale(1); }
50% { transform: translate(-10px, 6px) scale(1.03); }
100% { transform: translate(8px, -8px) scale(1.02); }
}

/* --- Core Layouts --- */
a{color:var(--mint);text-decoration:none}
a:hover{color:var(--mint-2)}

.container{max-width:1050px;margin:0 auto;padding:24px}

header.site-header{
position:sticky;top:0;z-index:50;background:rgba(15,17,21,.7);
backdrop-filter: blur(10px);border-bottom:1px solid var(--border)
}
nav.navbar{display:flex;align-items:center;justify-content:center;gap:20px;padding:14px 22px}
.brand{display:flex;align-items:center;gap:12px}
.brand .logo{
width:40px;height:40px;border-radius:12px;display:grid;place-items:center;
background: radial-gradient(100% 100% at 100% 0%, #86F5D2 0%, #2E8B75 100%);
color:#0b1311;font-weight:800;box-shadow: var(--shadow)
}
.brand .title{font-family:"Playfair Display",serif;font-weight:700;font-size:20px;letter-spacing:.3px}

.nav-links{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.nav-links a{
padding:8px 12px;border:1px solid transparent;border-radius:10px;color:var(--text)
}
.nav-links a.active,.nav-links a:hover{border-color:var(--border);background:#131725}

/* --- Hero Section --- */
.hero{padding:48px 22px;text-align:center}
.hero h1{
font-family:"Playfair Display",serif;
font-size: clamp(28px,4vw,44px);
margin-bottom:10px;
}
.hero p{color:var(--muted);margin-bottom:24px}

/* Centered Countdown */
.countdown{
display:flex;
justify-content:center;
gap:16px;
flex-wrap:wrap;
margin:24px auto;
}
.count-chip{
padding:18px 22px;
border:1px solid var(--border);
border-radius:12px;
background:#121624;
min-width:120px;
text-align:center;
box-shadow:var(--shadow);
}
.count-chip .n{font-weight:800;font-size:26px;color:var(--accent)}
.count-chip .l{font-size:14px;color:var(--muted)}

/* --- Lodging Page: “Jigsaw” Layout --- */
#villa-slideshow {
grid-column: 1 / span 2;
position: relative;
border-radius: 10px;
overflow: hidden;
height: 360px;
box-shadow: 0 6px 18px rgba(0,0,0,0.4);
}
#villa-slideshow .slide {
position: absolute;
inset: 0;
background-size: cover;
background-position: center;
opacity: 0;
transition: opacity 2.5s ease-in-out;
filter: brightness(60%) contrast(1.1);
}
#villa-slideshow .slide.active { opacity: 1; }
#villa-slideshow .overlay {
position: absolute;
bottom: 0;left: 0;right: 0;
background: linear-gradient(to top, rgba(0, 0, 0, 0.7), transparent 70%);
color: #fff;
padding: 2rem;
}
#villa-slideshow h2 {
font-family: "Playfair Display", serif;
font-size: 2.2rem;
margin: 0;
}
#villa-slideshow p {
font-size: 1.05rem;
margin-top: 0.75rem;
opacity: 0.95;
}

/* Grid Layout with Puzzle Feel */
.lodging-grid {
display: grid;
grid-template-columns: 1.2fr 0.8fr;
grid-template-rows: auto auto;
gap: 1.5rem;
}
.lodging-grid .card:nth-child(1) { grid-column: 1; grid-row: 2; }
.lodging-grid .card:nth-child(2) { grid-column: 2; grid-row: 1 / span 2; }
.lodging-grid .map-frame { height: 100%; border-radius: 12px; overflow: hidden; }

.card{background:linear-gradient(180deg,#121624 0%,#0f121a 100%);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow)}
.card.pad{padding:20px}

/* --- Footer --- */
footer {
background: rgba(255, 255, 255, 0.08);
color: #f5f5f5;
border-top: 1px solid rgba(255, 255, 255, 0.15);
text-align: center;
padding: 20px;
margin-top: 40px;
backdrop-filter: blur(6px);
}

/* --- Animations for details (events dropdowns) --- */
.itinerary details {
background: rgba(18, 22, 28, 0.9);
border: 1px solid var(--border);
border-radius: 12px;
margin-bottom: 1rem;
box-shadow: 0 4px 15px rgba(0,0,0,0.4);
overflow: hidden;
transition: all 0.3s ease;
}
.itinerary details[open] { transform: scale(1.01); border-color: var(--mint); }
.itinerary summary {
cursor: pointer;
font-weight: 600;
padding: 1rem 1.25rem;
font-size: 1.1rem;
background: #151a22;
color: var(--text);
border-bottom: 1px solid rgba(255,255,255,0.08);
border-radius: 12px 12px 0 0;
transition: background 0.3s ease;
}
.itinerary summary:hover { background: #1b1f2a; color: var(--mint); }
.itinerary ul { padding: 1rem 1.5rem; color: var(--muted); }

/* Forum style */
.post {
  background: rgba(15, 18, 27, 0.9);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  margin-bottom: 1rem;
  box-shadow: var(--shadow);
}

.post .meta {
  color: var(--muted);
  font-size: 0.9rem;
  margin-bottom: 6px;
}

.replies-wrapper {
  margin-top: 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px;
}

.replies-wrapper summary {
  font-weight: 600;
  color: var(--mint);
  cursor: pointer;
}

.replies-wrapper[open] {
  background: rgba(255,255,255,0.06);
}

.replies {
  margin-top: 8px;
  padding-left: 12px;
  border-left: 2px solid var(--border);
}

.reply {
  margin-bottom: 6px;
  background: rgba(255,255,255,0.05);
  border-radius: 6px;
  padding: 6px 8px;
}

.reply summary {
  cursor: pointer;
  font-size: 0.95rem;
  color: var(--accent);
}

.reply p {
  margin: 6px 0;
  font-size: 0.95rem;
  color: var(--text);
}

.reply-text {
  width: 100%;
  background: #0f121a;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px;
  color: var(--text);
  margin-top: 6px;
}

.send-reply {
  margin-top: 6px;
  background: var(--mint);
  color: #000;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  padding: 6px 10px;
  cursor: pointer;
}

/* Fade-in animation for posts and replies */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

.post, .reply {
  animation: fadeIn 0.4s ease both;
}

/* Shimmer effect while loading */
.loading-shimmer {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,0.05) 25%,
    rgba(255,255,255,0.1) 37%,
    rgba(255,255,255,0.05) 63%
  );
  background-size: 400% 100%;
  animation: shimmer 1.2s infinite linear;
  border-radius: 12px;
  height: 90px;
  margin-bottom: 10px;
}

@keyframes shimmer {
  0% { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

#postBody {
  width: 100%;
  padding: 12px;
  border-radius: 8px;
  border: 1px solid #333;
  background: #111;
  color: #eee;
  margin-bottom: 10px;
}

#submitPost {
  padding: 10px 18px;
  border-radius: 8px;
  background: #4be6b5;
  border: none;
  cursor: pointer;
  font-weight: bold;
}
#submitPost:hover {
  filter: brightness(1.1);
}

/* --- Forum Chat Bubbles (accessible + dark mode consistent) --- */
.post {
  background: linear-gradient(180deg, #161a24 0%, #10131b 100%);
  border-left: 4px solid var(--mint-2);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 1.2rem;
  color: var(--text);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.5);
  font-size: 1.05rem; /* larger text for readability */
  line-height: 1.7;
  transition: transform 0.1s ease, box-shadow 0.1s ease;
}

.post:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.6);
}

.meta {
  font-size: 0.95rem;
  color: var(--muted);
  margin-top: 10px;
  display: block;
  font-style: italic;
}

/* visually separate the user's own posts */
.post.mine {
  background: linear-gradient(180deg, #1a2b26 0%, #152520 100%);
  border-left-color: var(--mint);
}

/* Make all text slightly larger for accessibility site-wide */
body {
  font-size: 1.05rem;
  letter-spacing: 0.3px;
}

.email-link {
  color: var(--mint);
  font-weight: 600;
  text-decoration: none;
  word-break: break-all;
}

.email-link:hover {
  color: var(--mint-2);
  text-decoration: underline;
}




