/* Extracted Frontend Styles */

/* From about.php */
/* ══════════════════════════════════════════════════
   ABOUT PAGE — Fully Responsive Arch Images
   Strategi:
   - Desktop (>1024px)  : 2 arch tumpang tindih, height berbasis aspect-ratio
   - Tablet (768-1024px): 2 arch, ukuran disesuaikan
   - Mobile (<768px)    : hanya 1 arch utama + accent kecil di pojok
   - 480px ke bawah     : layout berubah — images jadi baris penuh di atas
══════════════════════════════════════════════════ */

/* ── Layout utama ── */
.about-page-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: center;
}

/* ── Wrapper images — pakai padding-bottom trick agar height otomatis ── */
.about-images {
    position: relative;
    /* Tinggi otomatis berdasar aspect ratio: lebar * 1.1 */
    aspect-ratio: 9 / 10;
    max-height: 600px;
    width: 100%;
}

/* ── Arch utama (gambar besar kiri atas) ── */
.about-arch-main-wrap {
    position: absolute;
    top: 0; left: 0;
    width: 73%;
    height: 90%;
}
.about-arch-main {
    width: 100%;
    height: 100%;
    border-radius: 100% 100% 0 0 / 50% 50% 0 0;
    overflow: hidden;
    box-shadow: 0 24px 80px rgba(28,43,74,0.22);
    transition: all 0.5s ease;
}
.about-arch-main > div,
.about-arch-main img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.about-images:hover .about-arch-main > div,
.about-images:hover .about-arch-main img { transform: scale(1.04); }

/* ── Arch aksen (gambar kecil kanan bawah) ── */
.about-arch-accent-wrap {
    position: absolute;
    bottom: 0; right: 0;
    width: 47%;
    height: 52%;
}
.about-arch-accent {
    width: 100%;
    height: 100%;
    border-radius: 100% 100% 0 0 / 50% 50% 0 0;
    overflow: hidden;
    box-shadow: 0 16px 56px rgba(28,43,74,0.25);
    border: 5px solid var(--ivory);
    transition: all 0.5s ease;
}
.about-arch-accent > div,
.about-arch-accent img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.about-images:hover .about-arch-accent > div,
.about-images:hover .about-arch-accent img { transform: scale(1.06); }

/* ── Badge "Since 2016" ── */
.about-badge-float {
    position: absolute;
    top: 50%; left: 60%;
    transform: translate(-50%, -50%);
    background: var(--gold);
    color: var(--secondary-deep);
    border-radius: 50%;
    width: 86px; height: 86px;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    font-family: var(--font-display);
    box-shadow: 0 8px 32px rgba(201,169,110,0.5);
    z-index: 3;
    pointer-events: none;
}
.about-badge-float .num { font-size: 1.5rem; font-weight: 700; line-height: 1; }
.about-badge-float .lbl { font-size: 0.58rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; margin-top: 2px; }

/* ── Stats grid ── */
.about-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 32px;
}
.about-stat-card {
    background: var(--white);
    border-radius: var(--radius-sm);
    padding: 18px 14px;
    text-align: center;
    border: 1px solid var(--border);
    transition: var(--transition);
}
.about-stat-card:hover {
    border-color: var(--gold);
    transform: translateY(-3px);
    box-shadow: var(--shadow-sm);
}
.about-stat-card i { font-size: 1.4rem; color: var(--primary); margin-bottom: 8px; display: block; }
.about-stat-card .num { font-family: var(--font-display); font-size: 1.5rem; font-weight: 700; color: var(--dark); line-height: 1; }
.about-stat-card .lbl { font-size: 0.72rem; color: var(--text-light); margin-top: 4px; line-height: 1.3; }

/* ── Values grid ── */
.about-values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
.about-value-card {
    text-align: center;
    padding: 36px 28px;
    background: var(--cream);
    border-radius: var(--radius);
    border: 1px solid transparent;
    transition: var(--transition);
}
.about-value-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow);
    border-color: rgba(201,169,110,0.15);
}

/* ══ RESPONSIVE ══ */

/* ── Tablet landscape (≤1200px) ── */
@media (max-width: 1200px) {
    .about-page-grid { gap: 48px; }
    .about-images { aspect-ratio: 4 / 4.5; }
    .about-arch-main-wrap { width: 74%; height: 88%; }
    .about-arch-accent-wrap { width: 48%; height: 50%; }
    .about-badge-float { width: 78px; height: 78px; }
    .about-badge-float .num { font-size: 1.3rem; }
}

/* ── Tablet portrait (≤1024px) ── */
@media (max-width: 1024px) {
    .about-page-grid { gap: 40px; }
    .about-images { aspect-ratio: 1 / 1; max-height: 440px; }
    .about-arch-main-wrap { width: 75%; height: 87%; }
    .about-arch-accent-wrap { width: 50%; height: 48%; }
    .about-badge-float { width: 72px; height: 72px; }
    .about-badge-float .num { font-size: 1.2rem; }
    .about-values-grid { grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
    .about-value-card { padding: 28px 18px; }
}

/* ── Mobile (≤768px): layout jadi 1 kolom ── */
@media (max-width: 768px) {
    .about-page-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    /* Images section: aspect ratio tetap, tidak fixed height */
    .about-images {
        aspect-ratio: 3 / 2.8;
        max-height: 340px;
        width: 100%;
    }
    .about-arch-main-wrap { width: 77%; height: 88%; }
    .about-arch-accent-wrap { width: 50%; height: 46%; }
    /* Arch radius lebih ringan di mobile agar tidak terpotong */
    .about-arch-main { border-radius: 100% 100% 0 0 / 45% 45% 0 0; }
    .about-arch-accent { border-radius: 100% 100% 0 0 / 45% 45% 0 0; border-width: 3px; }
    .about-badge-float { width: 64px; height: 64px; top: 48%; left: 58%; }
    .about-badge-float .num { font-size: 1.1rem; }
    .about-badge-float .lbl { font-size: 0.5rem; }
    /* Values: 1 kolom di mobile */
    .about-values-grid { grid-template-columns: 1fr; gap: 14px; }
    .about-value-card { padding: 28px 20px; border-radius: 16px; }
    /* Stats: tetap 2 kolom */
    .about-stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 24px; }
    .about-stat-card { padding: 16px 10px; }
    .about-stat-card i { font-size: 1.2rem; }
    .about-stat-card .num { font-size: 1.3rem; }
    .about-stat-card .lbl { font-size: 0.68rem; }
}

/* ── Small mobile (≤480px): accent disembunyikan, arch utama full ── */
@media (max-width: 480px) {
    .about-images {
        aspect-ratio: auto;
        height: 260px;
        max-height: 260px;
    }
    /* Arch utama hampir penuh */
    .about-arch-main-wrap { width: 100%; height: 100%; left: 0; }
    .about-arch-main { border-radius: 0 0 0 0; box-shadow: 0 12px 40px rgba(28,43,74,0.18); }
    /* Sembunyikan accent di layar sangat kecil agar tidak tumpang tindih */
    .about-arch-accent-wrap { display: none; }
    /* Badge pindah ke tengah */
    .about-badge-float {
        width: 60px; height: 60px;
        top: auto; bottom: -24px;
        left: 50%; right: auto;
        transform: translateX(-50%);
    }
    .about-badge-float .num { font-size: 1rem; }
    .about-badge-float .lbl { font-size: 0.48rem; }
    /* Beri ruang untuk badge yang turun */
    .about-images { margin-bottom: 32px; }
    /* Stats: tetap 2 kolom tapi lebih compact */
    .about-stats-grid { gap: 8px; }
    .about-stat-card { padding: 14px 8px; border-radius: 10px; }
    .about-stat-card .num { font-size: 1.2rem; }
    /* Values: 1 kolom */
    .about-values-grid { grid-template-columns: 1fr; }
    .about-value-card { padding: 22px 16px; }
}

/* ── Very small (≤360px) ── */
@media (max-width: 360px) {
    .about-images { height: 220px; max-height: 220px; }
    .about-stats-grid { grid-template-columns: 1fr 1fr; }
    .about-stat-card .num { font-size: 1.1rem; }
    .about-stat-card .lbl { font-size: 0.62rem; }
}

/* From amenities.php */
.amenities-quick-bar{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 20px;background:var(--white);border-radius:20px;padding:24px 28px;box-shadow:var(--shadow-sm);border:1px solid var(--border);margin-bottom:0;}
.amenities-quick-icon{display:flex;flex-direction:column;align-items:center;gap:8px;text-decoration:none;transition:var(--transition);cursor:pointer;}
.amenities-quick-icon:hover{transform:translateY(-4px);}
.amenities-quick-icon-circle{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:white;box-shadow:0 4px 14px rgba(0,0,0,0.15);transition:var(--transition);}
.amenities-quick-icon:hover .amenities-quick-icon-circle{transform:scale(1.08);box-shadow:0 8px 24px rgba(0,0,0,0.2);}
.amenities-quick-icon span{font-size:0.68rem;color:var(--text-light);font-weight:500;text-align:center;max-width:72px;line-height:1.3;}
.amenity-full-card{background:var(--white);border-radius:28px;overflow:visible;box-shadow:var(--shadow-sm);border:1px solid rgba(42,62,110,0.06);transition:var(--transition);scroll-margin-top:100px;}
.amenity-full-card:hover{box-shadow:var(--shadow);border-color:rgba(201,169,110,0.15);}
.amenity-full-inner{display:grid;grid-template-columns:380px 1fr;min-height:440px;border-radius:28px;overflow:hidden;}
.amenity-full-inner.reverse{grid-template-columns:1fr 380px;}
.amenity-full-inner.reverse .amenity-full-image{order:2;}
.amenity-full-inner.reverse .amenity-full-content{order:1;}
.amenity-full-image{position:relative;background:var(--cream);display:flex;align-items:center;justify-content:center;padding:32px 24px 52px;overflow:visible;}
.amenity-arch-wrap{width:100%;position:relative;}
.amenity-arch-img{width:100%;aspect-ratio:3/4;border-radius:50% 50% 0 0/30% 30% 0 0;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:all 0.5s cubic-bezier(0.4,0,0.2,1);box-shadow:0 16px 48px rgba(28,43,74,0.18);}
.amenity-full-card:hover .amenity-arch-img{box-shadow:0 24px 64px rgba(28,43,74,0.25);}
.amenity-full-emoji{font-size:7rem;filter:drop-shadow(0 8px 24px rgba(0,0,0,0.2));transition:var(--transition);display:block;line-height:1;}
.amenity-full-card:hover .amenity-full-emoji{transform:scale(1.08) translateY(-4px);}
.amenity-hours-badge{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);background:var(--secondary-deep);border:1px solid rgba(255,255,255,0.12);color:rgba(255,255,255,0.92);padding:8px 18px;border-radius:50px;font-size:0.75rem;display:flex;align-items:center;gap:7px;font-weight:500;white-space:nowrap;box-shadow:0 4px 16px rgba(13,24,40,0.25);z-index:2;}
.amenity-hours-badge i{color:var(--gold);font-size:0.78rem;}
.amenity-full-content{padding:48px 52px;display:flex;flex-direction:column;justify-content:center;background:var(--white);}
.amenity-full-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;color:white;margin-bottom:20px;box-shadow:0 6px 20px rgba(0,0,0,0.15);flex-shrink:0;}
.amenity-full-content .section-badge{color:var(--gold);margin-bottom:8px;}
.amenity-full-content .section-badge::before{background:var(--gold);}
.amenity-full-content .section-badge::after{background:var(--gold);}
.amenity-full-content .section-title{color:var(--secondary-dark)!important;font-size:clamp(1.6rem,3vw,2.4rem)!important;margin-bottom:16px;}
.amenity-full-content>p{color:var(--text-light)!important;line-height:1.85;margin-bottom:28px;font-size:0.93rem;font-weight:300;}
.amenity-full-features{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;}
.amenity-full-feat{display:flex;align-items:center;gap:10px;font-size:0.85rem;color:var(--text);font-weight:400;}
.amenity-feat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
@media(max-width:1100px){.amenity-full-inner,.amenity-full-inner.reverse{grid-template-columns:320px 1fr;}}
@media(max-width:900px){.amenity-full-inner,.amenity-full-inner.reverse{grid-template-columns:1fr;}.amenity-full-inner .amenity-full-image,.amenity-full-inner.reverse .amenity-full-image{order:0;}.amenity-full-inner .amenity-full-content,.amenity-full-inner.reverse .amenity-full-content{order:1;}.amenity-full-image{padding:28px 40px 56px;}.amenity-arch-img{aspect-ratio:4/3;border-radius:50% 50% 0 0/25% 25% 0 0;}}
@media(max-width:768px){.amenities-quick-bar{gap:10px 14px;padding:18px 16px;}.amenities-quick-icon-circle{width:44px;height:44px;font-size:0.95rem;border-radius:12px;}.amenities-quick-icon span{font-size:0.62rem;max-width:58px;}.amenity-full-card{border-radius:20px;}.amenity-full-inner{border-radius:20px;}.amenity-full-image{padding:24px 28px 52px;}.amenity-arch-img{aspect-ratio:3/2;}.amenity-full-emoji{font-size:5rem;}.amenity-full-content{padding:28px 24px 32px;}.amenity-full-features{grid-template-columns:1fr;gap:8px;}.amenity-stats-grid{grid-template-columns:1fr 1fr!important;gap:16px!important;}.amenity-cta-btns{flex-direction:column;align-items:center;}.amenity-cta-btns .btn{width:100%;max-width:320px;justify-content:center;}}
@media(max-width:480px){.amenity-full-image{padding:20px 20px 52px;}.amenity-arch-img{aspect-ratio:1/1;}.amenity-full-emoji{font-size:4rem;}.amenity-full-content{padding:22px 18px 28px;}.amenity-hours-badge{font-size:0.68rem;padding:7px 14px;}.amenity-full-icon{width:46px;height:46px;font-size:1.1rem;}}

/* From blog-detail.php */
.post-header { height:450px; background-position: center; background-size: cover; background-repeat: no-repeat; display: flex; align-items: center; }
.post-header-inner { display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; }
.post-date-badge { background:rgba(196,97,58,0.9); color:#fff; padding:6px 20px; border-radius:50px; font-size:0.8rem; font-weight:700; margin-bottom:20px; text-transform:uppercase; letter-spacing:1px; }
.post-title { font-family:'Playfair Display',serif; color:#fff; font-size:3rem; line-height:1.2; max-width:900px; margin-bottom:15px; }
.post-meta { color:rgba(255,255,255,0.8); font-size:0.95rem; display:flex; align-items:center; gap:15px; }
.post-meta i { margin-right:5px; color: var(--primary-light); }

.post-content-section { background:#fff; padding:80px 0; }
.post-layout { display:grid; grid-template-columns: 1fr 350px; gap:60px; }

.blog-content { font-size:1.15rem; line-height:1.8; color:#374151; }
.blog-content p { margin-bottom: 20px; }

.post-footer { margin-top:50px; padding-top:30px; border-top:1px solid #E5E7EB; display:flex; justify-content:space-between; align-items:center; gap: 20px; flex-wrap: wrap; }
.post-share { display:flex; align-items: center; gap:15px; }
.share-label { font-weight:700; color:#1C2B4A; }
.post-share a { color:#6B7280; font-size:1.1rem; transition: color 0.3s; }
.post-share a:hover { color: var(--primary); }

.btn-back { text-decoration:none; padding:10px 25px; border-radius:50px; border:1px solid #C4613A; color:#C4613A; font-weight:700; font-size:0.9rem; transition: all 0.3s; }
.btn-back:hover { background: #C4613A; color: #fff; }
.btn-back i { margin-right:8px; }

.sidebar-sticky { position:sticky; top:120px; }
.sidebar-box { background:#F9FAFB; padding:30px; border-radius:20px; border:1px solid #E5E7EB; margin-bottom:40px; }
.sidebar-title { font-family:'Playfair Display',serif; color:#1C2B4A; font-size:1.3rem; margin-bottom:25px; }

.recent-post-item { display:flex; gap:15px; margin-bottom:20px; }
.recent-post-thumb { width:80px; height:60px; border-radius:8px; overflow:hidden; flex-shrink:0; }
.recent-post-thumb img { width:100%; height:100%; object-fit:cover; }
.recent-post-info { flex: 1; }
.recent-post-title { margin:0 0 5px; font-size:0.9rem; line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.recent-post-title a { color:#1C2B4A; text-decoration:none; font-weight:700; transition: color 0.3s; }
.recent-post-title a:hover { color: var(--primary); }
.recent-post-date { font-size:0.75rem; color:#9CA3AF; }

.sidebar-cta { background:linear-gradient(135deg, #1C2B4A, #2A3E6E); padding:35px; border-radius:20px; color:#fff; text-align:center; }
.sidebar-cta i { font-size:2.5rem; color:#C4613A; margin-bottom:15px; }
.sidebar-cta h4 { font-family:'Playfair Display',serif; margin-bottom:10px; }
.sidebar-cta p { font-size:0.85rem; color:rgba(255,255,255,0.7); margin-bottom:20px; }
.btn-cta { display:block; background:#C4613A; color:#fff; padding:12px; border-radius:50px; text-decoration:none; font-weight:700; font-size:0.9rem; transition:background 0.3s; }
.btn-cta:hover { background: #A84D2E; }

@media (max-width: 992px) {
    .post-header { height: 350px; border-radius: 0 0 40px 40px; }
    .post-title { font-size: 2.2rem; }
    .post-layout { grid-template-columns: 1fr; gap: 40px; }
    .post-content-section { padding: 50px 0; }
    .sidebar-sticky { position: static; }
}

@media (max-width: 768px) {
    .post-header { height: 300px; padding: 0 20px; border-radius: 0 0 30px 30px; }
    .post-title { font-size: 1.8rem; }
    .post-meta { flex-direction: column; gap: 5px; font-size: 0.85rem; }
    .blog-content { font-size: 1.05rem; }
    .post-footer { flex-direction: column; align-items: flex-start; }
}

/* From blog.php */
.blog-section { background:#F0F2F5; padding:80px 0; }
.blog-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(350px, 1fr)); gap:30px; }

.blog-card { background:#fff; border-radius:20px; overflow:hidden; box-shadow:0 10px 30px rgba(0,0,0,0.05); transition:transform 0.3s ease; display:flex; flex-direction:column; }
.blog-card:hover { transform: translateY(-10px); }

.blog-card-img { height:230px; position:relative; overflow:hidden; }
.blog-card-img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.blog-card:hover .blog-card-img img { transform:scale(1.05); }

.blog-card-placeholder { width:100%; height:100%; background:linear-gradient(135deg, #C4613A, #A84D2E); display:flex; align-items:center; justify-content:center; color:#fff; font-size:3rem; }
.blog-card-date { position:absolute; top:20px; left:20px; background:#fff; padding:5px 15px; border-radius:50px; font-size:0.75rem; font-weight:700; color:#C4613A; box-shadow:0 4px 10px rgba(0,0,0,0.1); }

.blog-card-content { padding:25px; flex-grow:1; display:flex; flex-direction:column; }
.blog-card-title { font-family:'Playfair Display',serif; font-size:1.4rem; color:#1C2B4A; margin-bottom:12px; line-height:1.3; min-height:2.6em; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.blog-card-excerpt { color:#6B7280; font-size:0.9rem; line-height:1.6; margin-bottom:20px; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; flex-grow:1; }
.blog-card-link { display:inline-flex; align-items:center; gap:8px; color:#C4613A; font-weight:700; text-decoration:none; font-size:0.9rem; align-self:flex-start; position:relative; }
.blog-card-link::after { content:''; position:absolute; bottom:-2px; left:0; width:0; height:2px; background:#C4613A; transition:width 0.3s; }
.blog-card:hover .blog-card-link::after { width:100%; }

.no-posts { text-align:center; padding:100px 20px; background:#fff; border-radius:20px; box-shadow:0 10px 30px rgba(0,0,0,0.05); }
.no-posts i { font-size:4rem; color:#D1D5DB; margin-bottom:20px; display:block; }
.no-posts h3 { color:#6B7280; font-family:'Playfair Display',serif; }

@media (max-width: 768px) {
    .blog-section { padding:40px 0; }
    .blog-grid { grid-template-columns: 1fr; gap:20px; }
    .blog-card-img { height:200px; }
    .blog-card-content { padding:20px; }
    .blog-card-title { font-size:1.2rem; min-height:auto; }
}

/* From contact.php */
.map-container { background: var(--white); border-radius: 20px; overflow: hidden; border: 1px solid var(--border); box-shadow: var(--shadow-sm); }
.map-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border); gap: 12px; flex-wrap: wrap; }
.map-embed-wrap { position: relative; overflow: hidden; }
.map-embed-wrap iframe { width: 100%; height: 320px; display: block; border: 0; filter: saturate(0.9) brightness(0.97); }
.map-pin-label { position: absolute; bottom: 14px; left: 14px; background: rgba(13, 24, 40, 0.88); backdrop-filter: blur(10px); color: rgba(255, 255, 255, 0.9); padding: 7px 14px; border-radius: 50px; font-size: 0.74rem; font-weight: 500; border: 1px solid rgba(255,255,255,0.1); pointer-events: none; }
.map-transport { display: flex; gap: 0; border-top: 1px solid var(--border); }
.map-transport-item { flex: 1; display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-right: 1px solid var(--border); transition: var(--transition); }
.map-transport-item:last-child { border-right: none; }
.map-transport-item:hover { background: var(--cream); }
.map-transport-item > i { color: var(--primary); font-size: 1rem; width: 20px; text-align: center; flex-shrink: 0; }
@media (max-width: 768px) { .map-transport { flex-direction: column; } .map-transport-item { border-right: none; border-bottom: 1px solid var(--border); } .map-transport-item:last-child { border-bottom: none; } .map-embed-wrap iframe { height: 260px; } .map-header { flex-direction: column; align-items: flex-start; gap: 10px; } }

/* From gallery.php */
/* ── Gallery filter override for dark bg ── */
.gallery-section .filter-btn {
    border-color: rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.55);
    background: rgba(255,255,255,0.05);
}
.gallery-section .filter-btn:hover,
.gallery-section .filter-btn.active {
    background: var(--primary);
    color: white;
    border-color: var(--primary);
    box-shadow: 0 4px 14px rgba(196,97,58,0.35);
}

/* ── Arched Gallery Grid ── */
.gall-arch-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.gall-arch-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.gall-arch-card:hover { transform: translateY(-10px); }
.gall-arch-card.filter-hidden { display: none; }

.gall-arch-img-wrap { width: 100%; position: relative; }

.gall-arch-img {
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: 50% 50% 0 0 / 30% 30% 0 0;
    overflow: hidden;
    position: relative;
    box-shadow: 0 12px 40px rgba(0,0,0,0.35);
    transition: box-shadow 0.4s ease;
}
.gall-arch-card:hover .gall-arch-img {
    box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.gall-arch-img > div {
    transition: transform 0.65s cubic-bezier(0.4,0,0.2,1);
}
.gall-arch-card:hover .gall-arch-img > div { transform: scale(1.08); }

/* Hover overlay */
.gall-arch-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(to top, rgba(13,24,40,0.85) 0%, rgba(13,24,40,0.2) 55%, transparent 100%);
    display: flex; flex-direction: column;
    align-items: center; justify-content: flex-end;
    padding-bottom: 24px;
    opacity: 0;
    transition: opacity 0.4s ease;
}
.gall-arch-card:hover .gall-arch-overlay { opacity: 1; }

/* Caption below arch */
.gall-arch-caption { margin-top: 14px; text-align: center; padding: 0 8px; }
.gall-arch-title {
    font-family: var(--font-display);
    font-size: 0.95rem;
    color: rgba(255,255,255,0.8);
    font-weight: 600;
    letter-spacing: -0.01em;
    line-height: 1.3;
}

/* Responsive */
@media (max-width: 1024px) { .gall-arch-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; } }
@media (max-width: 768px)  { .gall-arch-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; } }
@media (max-width: 480px)  { .gall-arch-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; } .gall-arch-title { font-size: 0.8rem; } }

/* From index.php */
/* FAQ SECTION */
.idx-faq-section {
    background: var(--secondary-deep);
    padding: 100px 0;
    position: relative;
    overflow: hidden;
}
.idx-faq-bg-deco {
    position: absolute; inset: 0;
    background: 
        radial-gradient(circle at 10% 20%, rgba(196,97,58,0.05) 0%, transparent 40%),
        radial-gradient(circle at 90% 80%, rgba(42,62,110,0.1) 0%, transparent 40%);
    pointer-events: none;
}
.idx-faq-container {
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 80px;
    align-items: flex-start;
    position: relative; z-index: 1;
}

.idx-faq-contact-box {
    display: flex; align-items: center; gap: 16px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
    padding: 20px; border-radius: 16px;
    position: relative; transition: var(--transition);
}
.idx-faq-contact-box:hover {
    background: rgba(255,255,255,0.06);
    border-color: var(--primary);
    transform: translateY(-3px);
}
.idx-faq-contact-icon {
    width: 44px; height: 44px; border-radius: 12px;
    background: rgba(37,211,102,0.15); color: #25D366;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
}
.idx-faq-contact-link { position: absolute; inset: 0; z-index: 2; }

/* Accordion */
.idx-accordion { display: flex; flex-direction: column; gap: 12px; }
.idx-acc-item {
    background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.05);
    border-radius: 16px; overflow: hidden;
    transition: var(--transition);
}
.idx-acc-item.active {
    background: rgba(255,255,255,0.04);
    border-color: rgba(201,169,110,0.2);
}
.idx-acc-header {
    padding: 24px 30px; display: flex; align-items: center; gap: 20px;
    cursor: pointer; position: relative;
}
.idx-acc-num {
    font-family: var(--font-display); font-size: 0.9rem; font-weight: 700;
    color: var(--primary); opacity: 0.5;
}
.idx-acc-title {
    flex: 1; margin: 0; font-size: 1.05rem; color: var(--white);
    font-weight: 500; line-height: 1.4;
}
.idx-acc-icon {
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(255,255,255,0.05);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.3); font-size: 0.8rem;
    transition: var(--transition);
}
.idx-acc-item.active .idx-acc-icon {
    background: var(--primary); color: var(--white);
    transform: rotate(180deg);
}
.idx-acc-body {
    max-height: 0; overflow: hidden;
    padding: 0 30px 0 70px;
    transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.idx-acc-content {
    font-size: 0.92rem; color: rgba(255,255,255,0.5);
    line-height: 1.7; font-weight: 300;
}

@media (max-width: 1024px) {
    .idx-faq-container { grid-template-columns: 1fr; gap: 48px; }
    .idx-faq-left { text-align: center; }
    .idx-faq-left p { margin-left: auto; margin-right: auto; }
    .idx-faq-contact-box { max-width: 350px; margin: 0 auto; text-align: left; }
}
@media (max-width: 768px) {
    .idx-faq-section { padding: 70px 0; }
    .idx-acc-header { padding: 20px; gap: 15px; }
    .idx-acc-num { font-size: 0.8rem; }
    .idx-acc-title { font-size: 0.95rem; }
    .idx-acc-body { padding: 0 20px 0 55px; }
}

/* From index.php */
/* ── Diving Callout Section ── */
.diving-callout-section {
    background: var(--secondary-dark);
    position: relative;
    overflow: hidden;
}
.diving-callout-section .idx-exp-bg-deco {
    background:
        radial-gradient(ellipse 55% 60% at 0% 50%, rgba(42,62,110,0.4) 0%, transparent 65%),
        radial-gradient(ellipse 50% 55% at 85% 60%, rgba(196,97,58,0.08) 0%, transparent 60%);
}
.diving-callout-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
    position: relative; z-index: 1;
}
.diving-arch-img {
    width: 100%;
    aspect-ratio: 3 / 4;
    border-radius: 50% 50% 0 0 / 30% 30% 0 0;
    overflow: hidden;
    box-shadow: 0 24px 80px rgba(0,0,0,0.4);
    transition: var(--transition);
}
.diving-arch-img > div { width: 100%; height: 100%; object-fit: cover; }
.diving-feats { display: flex; flex-direction: column; gap: 14px; }
.diving-feat-item {
    display: flex; align-items: center; gap: 14px;
    font-size: 0.88rem; color: rgba(255,255,255,0.65); line-height: 1.4;
}
.diving-feat-icon {
    width: 38px; height: 38px; border-radius: 10px;
    background: rgba(42,62,110,0.4); border: 1px solid rgba(255,255,255,0.08);
    display: flex; align-items: center; justify-content: center;
    color: var(--gold); font-size: 0.82rem; flex-shrink: 0;
    transition: var(--transition);
}
.diving-feat-item:hover .diving-feat-icon { background: rgba(196,97,58,0.2); color: var(--primary-light); }

.about-text-p { color: var(--text-light); line-height: 1.8; margin-bottom: 22px; font-size: 0.92rem; font-weight: 300; }
.about-section .section-desc { margin-bottom: 22px; }

/* ── About arched images ── */
.about-img-main-arch-wrap { position: absolute; top: 0; left: 0; width: 75%; height: 88%; }
.about-img-main-arch { width: 100%; height: 100%; border-radius: 160px 160px 0 0; overflow: hidden; box-shadow: var(--shadow-xl); transition: var(--transition); }
.about-img-main-arch > div, .about-img-main-arch img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); }
.about-images:hover .about-img-main-arch > div { transform: scale(1.04); }
.about-img-accent-arch-wrap { position: absolute; bottom: 0; right: 0; width: 46%; height: 50%; }
.about-img-accent-arch { width: 100%; height: 100%; border-radius: 120px 120px 0 0; overflow: hidden; box-shadow: var(--shadow-xl); border: 5px solid var(--ivory); transition: var(--transition); }
.about-img-accent-arch > div, .about-img-accent-arch img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); }
.about-images:hover .about-img-accent-arch > div { transform: scale(1.06); }

/* Floating animation for About images */
@keyframes aboutFloat {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}
.about-img-main-arch-wrap { animation: aboutFloat 6s ease-in-out infinite; }
.about-img-accent-arch-wrap { animation: aboutFloat 6s ease-in-out infinite reverse; animation-delay: -3s; }

/* ── Amenity detail arched ── */
.amenity-detail-image-wrap { flex-shrink: 0; width: 420px; }
.amenity-detail-image-arch { width: 100%; aspect-ratio: 3 / 4; border-radius: 50% 50% 0 0 / 30% 30% 0 0; overflow: hidden; box-shadow: var(--shadow-lg); transition: var(--transition); }
.amenity-detail-image-arch > div { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); }
.amenity-detail:hover .amenity-detail-image-arch > div { transform: scale(1.05); }
.amenity-detail { display: grid; grid-template-columns: 420px 1fr; gap: 52px; align-items: start; }

/* ── Gallery section ── */
.idx-gallery-section { background: var(--secondary-deep); padding: 0; position: relative; overflow: hidden; }
.idx-gallery-header { padding: 80px 0 48px; }
.idx-gallery-header-inner { 
  max-width: 1280px; margin: 0 auto; padding: 0 48px; 
  display: flex; align-items: center; justify-content: space-between; 
  gap: 24px; flex-wrap: wrap; 
}
.idx-gallery-header-right {
  display: flex;
  align-items: center;
  gap: 32px;
}
.idx-gallery-header-text .section-badge { margin-bottom: 10px; }
.idx-gallery-header-text .section-title { margin-bottom: 0; color: var(--white); }

.idx-gallery-viewall { 
  display: inline-flex; align-items: center; gap: 14px; 
  color: rgba(255,255,255,0.55); font-size: 0.82rem; font-weight: 500; 
  letter-spacing: 0.08em; text-transform: uppercase; text-decoration: none; 
  transition: all 0.35s ease; flex-shrink: 0; 
  padding: 8px 4px;
  border-radius: 20px; /* Base radius to avoid square look if background is added */
}
.idx-gallery-viewall:hover { color: var(--white); }

.idx-gallery-viewall-icon { 
  width: 42px; height: 42px; 
  border-radius: 50% !important; /* Force circle/arch shape */
  border: 1px solid rgba(255,255,255,0.15); 
  display: flex; align-items: center; justify-content: center; 
  font-size: 0.8rem; transition: all 0.35s cubic-bezier(0.4,0,0.2,1); 
  color: var(--gold); 
  background: rgba(255,255,255,0.03);
}
.idx-gallery-viewall:hover .idx-gallery-viewall-icon { 
  background: var(--primary); 
  border-color: var(--primary); 
  color: white; 
  transform: translateX(4px) rotate(-10deg);
  border-radius: 50% !important; /* Ensure it stays round */
  box-shadow: 0 8px 20px rgba(196,97,58,0.3);
}
.idx-arch-gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; padding: 0 48px 80px; max-width: 1280px; margin: 0 auto; }
.idx-arch-card { display: flex; flex-direction: column; align-items: center; cursor: pointer; transition: var(--transition); }
.idx-arch-card:hover { transform: translateY(-8px); }
.idx-arch-img-wrap { width: 100%; position: relative; }
.idx-arch-img { 
  width: 100%; aspect-ratio: 3 / 4; 
  border-radius: 50% 50% 0 0 / 30% 30% 0 0; 
  overflow: hidden; box-shadow: var(--shadow); 
  position: relative; transition: var(--transition); 
  /* Fix for browser clipping bug on hover/scale */
  isolation: isolate;
  z-index: 1;
  -webkit-mask-image: -webkit-radial-gradient(white, black);
}
.idx-arch-img > div { width: 100%; height: 100%; object-fit: cover; transition: transform 0.65s cubic-bezier(0.4,0,0.2,1); }
.idx-arch-card:hover .idx-arch-img > div { transform: scale(1.07); }
.idx-arch-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(13,24,40,0.8) 0%, rgba(13,24,40,0.2) 50%, transparent 100%); display: flex; flex-direction: column; align-items: center; justify-content: flex-end; padding-bottom: 28px; opacity: 0; transition: opacity 0.4s ease; }
.idx-arch-card:hover .idx-arch-overlay { opacity: 1; }
.idx-arch-caption { margin-top: 16px; text-align: center; }
.idx-arch-title { font-family: var(--font-display); font-size: 1rem; color: var(--white); font-weight: 600; letter-spacing: -0.01em; }
.idx-arch-cta-bg { 
  width: 100%; height: 100%; 
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%); 
  display: flex; flex-direction: column; align-items: center; justify-content: center; 
  padding: 24px; position: relative; text-align: center; 
  border-radius: 50% 50% 0 0 / 30% 30% 0 0; /* Match parent radius to be safe */
}
.idx-arch-cta-bg::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 30%, rgba(255,255,255,0.15) 0%, transparent 65%); border-radius: inherit; }
.idx-arch-cta-num { font-family: var(--font-display); font-size: 2.8rem; font-weight: 700; color: var(--white); line-height: 1; margin-bottom: 10px; position: relative; z-index: 1; }
.idx-arch-cta-desc { font-size: 0.78rem; color: rgba(255,255,255,0.75); line-height: 1.6; margin-bottom: 20px; font-weight: 300; position: relative; z-index: 1; }
.idx-arch-cta-btn { 
  display: inline-flex; align-items: center; gap: 7px; 
  background: rgba(255,255,255,0.18); border: 1px solid rgba(255,255,255,0.35); 
  color: var(--white); padding: 10px 20px; border-radius: 50px; 
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.05em; 
  text-decoration: none; transition: all 0.3s; backdrop-filter: blur(8px); 
  position: relative; z-index: 1; 
}
.idx-arch-cta-btn:hover { background: rgba(255,255,255,0.28); transform: translateY(-2px); }

/* ── Testimonials ── */
.testi-carousel-section { background: var(--ivory); }
.testi-carousel-header { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 28px; gap: 20px; flex-wrap: wrap; }
.testi-view-all-btn { display: inline-flex; align-items: center; gap: 12px; color: var(--text-light); font-size: 0.78rem; font-weight: 500; letter-spacing: 0.06em; text-transform: uppercase; text-decoration: none; transition: var(--transition); flex-shrink: 0; }
.testi-view-all-btn:hover { color: var(--dark); }
.testi-view-all-icon { width: 38px; height: 38px; border-radius: 50%; border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; font-size: 0.75rem; color: var(--primary); transition: var(--transition); }
.testi-view-all-btn:hover .testi-view-all-icon { background: var(--primary); color: white; border-color: var(--primary); transform: translateX(4px); }
.testi-rating-strip { display: flex; align-items: center; gap: 20px; background: var(--white); border: 1px solid var(--border); border-radius: 14px; padding: 14px 24px; margin-bottom: 36px; flex-wrap: wrap; }
.testi-rating-score { display: flex; align-items: center; gap: 10px; }
.testi-rating-num { font-family: var(--font-display); font-size: 1.6rem; font-weight: 700; color: var(--primary); line-height: 1; }
.testi-rating-stars { color: var(--gold); font-size: 0.76rem; display: flex; gap: 2px; }
.testi-rating-label { font-size: 0.72rem; color: var(--text-muted); font-weight: 500; }
.testi-rating-divider { width: 1px; height: 26px; background: var(--border); flex-shrink: 0; }
.testi-rating-info { display: flex; align-items: center; gap: 7px; font-size: 0.76rem; color: var(--text-light); }
.testi-rating-info i { color: var(--gold); font-size: 0.7rem; }
.testi-carousel-outer { position: relative; overflow: hidden; border-radius: 24px; margin-bottom: 20px; }
.testi-carousel-track { display: flex; transition: transform 0.56s cubic-bezier(0.4,0,0.2,1); will-change: transform; }
.testi-carousel-card { flex: 0 0 calc(33.333% - 16px); margin-right: 24px; background: var(--white); border-radius: 20px; padding: 32px 28px; border: 1px solid rgba(42,62,110,0.06); position: relative; overflow: hidden; transition: box-shadow 0.35s ease, border-color 0.35s ease; min-height: 260px; display: flex; flex-direction: column; }
.testi-carousel-card:hover { box-shadow: var(--shadow); border-color: rgba(201,169,110,0.2); }
.testi-cc-quote { position: absolute; top: 16px; right: 20px; font-size: 2.8rem; line-height: 1; color: rgba(201,169,110,0.1); font-family: var(--font-display); }
.testi-cc-stars { display: flex; gap: 3px; margin-bottom: 14px; font-size: 0.76rem; color: var(--gold); }
.testi-cc-star-empty { color: rgba(201,169,110,0.2); }
.testi-cc-text { color: var(--text); font-size: 0.87rem; line-height: 1.8; font-style: italic; font-family: var(--font-display); font-weight: 400; flex: 1; margin-bottom: 20px; display: -webkit-box; -webkit-line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden; }
.testi-cc-author { display: flex; align-items: center; gap: 11px; padding-top: 16px; border-top: 1px solid var(--border); margin-top: auto; }
.testi-cc-avatar { width: 42px; height: 42px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1rem; font-weight: 600; color: var(--white); box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
.testi-cc-name { display: block; font-weight: 600; color: var(--dark); font-size: 0.85rem; }
.testi-cc-country { display: flex; align-items: center; gap: 4px; font-size: 0.68rem; color: var(--text-muted); margin-top: 2px; }
.testi-carousel-arrow { position: absolute; top: 50%; transform: translateY(-50%); width: 46px; height: 46px; border-radius: 50%; background: var(--white); border: 1.5px solid var(--border); color: var(--dark); font-size: 0.85rem; cursor: pointer; z-index: 10; display: flex; align-items: center; justify-content: center; transition: var(--transition); box-shadow: var(--shadow-sm); }
.testi-carousel-arrow:hover { background: var(--primary); color: white; border-color: var(--primary); transform: translateY(-50%) scale(1.08); }
.testi-arrow-prev { left: 14px; } .testi-arrow-next { right: 14px; }
.testi-carousel-dots { display: flex; justify-content: center; gap: 7px; margin-bottom: 12px; }
.testi-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(42,62,110,0.15); cursor: pointer; transition: var(--transition); border: none; padding: 0; outline: none; }
.testi-dot.active { background: var(--primary); width: 22px; border-radius: 4px; box-shadow: 0 2px 8px rgba(196,97,58,0.3); }
.testi-progress-wrap { height: 2px; background: rgba(42,62,110,0.07); border-radius: 2px; overflow: hidden; margin-bottom: 32px; }
.testi-progress-bar { height: 100%; background: linear-gradient(90deg, var(--primary), var(--gold)); border-radius: 2px; width: 0%; transition: width 0.1s linear; }
.testi-carousel-cta { display: flex; justify-content: center; gap: 14px; flex-wrap: wrap; }
.idx-exp-bg-deco { position: absolute; inset: 0; background: radial-gradient(ellipse 60% 70% at 80% 50%, rgba(196,97,58,0.07) 0%, transparent 65%), radial-gradient(ellipse 50% 60% at 10% 80%, rgba(42,62,110,0.3) 0%, transparent 60%); pointer-events: none; }

/* ── Responsive ── */
@media (max-width: 1024px) {
    .amenity-detail { grid-template-columns: 320px 1fr; gap: 36px; }
    .amenity-detail-image-wrap { width: 320px; }
    .idx-arch-gallery { grid-template-columns: repeat(2, 1fr); gap: 20px; padding: 0 28px 60px; }
    .diving-callout-grid { gap: 40px; }
}
@media (max-width: 900px) {
    .amenity-detail { grid-template-columns: 1fr; gap: 24px; }
    .amenity-detail-image-wrap { width: 100%; max-width: 320px; margin: 0 auto; }
    .diving-callout-grid { grid-template-columns: 1fr; gap: 36px; }
    .diving-arch-img { max-width: 320px; margin: 0 auto; }
}
@media (max-width: 768px) {
    .idx-gallery-header { padding: 60px 0 36px; }
    .idx-gallery-header-inner { padding: 0 24px; flex-direction: column; align-items: flex-start; }
    .idx-gallery-header-right { width: 100%; flex-direction: column; align-items: flex-start; gap: 20px; }
    .idx-gallery-filter-bar { padding: 0; justify-content: flex-start; width: 100%; }
    .idx-gallery-header-text .section-title { font-size: 1.6rem !important; }
    
    .idx-arch-gallery { grid-template-columns: repeat(2, 1fr); gap: 14px; padding: 0 18px 48px; }
    .testi-carousel-card { flex: 0 0 100%; margin-right: 24px; padding: 24px 20px; min-height: 220px; }
    .testi-carousel-arrow { display: none; }
    .testi-carousel-header { flex-direction: column; align-items: flex-start; gap: 10px; }
    .testi-rating-strip { padding: 12px 16px; gap: 12px; }
    .testi-rating-divider { display: none; }
}
@media (max-width: 480px) {
    .idx-arch-gallery { grid-template-columns: 1fr 1fr; gap: 12px; padding: 0 16px 40px; }
    .testi-carousel-cta { flex-direction: column; align-items: center; }
    .testi-carousel-cta .btn { width: 100%; max-width: 300px; justify-content: center; }
}

/* From room-detail.php */
/* ── Layout ── */
.rd-section { background: var(--ivory); }
.rd-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 48px;
    align-items: start;
}

/* ── Gallery ── */
.rd-gallery { margin-bottom: 36px; }
.rd-main-img-wrap {
    width: 100%;
    background: var(--cream);
    padding-bottom: 12px;
}
.rd-main-img {
    width: 100%;
    aspect-ratio: 1 / 1;
    border-radius: 50% 50% 0 0 / 50% 50% 0 0;
    overflow: hidden;
    position: relative;
    box-shadow: var(--shadow-lg);
    transition: var(--transition);
}
.rd-main-img > div { width: 100%; height: 100%; transition: transform 0.6s cubic-bezier(0.4,0,0.2,1); }
.rd-gallery:hover .rd-main-img > div { transform: scale(1.03); }
.rd-main-badge {
    position: absolute;
    bottom: 20px; left: 50%; transform: translateX(-50%);
    background: var(--gold);
    color: var(--secondary-deep);
    font-size: 0.68rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.1em;
    padding: 5px 18px; border-radius: 50px;
    white-space: nowrap;
}
.rd-thumbs {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin-top: 10px;
}
.rd-thumb {
    aspect-ratio: 4/3;
    border-radius: var(--radius-sm);
    overflow: hidden;
    cursor: pointer;
    border: 2px solid transparent;
    transition: var(--transition);
    opacity: 0.7;
}
.rd-thumb:hover, .rd-thumb.active {
    border-color: var(--gold);
    opacity: 1;
    box-shadow: 0 4px 16px rgba(201,169,110,0.3);
}
.rd-thumb > div { width: 100%; height: 100%; transition: transform 0.4s; }
.rd-thumb:hover > div { transform: scale(1.05); }

/* ── Desc block ── */
.rd-desc-block { margin-bottom: 36px; }
.rd-quick-meta {
    display: flex; flex-wrap: wrap; gap: 20px;
    margin: 18px 0 20px;
}
.rd-qm-item {
    display: flex; align-items: center; gap: 8px;
    font-size: 0.85rem; color: var(--text-light);
    background: var(--white);
    border: 1px solid var(--border);
    padding: 8px 16px;
    border-radius: 50px;
}
.rd-qm-item i { color: var(--primary); font-size: 0.8rem; }
.rd-desc-text {
    color: var(--text-light);
    line-height: 1.9;
    font-size: 0.93rem;
    font-weight: 300;
}

/* ── Shared block style ── */
.rd-amenities-block,
.rd-policies-block { margin-bottom: 36px; }
.rd-block-title {
    font-family: var(--font-display);
    font-size: 1.3rem;
    color: var(--dark);
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border);
}
.rd-amenities-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px;
}
.rd-amenity-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-align: center;
    padding: 16px 10px;
    background: var(--white);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    transition: var(--transition);
}
.rd-amenity-item:hover {
    border-color: var(--gold);
    box-shadow: 0 4px 16px rgba(201,169,110,0.15);
    transform: translateY(-3px);
}
.rd-amenity-icon {
    width: 40px; height: 40px;
    background: linear-gradient(135deg, var(--primary), var(--primary-dark));
    border-radius: 11px;
    display: flex; align-items: center; justify-content: center;
    color: white; font-size: 0.9rem;
}
.rd-amenity-item span {
    font-size: 0.72rem;
    color: var(--text-light);
    line-height: 1.3;
    font-weight: 400;
}

/* ── Policies ── */
.rd-policies {
    background: var(--white);
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    overflow: hidden;
}
.rd-policy-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    transition: var(--transition);
}
.rd-policy-row:last-child { border-bottom: none; }
.rd-policy-row:hover { background: var(--cream); }

/* ── Booking Card ── */
.rd-right { position: sticky; top: 100px; }
.rd-booking-card {
    background: var(--white);
    border-radius: 28px;
    padding: 32px;
    box-shadow: var(--shadow);
    border: 1px solid rgba(42,62,110,0.07);
}
.rd-price-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 24px;
}
.rd-price-amount {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    color: var(--primary);
    display: block;
    line-height: 1;
}
.rd-price-per { font-size: 0.8rem; color: var(--text-muted); margin-top: 2px; display: block; }
.rd-rating-pill {
    background: var(--cream);
    border: 1px solid var(--border);
    border-radius: 50px;
    padding: 6px 14px;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--dark);
    display: flex; align-items: center; gap: 5px;
}
.rd-rating-pill i { color: var(--gold); }

.rd-date-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    border: 1.5px solid var(--border);
    border-radius: var(--radius-sm);
    overflow: hidden;
    margin-bottom: 16px;
}
.rd-date-field {
    padding: 12px 16px;
    border-right: 1px solid var(--border);
}
.rd-date-field:last-child { border-right: none; }
.rd-date-field label {
    display: block;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
    margin-bottom: 4px;
}
.rd-date-field input {
    width: 100%;
    border: none;
    outline: none;
    font-family: var(--font-body);
    font-size: 0.88rem;
    font-weight: 500;
    color: var(--dark);
    background: transparent;
}

.rd-guests-row {
    margin-bottom: 20px;
}
.rd-qty-btn {
    width: 32px; height: 32px;
    border-radius: 8px;
    border: 1.5px solid var(--border);
    background: var(--cream);
    cursor: pointer;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--dark);
    display: flex; align-items: center; justify-content: center;
    transition: var(--transition);
    font-family: var(--font-body);
    line-height: 1;
}
.rd-qty-btn:hover { background: var(--primary); color: white; border-color: var(--primary); }

.rd-summary {
    background: var(--cream);
    border-radius: var(--radius-sm);
    padding: 16px;
    margin-bottom: 20px;
}
.rd-summary-row {
    display: flex;
    justify-content: space-between;
    font-size: 0.85rem;
    color: var(--text-light);
    margin-bottom: 8px;
}
.rd-summary-row:last-child { margin-bottom: 0; }

.rd-book-btn {
    width: 100%;
    justify-content: center;
    margin-bottom: 10px;
    font-size: 0.92rem;
    padding: 16px;
}
.rd-wa-btn {
    width: 100%;
    justify-content: center;
    background: #25D366;
    color: white;
    border-color: #25D366;
    margin-bottom: 20px;
    padding: 13px;
    border-radius: var(--radius-pill);
    font-size: 0.85rem;
    font-weight: 500;
}
.rd-wa-btn:hover { background: #1EBE59; border-color: #1EBE59; transform: translateY(-2px); }

.rd-trust {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}
.rd-trust-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.78rem;
    color: var(--text-light);
}
.rd-trust-item i { color: var(--primary); font-size: 0.72rem; width: 14px; }

/* ── Responsive ── */
@media (max-width: 1100px) {
    .rd-layout { grid-template-columns: 1fr; }
    .rd-right { position: static; }
    .rd-amenities-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
    .rd-thumbs { grid-template-columns: repeat(4, 1fr); }
    .rd-amenities-grid { grid-template-columns: repeat(2, 1fr); }
    .rd-date-grid { grid-template-columns: 1fr; }
    .rd-date-field { border-right: none; border-bottom: 1px solid var(--border); }
    .rd-date-field:last-child { border-bottom: none; }
    .rd-quick-meta { gap: 10px; }
}

/* From rooms.php */
/* ─── Filter Bar ─── */
.rooms-filter-wrap {
    background: var(--white);
    border-bottom: 1px solid var(--border);
    box-shadow: 0 4px 24px rgba(28,43,74,0.07);
    position: sticky; top: 0; z-index: 90;
    transition: box-shadow 0.3s;
}
.rooms-filter-bar {
    display: flex; align-items: center; gap: 0;
    padding: 0; flex-wrap: wrap;
}
.rooms-filter-field {
    flex: 1; min-width: 160px; padding: 18px 24px;
    border-right: 1px solid var(--border);
    transition: background 0.2s;
    position: relative;
}
.rooms-filter-field:focus-within { background: rgba(196,97,58,0.03); }
.rooms-filter-field label {
    display: flex; align-items: center; gap: 7px;
    font-size: 0.67rem; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.13em; color: var(--text-muted); margin-bottom: 5px;
}
.rooms-filter-field label i { color: var(--primary); font-size: 0.72rem; }
.rooms-filter-field input,
.rooms-filter-field select {
    width: 100%; border: none; outline: none;
    font-family: var(--font-body); font-size: 0.9rem;
    color: var(--dark); font-weight: 500; background: transparent;
    cursor: pointer;
}
.rooms-filter-field.field-error { background: rgba(239,68,68,0.04); }
.rooms-filter-field.field-error label { color: #ef4444; }
.rooms-filter-divider { width: 1px; height: 40px; background: var(--border); flex-shrink: 0; }

/* Actions area (tombol + error) */
.filter-actions-wrap {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 20px; flex-shrink: 0; flex-wrap: wrap;
}
.rooms-filter-btn { border-radius: var(--radius-pill); white-space: nowrap; }
.rooms-filter-reset-btn {
    padding: 10px 14px; border-radius: var(--radius-pill);
    font-size: 0.82rem; color: var(--text-muted);
    border-color: var(--border);
}
.rooms-filter-reset-btn:hover { color: #ef4444; border-color: #ef4444; background: rgba(239,68,68,0.06); }

/* Nights badge */
.filter-nights-badge {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(201,169,110,0.12);
    border: 1px solid rgba(201,169,110,0.3);
    color: var(--gold); font-size: 0.75rem; font-weight: 600;
    padding: 5px 12px; border-radius: 50px;
    white-space: nowrap;
    animation: fadeInUp 0.3s ease;
}
.filter-nights-badge i { font-size: 0.65rem; }

/* Error inline */
.filter-error {
    display: inline-flex; align-items: center; gap: 6px;
    background: rgba(239,68,68,0.08);
    border: 1px solid rgba(239,68,68,0.2);
    color: #dc2626; font-size: 0.75rem; font-weight: 500;
    padding: 5px 12px; border-radius: 50px;
    white-space: nowrap;
    animation: fadeInUp 0.3s ease;
}

/* Result info bar */
.filter-result-bar {
    display: flex; align-items: center; gap: 16px;
    padding: 10px 0 12px; flex-wrap: wrap; border-top: 1px solid var(--border);
    margin-top: 0;
}
.filter-result-info {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.8rem; color: var(--text-light); font-weight: 400;
}
.filter-result-info i { color: var(--primary); font-size: 0.72rem; }
.filter-result-info.filter-result-warn { color: #d97706; }
.filter-result-info.filter-result-warn i { color: #d97706; }
.filter-result-count {
    margin-left: auto;
    font-size: 0.8rem; color: var(--text-light);
}
.filter-result-count strong { color: var(--primary); font-size: 1rem; }

/* ─── Rooms Grid ─── */
.rooms-page-section { background: var(--cream); }
.rooms-page-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.room-arch-image-wrap { position: relative; }

/* Badge ketersediaan */
.room-page-badge {
    position: absolute; top: 16px; right: 16px;
    background: var(--gold); color: var(--secondary-deep);
    font-size: 0.65rem; font-weight: 700; letter-spacing: 0.10em;
    text-transform: uppercase; padding: 4px 12px;
    border-radius: 50px; box-shadow: 0 2px 10px rgba(201,169,110,0.4);
    z-index: 2;
}

/* Booked / Occupied room styles */
.room-badge-booked {
    background: #EF4444 !important; color: white !important;
    box-shadow: 0 2px 10px rgba(239,68,68,0.4) !important;
}
.room-booked { opacity: 0.72; }
.room-booked:hover { opacity: 0.88; }
.room-booked-overlay {
    position: absolute; inset: 0;
    background: rgba(0,0,0,0.25);
    display: flex; align-items: center; justify-content: center;
    z-index: 1; border-radius: inherit;
}
.room-booked-overlay i {
    font-size: 2.5rem; color: rgba(255,255,255,0.5);
}

/* Booking date schedule on card */
.room-booking-dates {
    display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
    margin-bottom: 8px; padding: 6px 8px;
    background: #FEF2F2; border: 1px solid #FECACA;
    border-radius: 8px;
}
.room-booking-dates-label {
    font-size: 0.62rem; font-weight: 700; color: #991B1B;
    display: flex; align-items: center; gap: 4px;
    margin-right: 2px;
}
.room-booking-dates-label i { font-size: 0.58rem; }
.room-booking-chip {
    font-size: 0.6rem; font-weight: 600;
    padding: 2px 7px; border-radius: 50px;
    display: inline-flex; align-items: center; gap: 2px;
    white-space: nowrap;
}
.chip-current { background: #FEE2E2; color: #DC2626; border: 1px solid #FECACA; }
.chip-upcoming { background: #FEF3C7; color: #92400E; border: 1px solid #FDE68A; }
.chip-more { background: #F3F4F6; color: #6B7280; border: 1px solid #E5E7EB; }

/* Badge malam (muncul saat ada filter tanggal) */
.room-date-badge {
    position: absolute; bottom: 0; left: 50%; transform: translateX(-50%);
    background: rgba(13,24,40,0.82); backdrop-filter: blur(8px);
    color: var(--white); font-size: 0.72rem; font-weight: 600;
    padding: 5px 14px; border-radius: 50px 50px 0 0;
    letter-spacing: 0.04em; z-index: 2; white-space: nowrap;
}
.room-date-badge i { color: var(--gold); margin-right: 4px; }

/* Tags amenity */
.room-page-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.room-page-tag {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 0.68rem; font-weight: 500; color: var(--text-light);
    background: var(--cream); border: 1px solid var(--border);
    padding: 4px 10px; border-radius: 50px;
}
.room-page-tag i { color: var(--primary); font-size: 0.6rem; }

/* Room number tags */
.room-number-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 8px; }
.room-number-tag {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 0.65rem; font-weight: 600; color: #166534;
    background: #F0FDF4; border: 1px solid #BBF7D0;
    padding: 2px 9px; border-radius: 50px;
}
.room-number-tag i { font-size: 0.55rem; color: #22C55E; }

/* Harga total kalkulasi */
.price-total-calc {
    display: block; font-size: 0.72rem; font-weight: 600;
    color: var(--secondary); margin-top: 5px;
    padding: 4px 0; border-top: 1px dashed var(--border);
}
.price-total-calc i { margin-right: 3px; }

/* Footer kartu */
.rooms-page-grid .room-arch-footer { flex-direction: column; align-items: flex-start; gap: 12px; }
.rooms-page-grid .room-arch-footer > div:last-child { width: 100%; display: flex; gap: 8px; }
.rooms-page-grid .room-arch-footer .btn { flex: 1; justify-content: center; }

/* ─── Empty State ─── */
.rooms-empty-state {
    text-align: center; padding: 80px 20px;
    background: var(--white); border-radius: 28px;
    border: 1px dashed rgba(42,62,110,0.12);
}
.rooms-empty-icon { font-size: 4rem; margin-bottom: 16px; filter: grayscale(0.3); }
.rooms-empty-state h3 {
    font-family: var(--font-display); font-size: 1.5rem;
    color: var(--dark); margin-bottom: 8px;
}
.rooms-empty-state p { color: var(--text-light); font-size: 0.93rem; }

/* ─── Responsive ─── */
@media (max-width: 1024px) {
    .rooms-page-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
}

    @media (max-width: 768px) {
        .rooms-filter-wrap { position: relative; }
        .rooms-filter-bar { flex-direction: column; align-items: stretch; }
        .rooms-filter-field { border-right: none; border-bottom: 1px solid var(--border); padding: 14px 20px; }
        .rooms-filter-divider { display: none; }
        .filter-actions-wrap { 
            padding: 14px 20px; 
            display: grid; 
            grid-template-columns: 1fr auto auto; 
            gap: 10px; 
            align-items: center; 
        }
        .rooms-filter-btn { margin: 0; width: 100%; justify-content: center; height: 50px; }
        .btn-booking-com { width: 60px; padding: 0; display: flex; align-items: center; justify-content: center; }
        .rooms-filter-reset-btn { display: flex !important; margin: 0; width: 50px; height: 50px; justify-content: center; }
        .filter-nights-badge, .filter-error { align-self: flex-start; grid-column: 1 / -1; margin-bottom: 8px; }
        .btn-booking-com img { height: 16px !important; }
        /* Mobile: 2 kolom dengan arch card */
        .rooms-page-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
        /* Tags: sembunyikan di card kecil agar tidak tumpuk */
        .rooms-page-grid .room-page-tags { display: none; }
        .filter-result-bar { gap: 12px; padding: 14px 0; }
        .filter-result-info { font-size: 0.76rem; }
        .filter-result-count { margin-left: 0; width: 100%; font-size: 0.76rem; border-top: 1px dashed var(--border); padding-top: 8px; }
        /* Badge lebih kecil di mobile */
        .room-page-badge { font-size: 0.58rem; padding: 3px 8px; top: 10px; right: 10px; }
        .room-date-badge { font-size: 0.62rem; padding: 4px 10px; }
    }

@media (max-width: 480px) {
    .rooms-filter-field { padding: 12px 16px; }
    .filter-actions-wrap { padding: 10px 16px 14px; }
    .rooms-page-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    /* Harga total sembunyi di layar sangat kecil */
    .price-total-calc { display: none; }
}

/* From seo.php */
/* ═══════════════════════════════════════════════
   SEO MANAGER — Premium Dark UI + Per-Page
   ═══════════════════════════════════════════════ */
:root {
  --seo-bg:      #0B1220;
  --seo-surf:    #121C2D;
  --seo-surf2:   #172235;
  --seo-border:  rgba(255,255,255,0.07);
  --seo-accent:  #10B981;
  --seo-gold:    #C9A96E;
  --seo-primary: #C4613A;
  --seo-text:    #D8E4F0;
  --seo-muted:   rgba(255,255,255,0.38);
  --seo-danger:  #EF4444;
  --seo-warning: #F59E0B;
  --seo-trans:   all 0.25s ease;
}

.seo-wrap { background:var(--seo-bg); border-radius:20px; overflow:hidden; box-shadow:0 0 0 1px var(--seo-border),0 32px 80px rgba(0,0,0,0.5); display:flex; min-height:calc(100vh - 100px); }

/* ── Score Bar ── */
.seo-score-bar { background:linear-gradient(135deg,#0B1220,#172235); border:1px solid var(--seo-border); border-radius:16px; padding:20px 24px; display:flex; align-items:center; gap:24px; margin-bottom:20px; flex-wrap:wrap; }
.seo-score-ring { position:relative; width:90px; height:90px; flex-shrink:0; }
.seo-score-ring svg { width:90px; height:90px; transform:rotate(-90deg); }
.seo-score-num { position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; font-size:1.5rem; font-weight:800; color:var(--seo-text); line-height:1; }
.seo-score-num small { font-size:0.55rem; color:var(--seo-muted); font-weight:400; }
.seo-score-items { display:flex; flex-wrap:wrap; gap:8px; flex:1; }
.seo-check-pill { display:inline-flex; align-items:center; gap:5px; padding:4px 10px; border-radius:50px; font-size:0.68rem; font-weight:600; }
.seo-check-ok   { background:rgba(16,185,129,0.15); color:#10B981; border:1px solid rgba(16,185,129,0.25); }
.seo-check-miss { background:rgba(239,68,68,0.1); color:#EF4444; border:1px solid rgba(239,68,68,0.2); }

/* ── Sidebar ── */
.seo-sidebar { width:268px; flex-shrink:0; background:var(--seo-surf); border-right:1px solid var(--seo-border); display:flex; flex-direction:column; position:sticky; top:0; max-height:calc(100vh - 100px); overflow-y:auto; }
.seo-sidebar::-webkit-scrollbar { width:3px; }
.seo-sidebar::-webkit-scrollbar-thumb { background:var(--seo-accent); border-radius:3px; }
.seo-sidebar-header { padding:20px 18px; border-bottom:1px solid var(--seo-border); display:flex; align-items:center; gap:12px; }
.seo-icon-box { width:38px; height:38px; background:linear-gradient(135deg,var(--seo-accent),#059669); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1rem; color:white; box-shadow:0 4px 14px rgba(16,185,129,0.3); }
.seo-sidebar-title { font-size:0.88rem; font-weight:700; color:var(--seo-text); }
.seo-sidebar-sub { font-size:0.61rem; color:var(--seo-muted); text-transform:uppercase; letter-spacing:0.1em; }
.seo-nav { padding:8px 0; }
.seo-nav-label { font-size:0.58rem; font-weight:700; letter-spacing:0.16em; text-transform:uppercase; color:var(--seo-muted); padding:10px 16px 4px; display:block; }
.seo-nav-item { display:flex; align-items:center; gap:10px; padding:9px 14px; cursor:pointer; border-left:2px solid transparent; transition:var(--seo-trans); width:100%; background:none; border-right:none; border-top:none; border-bottom:none; text-align:left; font-family:inherit; margin-bottom:1px; }
.seo-nav-item:hover { background:rgba(255,255,255,0.04); }
.seo-nav-item.active { background:rgba(16,185,129,0.1); border-left-color:var(--seo-accent); }
.seo-nav-dot { width:30px; height:30px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:0.75rem; background:rgba(255,255,255,0.05); transition:var(--seo-trans); flex-shrink:0; color:var(--seo-muted); }
.seo-nav-item.active .seo-nav-dot, .seo-nav-item:hover .seo-nav-dot { background:rgba(16,185,129,0.18); color:var(--seo-accent); }
.seo-nav-text { font-size:0.8rem; font-weight:500; color:var(--seo-muted); transition:var(--seo-trans); }
.seo-nav-item.active .seo-nav-text { color:var(--seo-text); }
.seo-nav-badge { margin-left:auto; font-size:0.58rem; font-weight:700; padding:2px 7px; border-radius:50px; }
.seo-badge-ok   { background:rgba(16,185,129,0.2); color:#10B981; }
.seo-badge-miss { background:rgba(239,68,68,0.15); color:#EF4444; }
.seo-badge-new  { background:rgba(196,97,58,0.2); color:#C4613A; }

/* ── Main ── */
.seo-main { flex:1; display:flex; flex-direction:column; min-width:0; }
.seo-topbar { background:var(--seo-surf); border-bottom:1px solid var(--seo-border); padding:13px 28px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; position:sticky; top:0; z-index:50; }
.seo-breadcrumb { font-size:0.74rem; color:var(--seo-muted); display:flex; align-items:center; gap:6px; }
.seo-breadcrumb .cur { color:var(--seo-text); font-weight:600; }

.seo-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 18px; border-radius:8px; font-size:0.79rem; font-weight:600; border:1px solid transparent; cursor:pointer; font-family:inherit; transition:var(--seo-trans); }
.seo-btn-primary { background:var(--seo-accent); color:white; }
.seo-btn-primary:hover { background:#059669; transform:translateY(-1px); }
.seo-btn-ghost { background:transparent; color:var(--seo-muted); border-color:var(--seo-border); }
.seo-btn-ghost:hover { background:rgba(255,255,255,0.05); color:var(--seo-text); }
.seo-btn-orange { background:var(--seo-primary); color:white; }
.seo-btn-orange:hover { background:#A84D2E; }
.seo-btn-sm { padding:6px 14px; font-size:0.73rem; }
.seo-btn-lg { padding:11px 24px; font-size:0.85rem; }

/* ── Panels ── */
.seo-panels { flex:1; overflow-y:auto; }
.seo-panel { display:none; }
.seo-panel.active { display:block; }
.seo-panel-hdr { padding:26px 30px 18px; border-bottom:1px solid var(--seo-border); }
.seo-panel-title { display:flex; align-items:center; gap:12px; font-size:1.12rem; font-weight:700; color:var(--seo-text); margin-bottom:4px; }
.seo-panel-icon { width:34px; height:34px; border-radius:9px; display:flex; align-items:center; justify-content:center; font-size:0.85rem; color:white; }
.seo-panel-desc { font-size:0.78rem; color:var(--seo-muted); line-height:1.6; }
.seo-panel-body { padding:22px 30px; }

/* ── Sections ── */
.seo-section { margin-bottom:26px; }
.seo-section-title { font-size:0.64rem; font-weight:700; text-transform:uppercase; letter-spacing:0.15em; color:var(--seo-muted); padding-bottom:10px; margin-bottom:14px; border-bottom:1px solid var(--seo-border); display:flex; align-items:center; gap:8px; }
.seo-section-title i { color:var(--seo-accent); }

/* ── Grids ── */
.seo-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.seo-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }

/* ── Input row ── */
.seo-input-row { background:var(--seo-surf2); border:1px solid var(--seo-border); border-radius:10px; padding:13px 15px; transition:var(--seo-trans); }
.seo-input-row:hover { border-color:rgba(16,185,129,0.25); }
.seo-input-row:focus-within { border-color:var(--seo-accent); box-shadow:0 0 0 2px rgba(16,185,129,0.1); }
.seo-input-row label { display:block; font-size:0.68rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--seo-muted); margin-bottom:6px; }
.seo-input-row .seo-hint { font-size:0.62rem; color:var(--seo-muted); margin-top:5px; line-height:1.5; }
.seo-input, .seo-textarea, .seo-select { width:100%; background:var(--seo-bg); border:1px solid var(--seo-border); border-radius:7px; padding:9px 12px; color:var(--seo-text); font-size:0.84rem; font-family:inherit; outline:none; transition:var(--seo-trans); }
.seo-input:focus, .seo-textarea:focus, .seo-select:focus { border-color:var(--seo-accent); }
.seo-textarea { resize:vertical; min-height:80px; line-height:1.6; }
.seo-select option { background:var(--seo-surf2); }

/* Character counter */
.seo-char-count { font-size:0.6rem; text-align:right; margin-top:4px; font-family:monospace; }
.seo-char-ok   { color:#10B981; }
.seo-char-warn { color:#F59E0B; }
.seo-char-bad  { color:#EF4444; }

/* ── Toggle ── */
.seo-toggle-row { background:var(--seo-surf2); border:1px solid var(--seo-border); border-radius:10px; padding:14px 15px; display:flex; align-items:center; justify-content:space-between; gap:12px; transition:var(--seo-trans); }
.seo-toggle-row:hover { border-color:rgba(16,185,129,0.2); }
.seo-toggle-info { flex:1; }
.seo-toggle-label { font-size:0.82rem; font-weight:600; color:var(--seo-text); }
.seo-toggle-desc { font-size:0.68rem; color:var(--seo-muted); margin-top:2px; }
.seo-toggle { position:relative; display:inline-block; width:42px; height:22px; flex-shrink:0; }
.seo-toggle input { opacity:0; width:0; height:0; }
.seo-toggle-slider { position:absolute; inset:0; background:rgba(255,255,255,0.1); border-radius:50px; cursor:pointer; transition:var(--seo-trans); border:1px solid var(--seo-border); }
.seo-toggle-slider::before { content:''; position:absolute; height:16px; width:16px; left:2px; bottom:2px; background:white; border-radius:50%; transition:var(--seo-trans); }
.seo-toggle input:checked + .seo-toggle-slider { background:var(--seo-accent); border-color:var(--seo-accent); }
.seo-toggle input:checked + .seo-toggle-slider::before { transform:translateX(20px); }

/* ── Code block ── */
.seo-code-wrap { background:#0D1117; border:1px solid var(--seo-border); border-radius:12px; overflow:hidden; }
.seo-code-hdr { background:rgba(255,255,255,0.03); padding:9px 14px; border-bottom:1px solid var(--seo-border); display:flex; align-items:center; gap:7px; }
.seo-code-dot { width:9px; height:9px; border-radius:50%; }
.seo-code-area { width:100%; background:transparent; border:none; outline:none; font-family:'Courier New',monospace; font-size:0.78rem; color:#8BE9FD; resize:vertical; min-height:160px; padding:16px 18px; line-height:1.75; }

/* ── Info box ── */
.seo-info-box { border-radius:10px; padding:13px 15px; font-size:0.78rem; line-height:1.7; display:flex; align-items:flex-start; gap:10px; margin-bottom:14px; }
.seo-info-green  { background:rgba(16,185,129,0.08);  border:1px solid rgba(16,185,129,0.2);  color:rgba(255,255,255,0.7); }
.seo-info-blue   { background:rgba(59,130,246,0.08);  border:1px solid rgba(59,130,246,0.2);  color:rgba(255,255,255,0.7); }
.seo-info-yellow { background:rgba(245,158,11,0.08);  border:1px solid rgba(245,158,11,0.2);  color:rgba(255,255,255,0.7); }
.seo-info-box i  { flex-shrink:0; margin-top:1px; }

/* ── SERP Preview ── */
.seo-serp-preview { background:white; border-radius:10px; padding:18px 20px; margin-top:12px; }
.seo-serp-url   { font-size:0.72rem; color:#202124; margin-bottom:2px; font-family:Arial,sans-serif; }
.seo-serp-title { font-size:1.1rem; color:#1a0dab; font-family:Arial,sans-serif; margin-bottom:4px; cursor:pointer; text-decoration:none; line-height:1.3; display:block; }
.seo-serp-desc  { font-size:0.82rem; color:#4d5156; font-family:Arial,sans-serif; line-height:1.55; }

/* ── OG Preview ── */
.seo-og-preview { background:#F0F2F5; border-radius:10px; overflow:hidden; margin-top:12px; border:1px solid #ddd; }
.seo-og-img  { height:180px; background:linear-gradient(135deg,#2A3E6E,#C4613A); display:flex; align-items:center; justify-content:center; font-size:3rem; }
.seo-og-body { padding:12px 14px; background:white; }
.seo-og-url   { font-size:0.68rem; color:#65676B; text-transform:uppercase; margin-bottom:4px; font-family:Arial,sans-serif; }
.seo-og-title { font-size:0.88rem; font-weight:700; color:#050505; font-family:Arial,sans-serif; margin-bottom:2px; }
.seo-og-desc  { font-size:0.78rem; color:#65676B; font-family:Arial,sans-serif; }

/* ── Sitemap preview ── */
.seo-sitemap-preview { background:#0D1117; border:1px solid var(--seo-border); border-radius:10px; padding:16px; font-family:'Courier New',monospace; font-size:0.72rem; color:#8BE9FD; max-height:300px; overflow-y:auto; line-height:1.7; white-space:pre-wrap; word-break:break-all; }

/* ── Save bar ── */
.seo-save-bar { position:sticky; bottom:0; background:rgba(11,18,32,0.96); backdrop-filter:blur(14px); border-top:1px solid var(--seo-border); padding:13px 30px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.seo-save-note { font-size:0.74rem; color:var(--seo-muted); display:flex; align-items:center; gap:7px; }

/* ── Per-Page Panel ── */
.pp-pages-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; margin-bottom:24px; }
.pp-page-card { background:var(--seo-surf2); border:1.5px solid var(--seo-border); border-radius:14px; padding:16px; cursor:pointer; transition:var(--seo-trans); text-align:center; position:relative; }
.pp-page-card:hover { border-color:rgba(196,97,58,0.4); background:rgba(255,255,255,0.04); }
.pp-page-card.active-page { border-color:var(--seo-primary); background:rgba(196,97,58,0.08); }
.pp-page-icon { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; color:white; margin:0 auto 10px; }
.pp-page-name { font-size:0.82rem; font-weight:700; color:var(--seo-text); margin-bottom:3px; }
.pp-page-file { font-size:0.62rem; color:var(--seo-muted); font-family:monospace; }
.pp-status-dot { position:absolute; top:10px; right:10px; width:9px; height:9px; border-radius:50%; }
.pp-status-ok   { background:#10B981; }
.pp-status-miss { background:rgba(255,255,255,0.2); }

/* ── Per-page editor ── */
.pp-editor { background:var(--seo-surf2); border:1px solid var(--seo-border); border-radius:16px; overflow:hidden; }
.pp-editor-header { background:linear-gradient(135deg,rgba(196,97,58,0.15),rgba(42,62,110,0.15)); padding:16px 20px; border-bottom:1px solid var(--seo-border); display:flex; align-items:center; gap:12px; }
.pp-editor-icon { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1rem; color:white; flex-shrink:0; }
.pp-editor-title h3 { font-size:0.95rem; font-weight:700; color:var(--seo-text); margin-bottom:2px; }
.pp-editor-title p  { font-size:0.68rem; color:var(--seo-muted); }
.pp-editor-body { padding:20px; }

/* ── Lang tabs inside editor ── */
.pp-lang-tabs { display:flex; gap:4px; margin-bottom:16px; background:var(--seo-bg); border-radius:9px; padding:4px; }
.pp-lang-tab { flex:1; padding:8px 12px; border-radius:7px; border:none; background:none; cursor:pointer; font-size:0.75rem; font-weight:600; color:var(--seo-muted); transition:var(--seo-trans); font-family:inherit; display:flex; align-items:center; justify-content:center; gap:5px; }
.pp-lang-tab:hover { color:var(--seo-text); }
.pp-lang-tab.active { background:var(--seo-surf2); color:var(--seo-text); }
.pp-lang-content { display:none; }
.pp-lang-content.active { display:block; }

/* ── Toast ── */
.seo-toast-wrap { position:fixed; bottom:28px; right:28px; z-index:9999; pointer-events:none; }
.seo-toast { background:var(--seo-surf); border:1px solid var(--seo-border); border-left:3px solid var(--seo-accent); color:var(--seo-text); padding:13px 18px; border-radius:12px; font-size:0.82rem; font-weight:500; display:flex; align-items:center; gap:10px; box-shadow:0 8px 32px rgba(0,0,0,0.4); animation:seoSlide 0.3s ease; max-width:380px; }
@keyframes seoSlide { from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;} }

/* ── Responsive ── */
@media(max-width:1024px){ .seo-sidebar{width:230px;} .seo-grid-3{grid-template-columns:1fr 1fr;} }
@media(max-width:768px){ .seo-wrap{flex-direction:column;} .seo-sidebar{width:100%;position:static;max-height:none;} .seo-grid-2,.seo-grid-3{grid-template-columns:1fr;} .seo-panel-body{padding:16px 18px;} .seo-panel-hdr{padding:16px 18px 12px;} .seo-save-bar{padding:12px 18px;} .pp-pages-grid{grid-template-columns:repeat(2,1fr);} }

/* From testimonials.php */
/* ═══════════════════════════════════════════
   TESTIMONIALS PAGE — Full Design
═══════════════════════════════════════════ */

/* ── Summary Section ── */
.testi-summary-section {
    background: var(--secondary-dark);
    padding: 64px 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
}
.testi-summary-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 52px;
    align-items: center;
}

/* Score ring */
.testi-score-block {
    display: flex;
    align-items: center;
    gap: 24px;
}
.testi-score-ring {
    position: relative;
    flex-shrink: 0;
    width: 120px; height: 120px;
}
.testi-ring-svg { width: 100%; height: 100%; }
.testi-ring-inner {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
}
.testi-ring-num {
    font-family: var(--font-display);
    font-size: 2.2rem; font-weight: 700;
    color: var(--white); line-height: 1;
}
.testi-ring-max {
    font-size: 0.64rem;
    color: rgba(255,255,255,0.3);
    margin-top: 2px;
}
.testi-score-text h3 {
    font-family: var(--font-display);
    font-size: 1.05rem; color: var(--white);
    margin-bottom: 6px; font-weight: 600;
}
.testi-score-text p {
    font-size: 0.76rem;
    color: rgba(255,255,255,0.35);
    font-weight: 300;
}
.testi-stars-row {
    display: flex; gap: 3px; margin-bottom: 8px;
    font-size: 0.88rem; color: var(--gold);
}
.testi-star-filled { color: var(--gold); }
.testi-star-empty { color: rgba(201,169,110,0.2); }

/* Rating bars */
.testi-bars-block {
    display: flex; flex-direction: column; gap: 10px;
}
.testi-bar-row {
    display: flex; align-items: center; gap: 12px;
}
.testi-bar-label {
    font-size: 0.76rem; font-weight: 600;
    color: rgba(255,255,255,0.5);
    min-width: 32px;
    display: flex; align-items: center; gap: 3px;
}
.testi-bar-track {
    flex: 1; height: 6px;
    background: rgba(255,255,255,0.07);
    border-radius: 6px; overflow: hidden;
}
.testi-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary), var(--gold));
    border-radius: 6px;
    width: 0;
    transition: width 1.2s cubic-bezier(0.4,0,0.2,1);
}
.reveal.visible .testi-bar-fill { width: var(--w, 0%); }
.testi-bar-count {
    font-size: 0.72rem;
    color: rgba(255,255,255,0.3);
    min-width: 20px;
    text-align: right;
}

/* Quick stats */
.testi-quick-stats {
    display: flex; flex-direction: column; gap: 14px;
}
.testi-qstat {
    display: flex; align-items: center; gap: 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.06);
    border-radius: 14px;
    padding: 14px 18px;
    transition: var(--transition);
}
.testi-qstat:hover {
    border-color: rgba(201,169,110,0.2);
    background: rgba(255,255,255,0.05);
}
.testi-qstat-icon {
    width: 38px; height: 38px;
    background: rgba(196,97,58,0.15);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: var(--primary); font-size: 0.9rem; flex-shrink: 0;
}
.testi-qstat-num {
    font-family: var(--font-display);
    font-size: 1.4rem; font-weight: 700;
    color: var(--white); line-height: 1;
}
.testi-qstat-lbl {
    font-size: 0.68rem;
    color: rgba(255,255,255,0.35);
    letter-spacing: 0.05em;
    margin-top: 2px;
}

/* ── Filter bar ── */
.testi-filter-bar {
    display: flex; gap: 8px; flex-wrap: wrap;
    margin-bottom: 40px;
}
.testi-filter-btn {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 9px 20px;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(42,62,110,0.12);
    background: var(--white);
    cursor: pointer; font-size: 0.78rem; font-weight: 500;
    color: var(--text-light); transition: var(--transition);
    font-family: var(--font-body);
}
.testi-filter-btn i { font-size: 0.72rem; color: var(--gold); }
.testi-filter-btn .testi-filter-count {
    background: var(--cream);
    color: var(--text-muted);
    padding: 1px 8px; border-radius: 50px;
    font-size: 0.68rem; font-weight: 700;
}
.testi-filter-btn.active,
.testi-filter-btn:hover {
    background: var(--dark);
    color: var(--white);
    border-color: var(--dark);
    box-shadow: 0 4px 14px rgba(28,43,74,0.2);
}
.testi-filter-btn.active .testi-filter-count,
.testi-filter-btn:hover .testi-filter-count {
    background: rgba(255,255,255,0.15);
    color: var(--white);
}

/* ── Masonry grid ── */
.testi-masonry-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: start;
}

/* ── Testimonial card ── */
.testi-card {
    background: var(--white);
    border-radius: 24px;
    padding: 32px;
    border: 1px solid rgba(42,62,110,0.06);
    position: relative; overflow: hidden;
    transition: var(--transition);
}
.testi-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow);
    border-color: rgba(201,169,110,0.2);
}
.testi-card-featured {
    background: linear-gradient(135deg, var(--secondary-dark) 0%, var(--secondary-deep) 100%);
    border-color: rgba(201,169,110,0.15);
    color: var(--white);
}
.testi-card-featured .testi-card-text { color: rgba(255,255,255,0.75); }
.testi-card-featured .testi-card-name { color: var(--white); }
.testi-card-featured .testi-card-country { color: rgba(255,255,255,0.4); }

.testi-card-quote {
    position: absolute; top: 20px; right: 24px;
    font-size: 3.5rem; line-height: 1;
    color: rgba(201,169,110,0.1);
    font-family: var(--font-display);
    pointer-events: none;
}
.testi-card-featured .testi-card-quote { color: rgba(201,169,110,0.08); }

.testi-card-stars {
    display: flex; align-items: center; gap: 4px;
    margin-bottom: 16px; font-size: 0.78rem; color: var(--gold);
}
.testi-star-empty-sm { color: rgba(201,169,110,0.2); }
.testi-verified-badge {
    margin-left: auto;
    display: inline-flex; align-items: center; gap: 4px;
    background: rgba(16,185,129,0.12);
    color: #10B981;
    font-size: 0.62rem; font-weight: 600;
    padding: 3px 9px; border-radius: 50px;
    font-family: var(--font-body);
    letter-spacing: 0.04em;
}

.testi-card-text {
    color: var(--text);
    font-size: 0.88rem; line-height: 1.85;
    margin-bottom: 24px;
    font-style: italic;
    font-family: var(--font-display);
    font-weight: 400;
}

.testi-card-author {
    display: flex; align-items: center; gap: 12px;
    padding-top: 18px;
    border-top: 1px solid rgba(42,62,110,0.07);
}
.testi-card-featured .testi-card-author { border-top-color: rgba(255,255,255,0.07); }

.testi-card-avatar {
    width: 46px; height: 46px; border-radius: 50%; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-size: 1.1rem;
    font-weight: 600; color: var(--white);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.testi-card-avatar-img { object-fit: cover; }
.testi-card-author-info { flex: 1; }
.testi-card-name { display: block; font-weight: 600; color: var(--dark); font-size: 0.88rem; }
.testi-card-country {
    display: flex; align-items: center; gap: 4px;
    font-size: 0.72rem; color: var(--text-muted); margin-top: 2px;
}
.testi-card-medal {
    width: 32px; height: 32px;
    background: linear-gradient(135deg, var(--gold), var(--gold-light));
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.8rem; color: var(--secondary-deep);
    box-shadow: 0 3px 10px rgba(201,169,110,0.4);
}

/* Hidden card */
.testi-card.hidden-card {
    display: none;
}

/* ── CTA Section ── */
.testi-cta-section {
    background: var(--cream); padding: 80px 0;
}
.testi-cta-card {
    background: var(--secondary-dark);
    border-radius: 36px;
    padding: 72px 80px;
    position: relative; overflow: hidden;
    border: 1px solid rgba(255,255,255,0.04);
    display: flex; align-items: center;
}
.testi-cta-deco {
    position: absolute; right: -80px; top: -80px;
    width: 400px; height: 400px; border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.03);
    pointer-events: none;
}
.testi-cta-deco::before {
    content: '';
    position: absolute; right: 40px; top: 40px;
    width: 300px; height: 300px; border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.03);
}
.testi-cta-content { position: relative; z-index: 1; }
.testi-grid-section { background: var(--ivory); }

/* ── Responsive ── */
@media (max-width: 1100px) {
    .testi-summary-wrap { grid-template-columns: 1fr 1fr; gap: 36px; }
    .testi-quick-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
    .testi-qstat { flex-direction: column; text-align: center; gap: 8px; }
    .testi-masonry-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
    .testi-summary-section { padding: 40px 0; }
    .testi-summary-wrap { grid-template-columns: 1fr; gap: 28px; }
    .testi-score-block { flex-direction: column; text-align: center; }
    .testi-score-ring { width: 100px; height: 100px; }
    .testi-quick-stats { grid-template-columns: 1fr 1fr 1fr; }
    .testi-masonry-grid { grid-template-columns: 1fr; gap: 16px; }
    .testi-filter-bar { gap: 6px; }
    .testi-filter-btn { padding: 7px 14px; font-size: 0.74rem; }
    .testi-cta-card { padding: 36px 24px; border-radius: 20px; flex-direction: column; }
    .testi-card { padding: 24px 20px; border-radius: 18px; }
}
@media (max-width: 480px) {
    .testi-quick-stats { grid-template-columns: 1fr; gap: 8px; }
    .testi-qstat { flex-direction: row; text-align: left; }
    .testi-cta-card { padding: 28px 18px; }
}
