/* ===== CSS VARIABLES ===== */
/* ki-svg: icon SVG di info kontak */
.ki-svg{width:17px;height:17px;flex-shrink:0;margin-top:3px;stroke:var(--color-accent);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

:root{
  --color-bg:#0c0c0c;--color-bg-alt:#111;--color-surface:#161616;--color-border:#222;
  --color-accent:#DC2626;--color-accent-light:#EF4444;--color-accent-dark:#B91C1C;
  --color-text:#EBEBEB;--color-text-secondary:#888;--color-text-muted:#555;
  --color-light-bg:#F5F3EF;--color-light-text:#1a1a1a;--color-light-secondary:#555;
  --font-head:'Inter',sans-serif;--font-body:'Inter',sans-serif;
  --text-xs:.72rem;--text-sm:.85rem;--text-base:1rem;--text-lg:1.1rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.8rem;--text-5xl:4rem;
  --radius:8px;--radius-lg:16px;--radius-xl:24px;
  --shadow:0 4px 24px rgba(0,0,0,.4);--shadow-lg:0 12px 48px rgba(0,0,0,.5);
  --transition:.25s ease;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;font-size:16px;}
body{background:var(--color-bg);color:var(--color-text);font-family:var(--font-body);line-height:1.7;overflow-x:hidden;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
ul{list-style:none;}
svg{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
section{padding:96px 0;}
.section-light{background:var(--color-light-bg);}
.section-header{text-align:center;margin-bottom:60px;}
.eyebrow{font-size:var(--text-xs);font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);margin-bottom:14px;}
.eyebrow-dark{color:var(--color-accent-dark);}
.section-title{font-size:var(--text-4xl);font-weight:800;line-height:1.1;margin-bottom:16px;}
.section-title.dark{color:var(--color-light-text);}
.section-subtitle{font-size:var(--text-lg);color:var(--color-text-secondary);max-width:560px;margin:0 auto;}
.section-subtitle.dark{color:var(--color-light-secondary);}

/* ===== REVEAL ANIMATION ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:none;}

/* ===== HEADER ===== */
#header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:background var(--transition),padding var(--transition),backdrop-filter var(--transition);}
#header.scrolled{background:rgba(12,12,12,.95);backdrop-filter:blur(16px);padding:12px 0;border-bottom:1px solid var(--color-border);}
.header-inner{display:flex;align-items:center;gap:32px;}
.logo{font-size:var(--text-xl);font-weight:900;letter-spacing:.08em;color:var(--color-text);display:flex;align-items:center;gap:10px;}
.logo-img{width:36px;height:36px;object-fit:contain;flex-shrink:0;border-radius:4px;}

.logo span{color:var(--color-accent);}
.nav-links{display:flex;gap:32px;}
.nav-links a{font-size:var(--text-sm);font-weight:500;letter-spacing:.04em;color:var(--color-text-secondary);transition:color var(--transition);position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--color-accent);transition:width var(--transition);}
.nav-links a:hover,.nav-links a.active{color:var(--color-text);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.btn-header-cta{margin-left:auto;padding:9px 22px;background:var(--color-accent);color:#000;font-size:var(--text-sm);font-weight:700;border-radius:var(--radius);letter-spacing:.04em;transition:background var(--transition),transform var(--transition);}
.btn-header-cta:hover{background:var(--color-accent-light);transform:translateY(-1px);}
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px;width:36px;}
.hamburger span{display:block;height:2px;background:var(--color-text);border-radius:2px;transition:transform .3s,opacity .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(12,12,12,.98);z-index:999;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:0;pointer-events:none;transition:opacity .3s;}
.mobile-nav.open{opacity:1;pointer-events:all;}
.mobile-nav-link{font-size:var(--text-2xl);font-weight:700;color:var(--color-text);}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:var(--radius);font-weight:700;font-size:var(--text-sm);transition:all var(--transition);}
.btn-primary{background:var(--color-accent);color:#000;}
.btn-wa{background:#25D366;color:#fff;}
.btn-gold-outline{border:2px solid var(--color-accent);color:var(--color-accent);}
.btn-gold-outline:hover{background:var(--color-accent);color:#000;}
/* ===== HERO ===== */
#hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;overflow:hidden;}
.hero-bg{position:absolute;inset:0;background:url('img/hero.jpg') center/cover no-repeat;}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(12,12,12,.92) 0%,rgba(12,12,12,.75) 100%);}
.hero-vertical-text{position:absolute;right:24px;top:50%;transform:translateY(-50%) rotate(90deg);font-size:var(--text-xs);letter-spacing:.25em;color:var(--color-text-muted);text-transform:uppercase;}
.hero-content{position:relative;z-index:1;max-width:720px;}
.hero-eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:28px;}
.eyebrow-line{width:48px;height:2px;background:var(--color-accent);}
.hero-eyebrow span{font-size:var(--text-xs);font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--color-accent);}
.hero-title{line-height:1;margin-bottom:20px;}
.ht-small{display:block;font-size:clamp(1.2rem,3vw,1.8rem);font-weight:300;letter-spacing:.12em;color:var(--color-text-secondary);text-transform:uppercase;}
.ht-large{display:block;font-size:clamp(4rem,10vw,8rem);font-weight:900;letter-spacing:-.02em;line-height:.9;}
.ht-accent{display:block;font-size:clamp(3rem,8vw,6.5rem);font-weight:900;color:var(--color-accent);letter-spacing:-.02em;}
.hero-tagline{font-size:var(--text-lg);color:var(--color-text-secondary);margin-bottom:36px;max-width:480px;}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;}
.btn-hero-primary{display:inline-flex;align-items:center;gap:10px;padding:16px 32px;background:var(--color-accent);color:#000;font-weight:800;font-size:var(--text-base);border-radius:var(--radius);letter-spacing:.04em;transition:all var(--transition);}
.btn-hero-primary:hover{background:var(--color-accent-light);transform:translateY(-2px);}
.btn-hero-secondary{display:inline-flex;align-items:center;padding:16px 32px;border:2px solid rgba(255,255,255,.25);color:var(--color-text);font-weight:600;border-radius:var(--radius);transition:all var(--transition);}
.btn-hero-secondary:hover{border-color:var(--color-accent);color:var(--color-accent);}
.btn-arrow{font-size:1.1em;}
.scroll-indicator-line{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;}
.scroll-line-inner{width:1px;height:48px;background:linear-gradient(to bottom,transparent,var(--color-accent));animation:scrollPulse 2s ease-in-out infinite;}
.scroll-label{font-size:var(--text-xs);letter-spacing:.2em;color:var(--color-text-muted);}
@keyframes scrollPulse{0%,100%{opacity:.4;transform:scaleY(1);}50%{opacity:1;transform:scaleY(1.1);}}

/* ===== TENTANG ===== */
#tentang{padding-top:112px;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start;margin-top:48px;}
.about-img-wrap{position:relative;}
.about-img-wrap img{width:100%;border-radius:var(--radius-lg);aspect-ratio:3/4;object-fit:cover;}
.img-label-vertical{position:absolute;right:-16px;top:50%;transform:translateY(-50%) rotate(90deg);font-size:var(--text-xs);letter-spacing:.2em;color:var(--color-text-muted);white-space:nowrap;}
.about-tabs{display:flex;gap:0;margin-bottom:28px;border-bottom:1px solid var(--color-border);}
.about-tab{padding:10px 20px;font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition);}
.about-tab.active{color:var(--color-accent);border-bottom-color:var(--color-accent);}
.about-tab-pane{display:none;}
.about-tab-pane.active{display:block;}
.about-tab-pane p{font-size:var(--text-base);color:var(--color-text-secondary);line-height:1.8;}
.about-contact-row{margin-top:28px;display:flex;flex-direction:column;gap:12px;}
.acr-item{display:flex;align-items:flex-start;gap:10px;font-size:var(--text-sm);color:var(--color-text-secondary);}
.acr-item svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;stroke:var(--color-accent);}

/* ===== PAKET ===== */
#paket{text-align:center;}
.packages-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;margin-top:48px;}
.pkg-card{background:#fff;border-radius:var(--radius-lg);padding:32px 24px;position:relative;text-align:left;border:2px solid transparent;transition:all var(--transition);}
.pkg-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.1);}
.pkg-card.featured{border-color:var(--color-accent-dark);box-shadow:0 8px 32px rgba(201,168,76,.15);}
.pkg-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--color-accent-dark);color:#fff;font-size:var(--text-xs);font-weight:700;padding:4px 16px;border-radius:20px;white-space:nowrap;letter-spacing:.05em;}
.pkg-duration-badge{display:inline-block;background:var(--color-accent);color:#000;font-size:var(--text-xs);font-weight:700;padding:3px 12px;border-radius:20px;margin-bottom:16px;letter-spacing:.06em;}
.pkg-name{font-size:var(--text-xl);font-weight:800;color:var(--color-light-text);margin-bottom:8px;}
.pkg-price{font-size:var(--text-3xl);font-weight:900;color:var(--color-accent-dark);margin-bottom:8px;line-height:1;}
.pkg-desc{font-size:var(--text-sm);color:var(--color-light-secondary);margin-bottom:20px;line-height:1.6;}
.pkg-benefits{display:flex;flex-direction:column;gap:8px;margin-bottom:28px;}
.pkg-benefits li{font-size:var(--text-sm);color:var(--color-light-secondary);padding-left:20px;position:relative;}
.pkg-benefits li::before{content:'✓';position:absolute;left:0;color:var(--color-accent-dark);font-weight:700;}
.pkg-cta{display:block;text-align:center;padding:13px;background:var(--color-light-text);color:#fff;font-weight:700;font-size:var(--text-sm);border-radius:var(--radius);transition:all var(--transition);}
.pkg-card.featured .pkg-cta{background:var(--color-accent-dark);}
.pkg-cta:hover{opacity:.85;transform:translateY(-1px);}
/* ===== GALERI ===== */
.gallery-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:36px;}
.gal-filter-btn{padding:8px 20px;border-radius:20px;font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary);border:1px solid var(--color-border);transition:all var(--transition);}
.gal-filter-btn.active,.gal-filter-btn:hover{background:var(--color-accent);color:#000;border-color:var(--color-accent);}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;}
.gallery-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/3;cursor:pointer;}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-caption{position:absolute;bottom:0;left:0;right:0;padding:20px 16px 16px;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);transform:translateY(100%);transition:transform .3s ease;}
.gallery-item:hover .gallery-caption{transform:none;}
.gallery-caption strong{display:block;font-size:var(--text-sm);font-weight:700;}
.gallery-caption span{font-size:var(--text-xs);color:rgba(255,255,255,.75);}

/* ===== TESTIMONI ===== */
#testimoni{text-align:center;}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:48px;}
.testi-card{background:#fff;border-radius:var(--radius-lg);padding:32px;text-align:left;box-shadow:0 4px 20px rgba(0,0,0,.06);transition:transform var(--transition),box-shadow var(--transition);}
.testi-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.1);}
.testi-stars{display:flex;gap:3px;margin-bottom:16px;}
.star{font-size:1rem;color:#ddd;}
.star.filled{color:#F59E0B;}
.testi-quote{font-size:var(--text-base);color:var(--color-light-secondary);line-height:1.75;margin-bottom:24px;font-style:italic;}
.testi-member{display:flex;align-items:center;gap:12px;}
.testi-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;}
.testi-avatar-default{width:44px;height:44px;border-radius:50%;background:var(--color-accent);color:#000;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--text-lg);}
.testi-member strong{font-size:var(--text-sm);color:var(--color-light-text);}

/* ===== KONTAK ===== */
.kontak-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:48px;}
.form-card,.kontak-info-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:40px;border:1px solid var(--color-border);}
.form-card h3,.kontak-info-card h3{font-size:var(--text-xl);font-weight:700;margin-bottom:28px;}
.form-field{margin-bottom:20px;}
.form-field label{display:block;font-size:var(--text-sm);font-weight:600;margin-bottom:6px;color:var(--color-text-secondary);}
.form-field input,.form-field textarea{width:100%;padding:12px 16px;background:#1e1e1e;border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition);}
.form-field input:focus,.form-field textarea:focus{outline:none;border-color:var(--color-accent);}
.form-field textarea{resize:vertical;}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.btn-submit{width:100%;padding:14px;background:var(--color-accent);color:#000;font-weight:800;font-size:var(--text-base);border-radius:var(--radius);transition:all var(--transition);margin-top:8px;}
.btn-submit:hover{background:var(--color-accent-light);transform:translateY(-1px);}
.contact-success{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px;gap:16px;}
.success-icon{width:56px;height:56px;border-radius:50%;background:var(--color-accent);color:#000;font-size:1.5rem;font-weight:900;display:flex;align-items:center;justify-content:center;}
.contact-success p{font-size:var(--text-lg);color:var(--color-text-secondary);}
.ki-item{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px;}
.ki-icon{font-size:1.1rem;flex-shrink:0;margin-top:2px;}
.ki-item strong{display:block;font-size:var(--text-sm);font-weight:700;margin-bottom:2px;}
.ki-item p{font-size:var(--text-sm);color:var(--color-text-secondary);}
.kontak-map-wrap{border-radius:var(--radius);overflow:hidden;height:200px;margin:24px 0;}
.kontak-map-wrap iframe{width:100%;height:100%;border:0;}
.btn-wa-kontak{display:block;text-align:center;padding:14px;background:#25D366;color:#fff;font-weight:700;border-radius:var(--radius);transition:opacity var(--transition);}
.btn-wa-kontak:hover{opacity:.85;}

/* ===== FOOTER ===== */
#footer{background:#080808;border-top:1px solid var(--color-border);padding:64px 0 0;}
.footer-inner{display:grid;grid-template-columns:2fr 1fr;gap:48px;padding-bottom:48px;}
.footer-brand p{font-size:var(--text-sm);color:var(--color-text-secondary);margin:16px 0 24px;max-width:320px;}
.social-links{display:flex;gap:12px;}
.social-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;transition:all var(--transition);}
.social-btn:hover{border-color:var(--color-accent);color:var(--color-accent);}
.social-btn svg{width:16px;height:16px;}
.footer-nav-label{font-size:var(--text-xs);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:16px;}
.footer-links{display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:var(--text-sm);color:var(--color-text-secondary);transition:color var(--transition);}
.footer-links a:hover{color:var(--color-accent);}
.footer-bottom{border-top:1px solid var(--color-border);padding:20px 0;font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;}

/* ===== FLOATING BAR ===== */
.floating-bar{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:12px;z-index:500;opacity:0;pointer-events:none;transition:opacity var(--transition);}
.floating-bar.visible{opacity:1;pointer-events:all;}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .about-grid{grid-template-columns:1fr;}
  .about-img-wrap{max-height:400px;overflow:hidden;}
  .kontak-grid{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
}
@media(max-width:768px){
  section{padding:72px 0;}
  .nav-links,.btn-header-cta{display:none;}
  .hamburger{display:flex;}
  .mobile-nav{display:flex;}
  .section-title{font-size:var(--text-3xl);}
  .packages-grid{grid-template-columns:1fr 1fr;}
  .testimonials-grid{grid-template-columns:1fr;}
  .form-row-2{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:480px){
  .packages-grid{grid-template-columns:1fr;}
  .gallery-grid{grid-template-columns:1fr;}
  .ht-large{font-size:3.5rem;}
  .ht-accent{font-size:2.8rem;}
}
