:root{
    --bg:#F5F2EE;
    --ink:#1A1A2E;
    --ink-soft:#5C5C7A;
    --violet:#C4500A;
    --violet-2:#E8731A;
    --violet-deep:#0D2447;
    --violet-deep-2:#081830;
    --violet-pale:#FDEBD8;
    --gold:#E3A93D;
    --gold-2:#F4C26B;
    --pink:#FF8FA8;
    --line:rgba(196,80,10,.12);
    --shadow:0 20px 50px -15px rgba(13,36,71,.30);
    --orange:#E8731A;
    --orange-deep:#C4500A;
    --blue-deep:#0D2447;
  }

  body{font-family:'Plus Jakarta Sans',sans-serif;color:var(--ink);background:var(--bg);}
  h1,h2,h3,h4,.brand-text{font-family:'Sora',sans-serif;}
  a{text-decoration:none;}

  .eyebrow{
    display:inline-flex;align-items:center;gap:.5rem;
    font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
    color:var(--violet);
  }
  .eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold);}

  .grad-text{
    background:linear-gradient(90deg,var(--gold-2),var(--gold));
    -webkit-background-clip:text;background-clip:text;color:transparent;
  }

  .btn-pill{
    border-radius:999px;font-weight:600;font-size:.92rem;
    padding:.65rem 1.5rem;border:none;display:inline-flex;align-items:center;gap:.5rem;
  }
  .btn-gold{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--violet-deep);}
  .btn-gold:hover{filter:brightness(1.05);color:var(--violet-deep);box-shadow:0 10px 24px -8px rgba(227,169,61,.55);}
  .btn-ghost-light{background:rgba(255,255,255,.10);color:#fff;border:1px solid rgba(255,255,255,.28);}
  .btn-ghost-light:hover{background:rgba(255,255,255,.18);color:#fff;}

  /* ===== Navbar ===== */
  .navbar-modern{
    background:rgba(8,24,48,.92);
    backdrop-filter:blur(12px);
    border-bottom:2px solid var(--orange);
    padding:.8rem 0;
  }
  .navbar-modern .navbar-brand{display:flex;align-items:center;gap:.6rem;color:#fff;}
  .logo-mark{
    width:34px;height:34px;border-radius:10px;
    background:linear-gradient(135deg,var(--gold-2),var(--orange));
    display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-family:'Sora',sans-serif;
  }
  .navbar-modern .nav-link{
    color:rgba(255,255,255,.78);font-weight:500;font-size:.75rem;
    padding:.35rem .50rem !important;border-radius:999px;
  }
  .navbar-modern .nav-link:hover{color:#fff;background:rgba(255,255,255,.08);}
  .navbar-modern .nav-link.active{color:#fff;background:rgba(255,255,255,.12);}

  /* ===== Hero / mesh gradient ===== */
  .hero{
    position:relative;
    overflow:hidden;
    background:var(--blue-deep);
    padding:5rem 0 4rem 0;
    min-height:560px;
  }
  .hero-bg-img{
    position:absolute;inset:0;
    background-image:url('../images/bpmp depan.png');
    background-size:cover;
    background-position:center 30%;
    background-repeat:no-repeat;
    filter:brightness(.38) saturate(1.1);
    z-index:0;
  }
  .hero-bg-overlay{
    position:absolute;inset:0;
    background:
      linear-gradient(90deg, rgba(8,24,48,.92) 0%, rgba(8,24,48,.70) 55%, rgba(196,80,10,.18) 100%),
      radial-gradient(circle at 80% 50%, rgba(232,115,26,.22), transparent 55%),
      radial-gradient(circle at 10% 80%, rgba(13,36,71,.85), transparent 50%);
    z-index:1;
  }
  .hero > .container{position:relative;z-index:2;}
  .hero h1{color:#fff;font-size:2.6rem;font-weight:700;line-height:1.18;}
  .hero p.lead-text{color:rgba(255,255,255,.78);font-size:1.05rem;max-width:560px;}

  /* glass carousel panel */
  .glass-panel{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.16);
    backdrop-filter:blur(3px);
    border-radius:28px;
    padding:1.6rem;
    box-shadow:var(--shadow);
  }
  .carousel-slide{min-height:220px;display:flex;align-items:center;}

  /* Foto fasilitas di slide */
  .slide-photo-wrap{
    position:relative;flex-shrink:0;
    width:200px;height:140px;border-radius:18px;overflow:hidden;
    box-shadow:0 8px 28px -8px rgba(0,0,0,.45);
    border:2px solid rgba(255,255,255,.18);
  }
  .slide-photo-wrap img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .5s ease;
  }
  .carousel-item.active .slide-photo-wrap img{transform:scale(1.04);}
  .slide-photo-badge{
    position:absolute;bottom:.55rem;left:.6rem;
    background:rgba(8,24,48,.75);backdrop-filter:blur(8px);
    color:var(--gold-2);font-size:.7rem;font-weight:700;letter-spacing:.05em;
    padding:.25rem .6rem;border-radius:999px;
    border:1px solid rgba(244,194,107,.3);
  }
  .slide-icon-circle{
    width:84px;height:84px;border-radius:22px;flex-shrink:0;
    background:linear-gradient(135deg,var(--gold-2),var(--orange));
    display:flex;align-items:center;justify-content:center;color:#fff;font-size:2.1rem;
  }

  @media(max-width:575.98px){
    .slide-photo-wrap{width:100%;height:160px;}
  }
  .slide-text h3{color:#fff;font-size:1.4rem;margin-bottom:.4rem;}
  .slide-text p{color:rgba(255,255,255,.75);font-size:.95rem;margin-bottom:0;max-width:420px;}
  .slide-num{font-size:.75rem;color:var(--gold-2);font-weight:700;letter-spacing:.06em;display:block;margin-bottom:.35rem;}

  #heroCarousel .carousel-indicators{position:static;margin-top:1.4rem;}
  #heroCarousel .carousel-indicators [data-bs-target]{
    width:26px;height:4px;border-radius:999px;background:rgba(255,255,255,.25);opacity:1;border:none;
  }
  #heroCarousel .carousel-indicators .active{background:var(--gold-2);}
  #heroCarousel .carousel-control-prev,#heroCarousel .carousel-control-next{width:5%;opacity:.7;}

  @media (max-width:767.98px){
    .hero h1{font-size:2rem;text-align:center;}
    .hero p.lead-text{text-align:center;margin:0 auto;}
    .hero .hero-cta{justify-content:center;}
    .carousel-slide .row{text-align:center;}
    .slide-icon-circle{margin:0 auto 1rem auto;}
    .slide-text p{margin:0 auto;}
  }

  /* ===== Section ===== */
  .section-heading{max-width:600px;margin:0 auto 3rem auto;text-align:center;}
  .section-heading h2{font-size:2rem;font-weight:700;margin:.6rem 0 .8rem 0;}
  .section-heading p{color:var(--ink-soft);}

  /* ===== Facility choice cards ===== */
  .choice-card{
    position:relative;
    background:#fff;
    border-radius:28px;
    padding:2.4rem 2.2rem;
    box-shadow:0 4px 24px -8px rgba(46,31,84,.12);
    border:1px solid var(--line);
    transition:transform .25s ease, box-shadow .25s ease;
    height:100%;
  }
  .choice-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);}

  .status-pill{
    position:absolute;top:1.6rem;right:1.6rem;
    background:#E9F8EF;color:#1C8A4D;
    font-size:.74rem;font-weight:600;
    padding:.3rem .7rem;border-radius:999px;
    display:flex;align-items:center;gap:.4rem;
  }
  .status-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:#1C8A4D;}

  .choice-icon{
    width:64px;height:64px;border-radius:18px;
    display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff;
    margin-bottom:1.4rem;
  }
  .tone-violet .choice-icon{background:linear-gradient(135deg,var(--orange),var(--orange-deep));}
  .tone-gold .choice-icon{background:linear-gradient(135deg,var(--gold-2),var(--gold));}

  .choice-card h3{font-size:1.5rem;font-weight:700;margin-bottom:.6rem;}
  .choice-card p.desc{color:var(--ink-soft);font-size:.95rem;margin-bottom:1.4rem;}

  .chip-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.8rem;}
  .chip{
    background:var(--violet-pale);color:var(--orange-deep);
    font-size:.8rem;font-weight:600;padding:.4rem .8rem;border-radius:999px;
    display:flex;align-items:center;gap:.4rem;
  }
  .tone-gold .chip{background:#FBF1DD;color:var(--gold-deep,#A6741F);}

  .choice-footer{display:flex;align-items:center;justify-content:space-between;}
  .choice-code{font-size:.78rem;color:var(--ink-soft);font-weight:600;letter-spacing:.04em;}
  .btn-card-cta{
    border-radius:999px;font-weight:600;font-size:.88rem;padding:.6rem 1.3rem;
    color:#fff;display:inline-flex;align-items:center;gap:.4rem;
  }
  .tone-violet .btn-card-cta{background:linear-gradient(135deg,var(--orange),var(--orange-deep));}
  .tone-gold .btn-card-cta{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--violet-deep);}
  .btn-card-cta:hover{filter:brightness(1.08);color:inherit;}
/* Page header */
  .page-header{
    position:relative;overflow:hidden;
    background:
      radial-gradient(circle at 85% 10%, rgba(244,194,107,.28), transparent 42%),
      radial-gradient(circle at 10% 90%, rgba(138,95,214,.40), transparent 50%),
      linear-gradient(160deg,var(--violet-deep) 0%, var(--violet-deep-2) 80%);
    padding:2.6rem 0 3rem 0;
  }
.breadcrumb-custom{font-size:.85rem;color:rgba(255,255,255,.6);margin-bottom:.9rem;}
  .breadcrumb-custom a{color:rgba(255,255,255,.78);}
  .breadcrumb-custom a:hover{color:var(--gold-2);}
  .page-header h1{color:#fff;font-size:2rem;font-weight:700;margin-bottom:.5rem;}
  .page-header p{color:rgba(255,255,255,.72);max-width:560px;margin-bottom:1.6rem;}

  .filter-row{display:flex;gap:.6rem;flex-wrap:wrap;}
  .filter-pill{background:rgba(255,255,255,.10);color:#fff;border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:.5rem 1.2rem;font-weight:600;font-size:.85rem;cursor:pointer;transition:.2s ease;}
  .filter-pill:hover{background:rgba(255,255,255,.18);}
  .filter-pill.active{background:var(--gold-2);color:var(--violet-deep);border-color:var(--gold-2);}

  /* Facility list */
  .listing{padding:3rem 0;}
  .facility-card{
    display:flex;gap:1.6rem;background:#fff;border-radius:24px;padding:1.4rem;
    box-shadow:0 4px 24px -8px rgba(46,31,84,.10);border:1px solid var(--line);
    margin-bottom:1.6rem;transition:transform .22s ease, box-shadow .22s ease;
  }
  .facility-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);}

  .photo-ph{border-radius:18px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.92);font-size:2.4rem;flex-shrink:0;}
  .ph-1{background:linear-gradient(135deg,var(--violet-2),var(--violet));}
  .ph-2{background:linear-gradient(135deg,var(--gold-2),var(--gold));}
  .ph-3{background:linear-gradient(135deg,var(--violet),var(--violet-deep-2));}
  .ph-4{background:linear-gradient(135deg,var(--pink),var(--violet-2));}
  .ph-5{background:linear-gradient(135deg,var(--gold),var(--violet));}
  .ph-6{background:linear-gradient(135deg,var(--violet-2),var(--pink));}

  .facility-img{width:260px;min-height:188px;}
  .facility-img img{
    width:100%;height:100%;object-fit:cover;
    transition:transform .5s ease;
  }

  .facility-body{flex:1;min-width:0;}
  .cat-tag{display:inline-block;font-size:.74rem;font-weight:700;letter-spacing:.04em;padding:.28rem .7rem;border-radius:999px;background:var(--violet-pale);color:var(--violet);margin-bottom:.6rem;}
  .facility-card[data-category="penginapan"] .cat-tag{background:#FBF1DD;color:var(--gold-deep);}
  .facility-body h3{font-size:1.35rem;font-weight:700;margin-bottom:.35rem;}
  .stars{color:var(--gold);font-size:.85rem;margin-bottom:.6rem;}
  .stars i{margin-right:1px;}
  .meta-row{font-size:.88rem;color:var(--ink-soft);margin-bottom:.45rem;display:flex;align-items:center;gap:.45rem;}
  .price-row{font-size:.9rem;color:var(--ink-soft);margin-bottom:.8rem;}
  .price-row strong{color:var(--ink);}
  .amenity-row{display:flex;gap:.5rem;margin-bottom:1rem;}
  .amenity-ic{width:34px;height:34px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);font-size:.9rem;}
  .btn-card-cta{border-radius:999px;font-weight:600;font-size:.86rem;padding:.55rem 1.25rem;color:#fff;display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(135deg,var(--violet-2),var(--violet));}
  .facility-card[data-category="penginapan"] .btn-card-cta{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:var(--violet-deep);}
  .btn-card-cta:hover{filter:brightness(1.08);color:inherit;}

  @media (max-width:767.98px){
    .facility-card{flex-direction:column;}
    .facility-img{width:100%;height:170px;}
  }

/* Gallery */
  .gallery-wrap{padding:2.6rem 0 1rem 0;}
  .photo-ph{display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.92);position:relative;overflow:hidden;}
  .main-viewer{
    height:420px;border-radius:24px;
    background:var(--violet-pale);
    box-shadow:var(--shadow);
  }
  .scene-wrap{position:absolute;inset:0;}
  .scene-wrap svg, .scene-wrap img,
  .thumb svg, .thumb img{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover;display:block;
  }
  .viewer-overlay{
    position:absolute;left:0;right:0;bottom:0;
    background:linear-gradient(180deg, transparent, rgba(12,17,30,.62));
    padding:1.6rem 1.8rem .9rem;
  }
  .viewer-overlay .viewer-caption{color:#fff;font-weight:600;font-size:1.05rem;}
  .viewer-overlay .viewer-sub{color:rgba(255,255,255,.7);font-size:.82rem;}

  .thumb-row{display:flex;gap:.9rem;margin-top:1rem;}
  .thumb{
    width:100px;height:78px;border-radius:14px;cursor:pointer;
    border:2px solid transparent;transition:.2s ease;
    background:var(--violet-pale);position:relative;overflow:hidden;
  }
  .thumb:hover{transform:translateY(-3px);}
  .thumb.active{border-color:var(--gold-2);box-shadow:0 4px 14px -4px rgba(17,35,77,.35);}

  @media (max-width:575.98px){
    .main-viewer{height:260px;}
    .thumb{width:74px;height:60px;}
  }

  /* Description + amenities */
  .desc-section{padding:0.4rem 0;}
  .desc-section p{color:var(--ink-soft);max-width:780px;}
  .chip-row{display:flex;flex-wrap:wrap;gap:.6rem;}
  .chip{background:var(--violet-pale);color:var(--violet);font-size:.85rem;font-weight:600;padding:.45rem .9rem;border-radius:999px;display:flex;align-items:center;gap:.45rem;}

  /* Room variants */
  .rooms-section{padding-bottom:3.5rem;}
  .rooms-section h2{font-size:1.55rem;font-weight:700;margin-bottom:1.4rem;}
  .room-row{
    display:flex;align-items:center;gap:1.4rem;background:#fff;border-radius:20px;
    padding:1.2rem 1.4rem;box-shadow:0 4px 20px -8px rgba(46,31,84,.10);border:1px solid var(--line);
    margin-bottom:1.2rem;transition:transform .2s ease, box-shadow .2s ease;
  }
  .room-row:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
  .room-thumb{width:78px;height:78px;border-radius:14px;flex-shrink:0;font-size:1.6rem;}
  .room-info{flex:1;min-width:0;}
  .room-info h4{font-size:1.1rem;font-weight:700;margin-bottom:.5rem;}
  .room-tags{display:flex;flex-wrap:wrap;gap:.5rem;}
  .room-tags .chip{background:var(--bg);color:var(--ink-soft);font-weight:500;font-size:.78rem;padding:.3rem .7rem;}
  .room-price{text-align:right;flex-shrink:0;}
  .price-amount{font-size:1.15rem;font-weight:700;color:var(--ink);}
  .price-unit{font-size:.8rem;color:var(--ink-soft);}
  .btn-card-cta{
    margin-top:.6rem;border-radius:999px;font-weight:600;font-size:.85rem;padding:.55rem 1.2rem;
    color:var(--violet-deep);display:inline-flex;align-items:center;gap:.4rem;
    background:linear-gradient(135deg,var(--gold-2),var(--gold));
  }
  .btn-card-cta:hover{filter:brightness(1.08);color:var(--violet-deep);}

  @media (max-width:575.98px){
    .room-row{flex-direction:column;align-items:flex-start;}
    .room-price{text-align:left;width:100%;}
  }

  .back-link{display:inline-flex;align-items:center;gap:.4rem;color:var(--violet);font-weight:600;font-size:.92rem;margin-bottom:1.4rem;}
  .back-link:hover{color:var(--violet-2);}

  /* ===== Footer ===== */
  footer{
    background:linear-gradient(160deg,var(--blue-deep) 0%, var(--violet-deep-2) 100%);
    padding:3.2rem 0 1.4rem 0;
    border-top:3px solid var(--orange);
  }
  footer h6{color:#fff;font-family:'Sora',sans-serif;margin-bottom:1rem;}
  footer p,footer li,footer a{color:rgba(255,255,255,.68);font-size:.92rem;}
  footer ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.55rem;}
  footer a:hover{color:var(--gold-2);}
  .footer-bottom{
    border-top:1px solid rgba(255,255,255,.12);
    margin-top:2.2rem;padding-top:1.1rem;font-size:.8rem;color:rgba(255,255,255,.5);
  }