:root {
    --bg-main: #0f172a;        /* Midnight Blue */
    --bg-card: #1e293b;        /* Slate Blue */
    --accent: #10b981;          /* Emerald Green - Simbol Kesehatan */
    --text-primary: #f1f5f9;    /* Ghost Grey */
    --text-secondary: #94a3b8;  /* Muted Grey */
    --fraunces: 'Fraunces', serif;
}

* {
    margin: 0; padding: 0; box-sizing: border-box;
}

body {
    font-family: 'Plus Jakarta Sans', sans-serif;
    background-color: var(--bg-main);
    color: var(--text-primary);
    line-height: 1.6;
    scroll-behavior: smooth;
}

.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* Navbar */
.navbar {
    background: rgba(15, 23, 42, 0.9);
    backdrop-filter: blur(10px);
    padding: 1rem 0;
    position: fixed; width: 100%; top: 0; z-index: 1000;
}

.nav-container { display: flex; justify-content: space-between; align-items: center; }

.logo { font-weight: 800; font-size: 1.3rem; letter-spacing: 1px; }
.logo span { color: var(--accent); }

.nav-links { list-style: none; display: flex; gap: 30px; }
.nav-links a { text-decoration: none; color: var(--text-secondary); font-weight: 600; transition: 0.3s; }
.nav-links a:hover { color: var(--accent); }

.btn-cta-nav {
    background: var(--accent); color: var(--bg-main); padding: 10px 20px;
    border-radius: 8px; text-decoration: none; font-weight: 700;
}

/* Hero Section */
.hero {
    height: 100vh;
    background: url('galeri/pijat.jpg') center/cover;
    display: flex; align-items: center; position: relative;
}

.hero-overlay {
    position: absolute; width: 100%; height: 100%;
    background: linear-gradient(to right, #0f172ad0, #0f172a50);
}

.hero-content { position: relative; z-index: 2; max-width: 700px; }

.badge {
    background: rgba(16, 185, 129, 0.2);
    color: var(--accent);
    padding: 5px 15px; border-radius: 20px; font-size: 0.8rem;
    display: inline-block; margin-bottom: 20px;
}

.hero h1 { font-family: var(--fraunces); font-size: clamp(3rem, 8vw, 5rem); line-height: 1.1; margin-bottom: 20px; }
.hero h1 span { color: var(--accent); }

.hero-actions { display: flex; gap: 15px; }

.btn-main {
    background: var(--accent); color: var(--bg-main); padding: 15px 30px;
    text-decoration: none; font-weight: 800; border-radius: 8px;
}

.btn-alt {
    border: 1px solid var(--text-secondary); color: var(--text-primary);
    padding: 15px 30px; text-decoration: none; border-radius: 8px;
}

/* Services */
.services { padding: 100px 0; background: #0b1120; }
.section-title { text-align: center; font-family: var(--fraunces); font-size: 2.5rem; margin-bottom: 50px; }

.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 20px; }

.service-card {
    background: var(--bg-card); padding: 40px 30px; border-radius: 15px;
    transition: 0.4s; border: 1px solid #334155;
}

.service-card i { font-size: 2.5rem; color: var(--accent); margin-bottom: 20px; display: block; }
.service-card:hover { transform: translateY(-10px); border-color: var(--accent); }
.service-card.active { background: var(--accent); color: var(--bg-main); }
.service-card.active i { color: var(--bg-main); }

/* Location */
.location-box {
    display: grid; grid-template-columns: 1fr 1.2fr;
    background: var(--bg-card); border-radius: 20px; overflow: hidden; margin: 100px 0;
}

.location-info { padding: 50px; }
.location-info h2 { margin-bottom: 20px; font-family: var(--fraunces); }
.btn-map {
    display: inline-block; margin-top: 30px; color: var(--accent);
    text-decoration: none; font-weight: 700; border-bottom: 2px solid var(--accent);
}

/* Footer */
footer { padding: 50px 0; border-top: 1px solid #1e293b; text-align: center; }

@media (max-width: 768px) {
    .nav-links { display: none; }
    .location-box { grid-template-columns: 1fr; }
    .hero h1 { font-size: 3rem; }
    .hero-actions { flex-direction: column; }
}