/* Custom Premium Scrollbar */
::-webkit-scrollbar {
     width: 8px;
     height: 8px;
}
::-webkit-scrollbar-track {
     background: var(--secondary-dark);
}
::-webkit-scrollbar-thumb {
     background: var(--primary);
     border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
     background: var(--primary-hover);
}

:root {
     --primary: #2563EB;
     --primary-hover: #1D4ED8;
     --secondary: #F1F5F9;
     --secondary-dark: #0F172A;
     --accent: #D97706;
     --bg-light: #F8FAFC;
     --bg-card: #FFFFFF;
     --text-primary: #1E293B;
     --text-muted: #64748B;
     --border-color: #E2E8F0;
     --font-headings: 'Plus Jakarta Sans', sans-serif;
     --font-body: 'Inter', sans-serif;
     --radius-sm: 8px;
     --radius-md: 12px;
     --radius-lg: 18px;
     --shadow-sm: 0 1px 3px 0 rgba(0,0,0,0.05), 0 1px 2px -1px rgba(0,0,0,0.05);
     --shadow-md: 0 4px 6px -1px rgba(15,23,42,0.05), 0 2px 4px -2px rgba(15,23,42,0.05);
     --shadow-lg: 0 10px 15px -3px rgba(15,23,42,0.04), 0 4px 6px -4px rgba(15,23,42,0.04);
     --shadow-xl: 0 20px 25px -5px rgba(15,23,42,0.08), 0 8px 10px -6px rgba(15,23,42,0.08);
     --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

#toTop {
     width: 48px;
     height: 48px;
     position: fixed;
     bottom: 90px;
     right: 24px;
     cursor: pointer;
     display: none;
     z-index: 999;
     background: var(--primary) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M4.5 15.75l7.5-7.5 7.5 7.5'/%3E%3C/svg%3E") center center no-repeat;
     background-size: 20px;
     border: none;
     border-radius: 50%;
     box-shadow: var(--shadow-lg);
     transition: var(--transition);
}

#toTop:hover {
     background-color: var(--primary-hover);
     transform: translateY(-5px);
     box-shadow: 0 10px 20px rgba(0,0,0,0.15);
}

body {
     color: var(--text-primary);
     font-family: var(--font-body);
     padding: 0px;
     margin: 0px;
     font-size: 16px;
     line-height: 1.6;
     background-color: #ffffff;
     -webkit-font-smoothing: antialiased;
}

h1 {
     text-transform: uppercase;
     margin: 0px;
     font-weight: 700;
     font-size: 11px;
     letter-spacing: 2px;
     text-align: center;
     color: #ffffff;
}

h2 {
     margin: 0px 0px 12px 0px;
     font-size: 36px;
     font-weight: 700;
     font-family: var(--font-headings);
     line-height: 1.25;
}

.background1 {
     background-image: linear-gradient(135deg, rgba(30, 41, 59, 0.05) 0%, rgba(15, 23, 42, 0.05) 100%), url(../../../images/frontend/2/texture2.jpg);
}

.background2 {
     background: var(--bg-light);
}

.background3 {
     background: var(--secondary);
}

.premium-ticker {
     display: flex;
     align-items: center;
     background: var(--secondary-dark);
     border-top: 1px solid rgba(255, 255, 255, 0.05);
     border-bottom: 2px solid var(--primary);
     overflow: hidden;
     height: 46px;
     font-family: var(--font-body);
     font-size: 14px;
     color: #cbd5e1;
     position: relative;
     box-shadow: var(--shadow-sm);
}

.ticker-badge {
     background: var(--primary);
     color: var(--secondary-dark);
     font-weight: 800;
     font-size: 11px;
     padding: 0 20px;
     height: 100%;
     display: flex;
     align-items: center;
     letter-spacing: 1.5px;
     text-transform: uppercase;
     z-index: 10;
     position: relative;
     box-shadow: 6px 0 15px rgba(0, 0, 0, 0.2);
}

.ticker-content-wrapper {
     overflow: hidden;
     white-space: nowrap;
     display: flex;
     align-items: center;
     width: 100%;
     position: relative;
}

.ticker-content-wrapper::before,
.ticker-content-wrapper::after {
     content: '';
     position: absolute;
     top: 0;
     bottom: 0;
     width: 40px;
     z-index: 2;
     pointer-events: none;
}
.ticker-content-wrapper::before {
     left: 0;
     background: linear-gradient(to right, var(--secondary-dark), transparent);
}
.ticker-content-wrapper::after {
     right: 0;
     background: linear-gradient(to left, var(--secondary-dark), transparent);
}

.ticker-content {
     display: inline-block;
     padding-left: 100%;
     animation: premium-ticker-anim 28s linear infinite;
     font-weight: 500;
}

.ticker-content span {
     padding-right: 50px;
}

@keyframes premium-ticker-anim {
     0% {
          transform: translate3d(0, 0, 0);
     }
     100% {
          transform: translate3d(-100%, 0, 0);
     }
}

.alamat {
     font-size: 14px;
     line-height: 1.6;
     color: #94a3b8;
}

.alamat p {
     margin: 0px;
     padding: 0px;
}

.logo-container {
     padding: 10px 20px;
     background: transparent;
}
.logo-container ul {
     margin: 0;
     padding: 0;
     list-style: none;
     display: flex;
     flex-direction: column;
     align-items: center;
}
.logo-container li {
     list-style: none;
     margin: 0;
     padding: 0;
}
.logo-container img {
     max-height: 46px;
     width: auto;
     display: block;
     transition: var(--transition);
}
.logo-container img:hover {
     transform: scale(1.03);
}
.logo-container h1 {
     font-size: 9px;
     letter-spacing: 1.5px;
     color: #94a3b8;
     font-weight: 500;
     margin-top: 5px;
     text-transform: uppercase;
     text-align: center;
}

.pad7 {
     padding: 30px 0px;
}

.pad8 {
     padding: 80px 0px;
}

.pad9 {
     padding: 100px 0px;
}

.gap10 {
     grid-gap: 15px;
}

.gap20 {
     grid-gap: 30px;
}

.gap30 {
     grid-gap: 45px;
}

.head {
     font-size: 40px;
     text-transform: uppercase;
     padding-bottom: 15px;
     font-weight: 800;
     margin: 40px 0px 20px 0px;
     clear: both;
     text-align: center;
     font-family: var(--font-headings);
     color: var(--secondary-dark);
     position: relative;
}

.head::after {
     content: '';
     position: absolute;
     bottom: 0;
     left: 50%;
     transform: translateX(-50%);
     width: 80px;
     height: 3px;
     background: linear-gradient(90deg, transparent, var(--primary) 15%, var(--accent) 50%, var(--primary) 85%, transparent);
     border-radius: 2px;
}

/* ============  footer =============== */

footer {
     padding: 80px 0px 40px 0px;
     background: var(--secondary-dark) !important;
     color: #94a3b8 !important;
     font-weight: 400;
     border-top: 1px solid rgba(205, 162, 116, 0.1) !important;
     border-bottom: 1px solid rgba(255, 255, 255, 0.03) !important;
}

footer a {
     color: #cbd5e1;
     transition: var(--transition);
     text-decoration: none;
}

footer a:hover {
     color: var(--primary);
}

footer ul {
     list-style: none !important;
     padding: 0 !important;
     margin: 0 !important;
}

footer li {
     list-style: none !important;
     margin-bottom: 12px !important;
     color: #cbd5e1;
     font-size: 14px;
     line-height: 1.6;
}

footer p {
     margin: 0 0 15px 0 !important;
     padding: 0 !important;
     line-height: 1.6;
     color: #cbd5e1;
}

.tempat-footer {
     grid-gap: 40px;
}

.titile-footer {
     font-size: 16px !important;
     font-weight: 700 !important;
     padding-bottom: 12px !important;
     margin-bottom: 20px !important;
     text-transform: uppercase !important;
     font-family: var(--font-headings) !important;
     color: var(--primary) !important;
     letter-spacing: 1px !important;
     position: relative;
}

.titile-footer::after {
     content: '';
     position: absolute;
     left: 0;
     bottom: 0;
     width: 30px;
     height: 2px;
     background: var(--primary);
     border-radius: 1px;
     transition: var(--transition);
}

footer div:hover .titile-footer::after {
     width: 55px;
}

@media (max-width: 768px) {
     .titile-footer::after {
          left: 50%;
          transform: translateX(-50%);
     }
}

.footer-logo-col {
     display: flex;
     flex-direction: column;
     align-items: flex-start;
     justify-content: flex-start;
}

.footer-logo {
     max-height: 55px;
     width: auto;
     margin-bottom: 15px;
}

@media (max-width: 768px) {
     .footer-logo-col {
          align-items: center;
          text-align: center;
     }
}

.flogo {
     margin: 30px auto 20px auto;
}

.bawah {
     border-top: 1px solid rgba(255, 255, 255, 0.03);
     background: #0b0f19 !important;
     padding: 24px 0px !important;
     font-size: 13px;
     text-transform: uppercase;
     color: #64748b;
     letter-spacing: 0.5px;
}

.bawah a {
     color: #94a3b8;
     transition: var(--transition);
     font-weight: 500;
}

.bawah a:hover {
     color: var(--primary);
}

.h1bawah {
     text-align: left;
     text-transform: uppercase;
     font-size: 11px;
     color: #64748b;
     margin-top: 8px;
     line-height: 1.4;
     letter-spacing: 0.5px;
}

@media (max-width: 768px) {
     .h1bawah {
          text-align: center;
     }
}

/* Payment / Bank Badges Styling */
.bank {
     display: flex !important;
     justify-content: center !important;
     align-items: center !important;
     flex-wrap: wrap !important;
     gap: 16px !important;
     margin-top: 40px !important;
     border-top: 1px solid rgba(255, 255, 255, 0.05) !important;
     padding-top: 30px !important;
     list-style: none !important;
     padding-left: 0 !important;
}

.bank li {
     background: rgba(255, 255, 255, 0.02) !important;
     border: 1px solid rgba(255, 255, 255, 0.05) !important;
     border-radius: var(--radius-sm) !important;
     padding: 12px 20px !important;
     text-align: center !important;
     min-width: 150px !important;
     transition: var(--transition) !important;
     margin: 0 !important;
}

.bank li:hover {
     background: rgba(255, 255, 255, 0.04) !important;
     border-color: rgba(205, 162, 116, 0.25) !important;
     transform: translateY(-3px);
     box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

.bank img {
     height: 20px !important;
     width: auto !important;
     margin-bottom: 6px !important;
     object-fit: contain !important;
     filter: grayscale(1) brightness(0.9) contrast(1.1);
     transition: var(--transition) !important;
}

.bank li:hover img {
     filter: none !important;
}

.bank strong {
     color: #cbd5e1 !important;
     font-size: 13px !important;
     font-weight: 600 !important;
     display: block !important;
     margin-top: 4px !important;
     letter-spacing: 0.5px !important;
}

.bank li span, .bank li {
     font-size: 11px !important;
     color: #64748b !important;
     line-height: 1.4 !important;
}


.search {
     grid-template-columns: 1fr auto;
     background: #ffffff;
     border: 1px solid var(--border-color);
     border-radius: var(--radius-sm);
     overflow: hidden;
     box-shadow: var(--shadow-sm);
     transition: var(--transition);
}

.search:focus-within {
     border-color: var(--primary);
     box-shadow: 0 0 0 3px rgba(205, 162, 116, 0.2);
}

.search .keys {
     border: none;
     background: none;
     color: var(--text-primary);
     padding: 12px 15px;
     font-size: 14px;
     outline: none;
}

.search .btn {
     margin: 0;
     border: none;
     cursor: pointer;
     width: 50px;
     background: url(../../../images/frontend/2/find.png) center center no-repeat var(--primary);
     background-size: 18px;
     transition: var(--transition);
}

.search .btn:hover {
     background-color: var(--primary-hover);
}

.no-data {
     font-size: 16px;
     font-weight: 600;
     color: #ef4444;
     padding: 20px;
     text-align: center;
}

.tulisan-putih {
     color: #ffffff !important;
}

.tulisan-putih::after {
     background: #ffffff !important;
}

.background-atas {
     background: rgba(255, 255, 255, 0.95);
     box-shadow: var(--shadow-sm);
     border-bottom: 1px solid rgba(15, 23, 42, 0.06);
     transition: var(--transition);
}

.overlay {
     background: linear-gradient(135deg, rgba(15, 23, 42, 0.85) 0%, rgba(15, 23, 42, 0.4) 100%);
     color: #ffffff;
}

@media (max-width: 740px) {
     .sticky {
          position: relative;
     }

     .wrapper {
          padding-left: 20px;
          padding-right: 20px;
     }

     .alamat {
          text-align: center;
     }

     .tempat-footer {
          grid-template-columns: 1fr;
          text-align: center;
     }

     .bawah {
          text-align: center;
     }

     .bank li {
          text-align: center;
          display: inline-block;
          margin: 5px;
     }

     .titile-footer {
          text-align: center;
     }

     .isi {
          margin-bottom: 30px;
          padding-bottom: 30px;
          display: block;
     }

     .atas2 {
          display: flex;
          justify-content: center;
          padding-bottom: 20px;
     }

     .background-atas {
          background: var(--secondary-dark);
     }
}

@media (min-width: 741px) {
     .isi {
          margin-bottom: 40px;
          padding: 0px 0px 40px 0px;
          display: block;
     }

     .background-atas {
          position: fixed;
          top: 0;
          left: 0;
          z-index: 1000;
          width: 100%;
          border-bottom: 1px solid rgba(255, 255, 255, 0.08);
     }

     .sticky {
          position: fixed;
          top: 0;
          left: 0;
          z-index: 1000;
          background: rgba(255, 255, 255, 0.95);
          backdrop-filter: blur(8px);
          box-shadow: var(--shadow-md);
          border-bottom: 1px solid rgba(15, 23, 42, 0.06);
     }

     .wrapper {
          padding-left: 20px;
          padding-right: 20px;
     }

     .bank {
          display: flex;
          justify-content: center;
          flex-wrap: wrap;
          margin-top: 20px;
          border-top: 1px solid #1e293b;
          padding-top: 20px;
     }

     .bank li {
          margin: 10px;
     }

     .atas1 {
          grid-template-columns: max-content 1fr;
          align-items: center;
     }

     .tempat-footer {
          grid-template-columns: 2fr 2fr 1.5fr 2fr;
     }

     .atas2 {
          display: flex;
          justify-content: flex-end;
          align-items: center;
     }

     .atas3 {
          display: grid;
          grid-template-columns: 1fr auto;
          align-items: center;
          gap: 24px;
     }
}

@media (min-width: 992px) {
     .wrapper {
          margin-right: auto;
          margin-left: auto;
          max-width: 1200px;
     }
}

/* Magnific Popup Zoom Animation & Glassmorphism */
.mfp-with-zoom .mfp-container,
.mfp-with-zoom.mfp-bg {
    opacity: 0;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.mfp-with-zoom.mfp-ready .mfp-container {
    opacity: 1;
}
.mfp-with-zoom.mfp-ready.mfp-bg {
    opacity: 0.95 !important;
    background: rgba(15, 23, 42, 0.96) !important;
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}
.mfp-with-zoom.mfp-removing .mfp-container,
.mfp-with-zoom.mfp-removing.mfp-bg {
    opacity: 0;
}

/* Rounded corners and shadow on the popup image */
.mfp-img {
    border-radius: var(--radius-md) !important;
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.6) !important;
    padding: 40px 0 !important;
}

/* Premium Popup Caption/Title Styling */
.mfp-title {
    font-family: var(--font-headings) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #ffffff !important;
    text-align: center !important;
    padding: 12px 16px !important;
    background: rgba(15, 23, 42, 0.8) !important;
    backdrop-filter: blur(8px);
    border-radius: var(--radius-sm) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    margin-top: 15px !important;
    box-shadow: var(--shadow-lg) !important;
    line-height: 1.6 !important;
}
.mfp-counter {
    font-family: var(--font-body) !important;
    font-size: 12px !important;
    color: #94a3b8 !important;
    top: 55px !important;
    right: 16px !important;
}

/* Premium Navigation Arrows */
.mfp-arrow {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 50% !important;
    width: 60px !important;
    height: 60px !important;
    transition: var(--transition) !important;
    margin-top: -30px !important;
    opacity: 0.85 !important;
}
.mfp-arrow:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    transform: scale(1.1) !important;
    opacity: 1 !important;
}
.mfp-arrow::before, .mfp-arrow::after {
    border: none !important;
    margin: 0 !important;
    top: auto !important;
    left: auto !important;
}
.mfp-arrow-left::before {
    content: '←' !important;
    color: #ffffff !important;
    font-size: 24px !important;
    line-height: 58px !important;
    display: block !important;
    text-align: center !important;
    font-weight: 400 !important;
}
.mfp-arrow-left:hover::before {
    color: var(--secondary-dark) !important;
}
.mfp-arrow-right::before {
    content: '→' !important;
    color: #ffffff !important;
    font-size: 24px !important;
    line-height: 58px !important;
    display: block !important;
    text-align: center !important;
    font-weight: 400 !important;
}
.mfp-arrow-right:hover::before {
    color: var(--secondary-dark) !important;
}

/* Style close button */
.mfp-close {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: 50% !important;
    width: 44px !important;
    height: 44px !important;
    line-height: 42px !important;
    position: fixed !important;
    right: 25px !important;
    top: 25px !important;
    color: #ffffff !important;
    transition: var(--transition) !important;
    text-align: center !important;
    padding: 0 !important;
    font-size: 28px !important;
    opacity: 0.85 !important;
}
.mfp-close:hover {
    background: #ef4444 !important;
    border-color: #ef4444 !important;
    transform: rotate(90deg) scale(1.05) !important;
    color: #ffffff !important;
    opacity: 1 !important;
}