﻿*{margin:0;padding:0;box-sizing:border-box}
        :root{
          --merah:#DE1F26;--merah-gelap:#A8151B;--merah-muda:#FFF0F0;--merah-border:#F5CCCF;
          --teks:#1A1A1A;--teks-muted:#6B6B6B;--bg:#FFFFFF;--bg2:#FAFAFA;--garis:#E8E8E8;
          --serif:'Playfair Display',Georgia,serif;--sans:'DM Sans',sans-serif;
        }
        html{scroll-behavior:smooth}
        body{font-family:var(--sans);color:var(--teks);background:var(--bg);font-size:15px;line-height:1.7}

        /* ===== NAV ===== */
        nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,0.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--garis);padding:0 2rem}
        .nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:64px}
        .logo{display:flex;align-items:center;gap:10px;text-decoration:none}
        .logo-mark{width:36px;height:36px;background:var(--merah);border-radius:6px;display:flex;align-items:center;justify-content:center}
        .logo-mark svg{width:20px;height:20px;fill:white}
        .logo-text{display:flex;flex-direction:column;line-height:1.1}
        .logo-name{font-family:var(--serif);font-size:16px;color:var(--teks);font-weight:700;letter-spacing:-0.3px}
        .logo-name span{color:var(--merah)}
        .logo-sub{font-size:10px;color:var(--teks-muted);font-weight:300;letter-spacing:0.3px}
        .nav-links{display:flex;gap:2rem;list-style:none}
        .nav-links a{text-decoration:none;color:var(--teks-muted);font-size:14px;font-weight:400;transition:color 0.2s}
        .nav-links a:hover{color:var(--merah)}
        .nav-cta{background:var(--merah);color:white;border:none;padding:8px 20px;border-radius:6px;font-size:14px;font-family:var(--sans);font-weight:500;cursor:pointer;text-decoration:none;transition:background 0.2s}
        .nav-cta:hover{background:var(--merah-gelap)}

        /* ===== HERO ===== */
        .hero{max-width:1100px;margin:0 auto;padding:80px 2rem 60px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
        .hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--merah-muda);border:1px solid var(--merah-border);color:var(--merah);border-radius:100px;padding:5px 14px;font-size:12px;font-weight:500;margin-bottom:20px}
        .hero-badge::before{content:'';display:inline-block;width:7px;height:7px;background:var(--merah);border-radius:50%}
        h1{font-family:var(--serif);font-size:42px;line-height:1.2;color:var(--teks);margin-bottom:16px;font-weight:700}
        h1 em{color:var(--merah);font-style:normal}
        .hero-sub{color:var(--teks-muted);font-size:16px;margin-bottom:32px;line-height:1.7;font-weight:300}
        .hero-btns{display:flex;gap:12px;flex-wrap:wrap}
        .btn-primary{background:var(--merah);color:white;border:none;padding:13px 28px;border-radius:8px;font-size:15px;font-family:var(--sans);font-weight:500;cursor:pointer;text-decoration:none;transition:background 0.2s;display:inline-block}
        .btn-primary:hover{background:var(--merah-gelap)}
        .btn-outline{background:transparent;color:var(--teks);border:1.5px solid var(--garis);padding:13px 28px;border-radius:8px;font-size:15px;font-family:var(--sans);font-weight:400;cursor:pointer;text-decoration:none;transition:all 0.2s;display:inline-block}
        .btn-outline:hover{border-color:var(--merah);color:var(--merah)}
        .hero-visual{background:var(--bg2);border:1px solid var(--garis);border-radius:16px;padding:28px}
        .stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
        .stat-card{background:white;border:1px solid var(--garis);border-radius:10px;padding:18px}
        .stat-num{font-family:var(--serif);font-size:28px;font-weight:700;color:var(--teks)}
        .stat-num.red{color:var(--merah)}
        .stat-label{font-size:12px;color:var(--teks-muted);margin-top:2px;font-weight:300}
        .izin-badge{margin-top:16px;background:white;border:1px solid var(--merah-border);border-radius:10px;padding:14px 18px;display:flex;align-items:center;gap:12px}
        .izin-icon{width:36px;height:36px;background:var(--merah-muda);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
        .izin-text p:first-child{font-size:12px;color:var(--teks-muted)}
        .izin-text p:last-child{font-size:13px;font-weight:500;color:var(--teks)}

        /* ===== SECTION COMMON ===== */
        section{padding:60px 0;border-top:1px solid var(--garis)}
        .container{max-width:1100px;margin:0 auto;padding:0 2rem}
        .sec-label{font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;color:var(--merah);margin-bottom:10px}
        h2{font-family:var(--serif);font-size:32px;font-weight:700;color:var(--teks);margin-bottom:12px;line-height:1.25}
        .sec-desc{color:var(--teks-muted);font-size:15px;max-width:520px;font-weight:300}

        /* ===== PAKET ===== */
        .paket-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
        .paket-card{border:1px solid var(--garis);border-radius:12px;padding:24px;background:white;transition:border-color 0.2s,transform 0.2s;position:relative}
        .paket-card:hover{border-color:var(--merah-border);transform:translateY(-3px)}
        .paket-card.featured{border-color:var(--merah)}
        .featured-tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--merah);color:white;font-size:11px;font-weight:500;padding:3px 14px;border-radius:100px;white-space:nowrap}
        .paket-name{font-weight:500;font-size:15px;margin-bottom:4px}
        .paket-dur{font-size:12px;color:var(--teks-muted);margin-bottom:16px}
        .paket-price{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--merah);margin-bottom:4px}
        .paket-price-sub{font-size:12px;color:var(--teks-muted);margin-bottom:20px}
        .paket-list{list-style:none;margin-bottom:24px}
        .paket-list li{font-size:13px;color:var(--teks-muted);padding:5px 0;border-bottom:1px solid var(--bg2);display:flex;align-items:center;gap:8px}
        .paket-list li::before{content:'';width:5px;height:5px;background:var(--merah);border-radius:50%;flex-shrink:0}
        .paket-btn{width:100%;padding:11px;border-radius:7px;font-size:14px;font-family:var(--sans);font-weight:500;cursor:pointer;border:1.5px solid var(--garis);background:white;color:var(--teks);transition:all 0.2s}
        .paket-btn:hover,.paket-card.featured .paket-btn{background:var(--merah);border-color:var(--merah);color:white}

        /* ===== YOUTUBE SECTION ===== */
        .yt-section{background:var(--bg2)}
        .yt-header{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:36px}
        .yt-channel-link{display:inline-flex;align-items:center;gap:7px;color:var(--merah);text-decoration:none;font-weight:500;font-size:13px;border:1.5px solid var(--merah-border);padding:8px 16px;border-radius:8px;background:var(--merah-muda);transition:background 0.2s;flex-shrink:0}
        .yt-channel-link:hover{background:var(--merah);color:white}
        .yt-channel-link svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}

        /* Video grid */
        .video-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
        .video-card{background:white;border:1px solid var(--garis);border-radius:12px;overflow:hidden;transition:transform 0.2s,border-color 0.2s;cursor:pointer}
        .video-card:hover{transform:translateY(-3px);border-color:var(--merah-border)}
        .video-thumb{position:relative;aspect-ratio:16/9;background:#111;overflow:hidden}
        .video-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.3s}
        .video-card:hover .video-thumb img{transform:scale(1.04)}
        .play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.25);opacity:0;transition:opacity 0.2s}
        .video-card:hover .play-overlay{opacity:1}
        .play-btn{width:48px;height:48px;background:var(--merah);border-radius:50%;display:flex;align-items:center;justify-content:center}
        .play-btn svg{width:20px;height:20px;fill:white;margin-left:3px}
        .video-info{padding:14px}
        .video-title{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:6px;color:var(--teks);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
        .video-date{font-size:11px;color:var(--teks-muted);font-weight:300}

        /* Loading & error states */
        .video-loading{text-align:center;padding:48px 0;color:var(--teks-muted);font-size:14px}
        .video-loading .spinner{width:32px;height:32px;border:2px solid var(--garis);border-top-color:var(--merah);border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 12px}
        @keyframes spin{to{transform:rotate(360deg)}}
        .video-error{text-align:center;padding:32px;background:white;border:1px solid var(--garis);border-radius:12px;color:var(--teks-muted);font-size:14px}
        .video-error a{color:var(--merah);text-decoration:none;font-weight:500}

        /* Modal player */
        .modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:999;align-items:center;justify-content:center;padding:20px}
        .modal-overlay.active{display:flex}
        .modal-box{background:#000;border-radius:12px;overflow:hidden;width:100%;max-width:800px;position:relative}
        .modal-close{position:absolute;top:10px;right:10px;background:rgba(255,255,255,0.15);border:none;color:white;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:10;transition:background 0.2s}
        .modal-close:hover{background:rgba(255,255,255,0.3)}
        .modal-iframe{width:100%;aspect-ratio:16/9;border:none;display:block}

        /* ===== TRUST BAR ===== */
        .trust-bar{background:var(--merah);color:white;padding:40px 0}
        .trust-inner{max-width:1100px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
        .trust-num{font-family:var(--serif);font-size:30px;font-weight:700;margin-bottom:4px}
        .trust-label{font-size:12px;opacity:0.85;font-weight:300}

        /* ===== FAQ ===== */
        .faq-list{margin-top:40px;max-width:760px}
        .faq-item{border-bottom:1px solid var(--garis)}
        .faq-q{width:100%;text-align:left;padding:18px 0;font-size:15px;font-weight:500;font-family:var(--sans);background:none;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:var(--teks)}
        .faq-arrow{width:20px;height:20px;flex-shrink:0;transition:transform 0.3s;color:var(--merah)}
        .faq-item.open .faq-arrow{transform:rotate(180deg)}
        .faq-a{max-height:0;overflow:hidden;transition:max-height 0.35s ease,padding 0.35s}
        .faq-item.open .faq-a{max-height:200px;padding-bottom:16px}
        .faq-a p{font-size:14px;color:var(--teks-muted);line-height:1.7;font-weight:300}

        /* ===== KONTAK ===== */
        .kontak-section{background:var(--bg2)}
        .kontak-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:40px}
        .kontak-card{background:white;border:1px solid var(--garis);border-radius:12px;padding:28px;display:flex;flex-direction:column;gap:12px}
        .kontak-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
        .kontak-icon.wa{background:#E8F8F0}
        .kontak-icon.email{background:var(--merah-muda)}
        .kontak-card h3{font-size:16px;font-weight:500}
        .kontak-card p{font-size:13px;color:var(--teks-muted);font-weight:300}
        .kontak-card a{display:inline-flex;align-items:center;gap:8px;margin-top:auto;padding:11px 20px;border-radius:8px;font-size:14px;font-weight:500;text-decoration:none;transition:opacity 0.2s}
        .kontak-card a:hover{opacity:0.85}
        .wa-btn{background:#25D366;color:white}
        .email-btn{background:var(--merah);color:white}

        /* ===== FOOTER ===== */
        footer{background:var(--teks);color:white;padding:40px 0 20px}
        .footer-inner{max-width:1100px;margin:0 auto;padding:0 2rem}
        .footer-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;flex-wrap:wrap;gap:24px}
        .footer-brand{max-width:280px}
        .footer-logo-name{font-family:var(--serif);font-size:20px;font-weight:700;margin-bottom:4px;color:white}
        .footer-logo-name span{color:#F5A0A3}
        .footer-logo-sub{font-size:11px;color:rgba(255,255,255,0.4);margin-bottom:10px;font-weight:300;letter-spacing:0.3px}
        .footer-brand p{font-size:13px;color:rgba(255,255,255,0.5);font-weight:300;line-height:1.7}
        .footer-links h4{font-size:13px;font-weight:500;margin-bottom:14px;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,0.6)}
        .footer-links ul{list-style:none}
        .footer-links ul li{margin-bottom:8px}
        .footer-links ul li a{font-size:13px;color:rgba(255,255,255,0.5);text-decoration:none;font-weight:300;transition:color 0.2s}
        .footer-links ul li a:hover{color:white}
        .footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
        .footer-copy{font-size:12px;color:rgba(255,255,255,0.4);font-weight:300}
        .kemenag{font-size:12px;color:#F5A0A3;font-weight:400}

/* =========================
   FIX RESPONSIVE AMAN
========================= */

@media (max-width: 768px) {

    .hero {
        grid-template-columns: 1fr !important;
        gap: 30px;
        padding: 50px 1.5rem !important;
    }

    .hero-visual {
        padding: 20px;
    }

    .stat-grid {
        grid-template-columns: 1fr 1fr;
    }

    .nav-links {
        display: none;
    }

    .paket-grid {
        grid-template-columns: 1fr;
    }

    .video-grid {
        grid-template-columns: 1fr 1fr;
    }

    .trust-inner {
        grid-template-columns: repeat(2,1fr);
    }

    .kontak-grid {
        grid-template-columns: 1fr;
    }
}

/* MOBILE */
@media (max-width: 480px) {

    h1 {
        font-size: 26px;
    }

    .video-grid {
        grid-template-columns: 1fr;
    }

    .hero-btns {
        flex-direction: column;
    }

    .btn-primary,
    .btn-outline {
        width: 100%;
        text-align: center;
    }
}

/* ===== FIX MOBILE REAL ===== */

@media (max-width: 768px) {

    /* hero fix utama */
    .hero {
        grid-template-columns: 1fr;
        padding: 40px 16px;
        max-width: 100%;
    }

    /* ini penting: biar box kanan gak maksa lebar */
    .hero-visual {
        width: 100%;
        padding: 16px;
    }

    /* stat grid tetap rapi */
    .stat-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    /* ini yang sering bikin overflow */
    .izin-badge {
        flex-wrap: wrap;
        align-items: flex-start;
    }
}

/* MOBILE KECIL */
@media (max-width: 480px) {

    .hero {
        padding: 30px 14px;
    }

    .stat-grid {
        grid-template-columns: 1fr;
    }

    h1 {
        font-size: 26px;
        line-height: 1.3;
    }
}

.map-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
}

    .map-container iframe {
        position: absolute;
        width: 100%;
        height: 100%;
        border: 0;
    }


/* ===== CARD LIST ===== */
.paket-list {
    display: grid;
    gap: 16px;
}

/* ===== CARD ===== */
.paket-item {
    background: #fff;
    border-radius: 14px;
    padding: 16px;
    border: 1px solid #eee;
    box-shadow: 0 4px 12px rgba(0,0,0,0.04);
    transition: 0.2s;
}

    .paket-item:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 20px rgba(0,0,0,0.06);
    }

/* ===== CARD COMPACT ===== */
.paket-item {
    background: #fff;
    border-radius: 12px;
    padding: 14px;
    border: 1px solid #eee;
    box-shadow: 0 3px 10px rgba(0,0,0,0.04);
    display: flex;
    flex-direction: column;
    gap: 10px; /* 🔥 ini kunci biar rapat */
}

/* HEADER */
.paket-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/* DATE */
.paket-date {
    font-size: 12px;
    color: #777;
}

.paket-dur {
    font-size: 11px;
    color: #aaa;
}

/* BADGE */
.paket-badge {
    font-size: 11px;
    padding: 3px 8px;
    border-radius: 20px;
}

    .paket-badge.sisa {
        background: #ffeaea;
        color: #d62828;
    }

/* TITLE */
.paket-title {
    font-size: 14px;
    font-weight: 600;
    line-height: 1.3;
    margin-top: 2px;
}

/* META */
.paket-meta {
    font-size: 12px;
    color: #666;
}

/* INFO (inline biar hemat space) */
.paket-info {
    font-size: 12px;
    color: #444;
}

/* BUTTON (lebih compact) */
.paket-btn {
    margin-top: 6px;
    padding: 10px;
    border-radius: 8px;
    font-size: 13px;
}

.paket-item:hover {
    transform: translateY(-2px);
}

.paket-title {
    color: #222;
}

.paket-meta {
    opacity: 0.8;
}

/* =========================
   PAKET ITEM IMPROVEMENT
========================= */

.paket-item {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

    /* LIST INFO */
    .paket-item ul {
        list-style: none;
        padding: 0;
        margin: 0;
    }

        .paket-item ul li {
            font-size: 13px;
            color: #444;
            padding: 6px 0;
            border-bottom: 1px dashed #eee;
            display: flex;
            justify-content: space-between;
            gap: 10px;
        }

            .paket-item ul li:last-child {
                border-bottom: none;
            }

            /* LABEL & VALUE */
            .paket-item ul li span:first-child {
                color: #777;
            }

            .paket-item ul li span:last-child {
                font-weight: 500;
                color: #222;
            }

/* =========================
   HOTEL SECTION
========================= */

.paket-hotel {
    font-size: 13px;
    background: #fafafa;
    padding: 10px;
    border-radius: 8px;
}

    .paket-hotel div {
        display: flex;
        justify-content: space-between;
        margin-bottom: 4px;
    }

        .paket-hotel div:last-child {
            margin-bottom: 0;
        }

/* =========================
   HARGA SECTION
========================= */

.paket-harga {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
}

    .paket-harga div {
        background: #fff5f5;
        padding: 8px;
        border-radius: 6px;
        display: flex;
        justify-content: space-between;
        font-size: 13px;
    }

    .paket-harga span:last-child {
        font-weight: 600;
        color: #DE1F26;
    }

/* =========================
   BUTTON FIX
========================= */

.paket-btn {
    margin-top: auto;
}