/* ===== ROOT COLOURFUL ===== */
:root{
  --orange:#ff7a00;
  --pink:#ff006e;
  --purple:#8338ec;
  --blue:#3a86ff;
  --dark:#222;
  --light:#f5f5f5;
  --radius:12px;
  --shadow:0 10px 30px rgba(0,0,0,.15);
  --grad:linear-gradient(135deg,var(--orange),var(--pink));
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Poppins',sans-serif;line-height:1.6;color:var(--dark)}
.container{width:90%;max-width:1100px;margin:auto}
img{max-width:100%;display:block}

/* ===== HEADER COLOURFUL ===== */
.header-color{background:var(--grad);padding:1rem 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap}
.brand img{height:70px}
.nav ul{list-style:none;display:flex;gap:1.5rem}
.nav a{color:#fff;text-decoration:none;font-weight:600}
.nav a:hover{color:var(--light)}
.hamburger{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer}
.hamburger span{width:25px;height:3px;background:#fff}

/* ===== HERO COLOURFUL ===== */
.hero-color{background:var(--grad);color:#fff;padding:5rem 0;text-align:center}
.hero-inner h1{font-size:2.5rem;margin-bottom:1rem}
.gradient-text{background:linear-gradient(45deg,#fff,var(--light));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.btn-grad{background:#fff;color:var(--orange);padding:.75rem 1.5rem;border:none;border-radius:var(--radius);font-weight:600;text-decoration:none;display:inline-block;transition:.3s}
.btn-grad:hover{background:var(--light);color:var(--pink)}

/* ===== LAYANAN COLOURFUL ===== */
.layanan-color{padding:4rem 0;background:var(--light)}
.grid-color{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.card-color{background:#fff;padding:2rem;border-radius:var(--radius);box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s}
.card-color:hover{transform:translateY(-10px) rotate(-1deg);box-shadow:0 15px 40px rgba(0,0,0,.2)}
.card-color h3{color:var(--orange);margin-bottom:.5rem}

/* ===== GALERI COLOURFUL ===== */
.galeri-color{padding:4rem 0;background:#fff}
.galeri-grid-color{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.gal-thumb{width:100%;height:220px;object-fit:cover;border-radius:var(--radius);cursor:pointer;transition:transform .3s,box-shadow .3s}
.gal-thumb:hover{transform:scale(1.05);box-shadow:0 10px 25px rgba(0,0,0,.25)}

/* ===== POPUP GALERI ===== */
.gal-popup{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:99999;cursor:pointer;animation:fadePop .3s}
.gal-popup.show{display:flex !important}
.gal-popup .gal-close{position:absolute;top:20px;right:30px;font-size:2.5rem;color:#fff;cursor:pointer;line-height:1}
.gal-popup .gal-popimg{max-width:90%;max-height:85%;border-radius:6px;cursor:pointer;box-shadow:0 0 20px rgba(0,0,0,.5)}
@keyframes fadePop{from{opacity:0}to{opacity:1}}

/* ===== TESTIMONI ===== */
.testimoni-color{padding:4rem 0;background:var(--grad);color:#fff}
.testimoni-color blockquote{background:rgba(255,255,255,.15);border-left:5px solid #fff;padding:1.5rem;border-radius:var(--radius);margin-bottom:1.5rem}
.testimoni-color cite{display:block;margin-top:.5rem;font-style:normal;font-weight:600}

/* ===== FOOTER COLOURFUL ===== */
.footer-color{background:var(--dark);color:#fff;padding:3rem 0 1.5rem}
.foot-top{display:flex;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}
.foot-brand img{height:70px}
.foot-info{flex:1 1 300px}
.foot-info h3{font-size:1.2rem;margin-bottom:.5rem;color:var(--orange)}
.foot-info p{margin-bottom:.3rem}
.foot-info .maps-link{color:var(--orange);text-decoration:none;font-size:.9rem}
.foot-info .maps-link:hover{text-decoration:underline}
.foot-bot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid #444;padding-top:1rem;font-size:.85rem;flex-wrap:wrap}
.social a{color:#fff;margin-left:1rem;text-decoration:none}
.social a:hover{color:var(--orange)}

/* ===== WHATSAPP FLOAT ===== */
.wa-float{position:fixed;bottom:20px;right:20px;background:#25d366;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,0,0,.3);z-index:999;transition:.3s}
.wa-float:hover{transform:scale(1.1)}

/* ===== MOBILE ===== */
@media(max-width:768px){
  .nav{position:absolute;top:100%;right:0;background:var(--dark);width:200px;flex-direction:column;padding:1rem;box-shadow:0 2px 5px rgba(0,0,0,.1);transform:translateX(200px);transition:transform .3s}
  .nav.open{transform:translateX(0)}
  .hamburger{display:flex}
  .foot-top,.foot-bot{flex-direction:column;align-items:center;text-align:center}
}
/* ===== BLOG ARTICLE ===== */
.blog-article{background:#fff;padding:3rem 0}
.blog-header{text-align:center;margin-bottom:2rem}
.blog-header h1{font-size:2.2rem;color:var(--orange)}
.blog-meta{color:#777;font-size:.9rem}
.blog-content{max-width:800px;margin:auto;padding:0 1rem}
.blog-content h2{margin-top:2rem;margin-bottom:.5rem;color:var(--pink)}
.blog-content p{margin-bottom:1rem;text-align:justify}
.blog-content ul,ol{margin-left:1.5rem;margin-bottom:1rem}
.blog-content table{width:100%;border-collapse:collapse;margin:1rem 0}
.blog-content th,.blog-content td{border:1px solid #ddd;padding:.5rem;text-align:left}
.blog-content th{background:var(--grad);color:#fff}
.blog-content img{width:100%;border-radius:8px;margin:1rem 0}
.btn-blog{background:var(--grad);color:#fff;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;display:inline-block;margin-top:1rem;transition:.3s}
.btn-blog:hover{filter:brightness(1.1)}
.foot-blog{list-style:none;padding:0}
.foot-blog li{margin-bottom:.5rem}
.foot-blog a{color:#fff;text-decoration:none}
.foot-blog a:hover{color:var(--orange)}