@font-face {
    font-family: 'UAESymbol';
    src: url('../fonts/font.ttf') format('truetype');
}
@font-face {
    font-family: 'mfont';
    src: url('../fonts/All-Genders-Regular-v4.otf') format('truetype');
}

@font-face {
    font-family: 'insta';
    src: url('../fonts/instagram_e900.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'wa';
    src: url('../fonts/whatsapp_e906.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'tik';
    src: url('../fonts/tiktok_e903.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'mail';
    src: url('../fonts/mail_e902.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'landline';
    src: url('../fonts/landline_e901.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'spa1982';
    src: url('../fonts/spa1982.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
/*PAUMENTS SECRION */
@font-face {
    font-family: 'apple_pay';
    src: url('../fonts/apple_pay.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'google_pay';
    src: url('../fonts/google_pay.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}@font-face {
    font-family: 'mastercard';
    src: url('../fonts/mastercard.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}@font-face {
    font-family: 'visa';
    src: url('../fonts/visa.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}@font-face {
    font-family: 'tamara';
    src: url('../fonts/tamara.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}@font-face {
    font-family: 'tabby';
    src: url('../fonts/tabby.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}@font-face {
    font-family: 'arr_1';
    src: url('../fonts/arr_1.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}@font-face {
    font-family: 'arrow_2';
    src: url('../fonts/arr_2.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

.uae-symbol {
    font-family: 'UAESymbol';
    margin-right: 5px;
    color : #a7c957;
}

.spa1982__ {
     font-family: 'spa1982';
     speak: none;
     font-size: 1.5rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;

 }.arrow_1__ {
     font-family: 'arr_1';
     speak: none;
     font-size: 1.5rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;

}
.arrow_2__ {
     font-family: 'arrow_2';
     speak: none;
     font-size: 1.5rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
}

.arrow_1-i::before {
      content: "\e900";
}
.arrow_2-i::before {
      content: "\e901";
  }
.apple_pay__ {
     font-family: 'apple_pay';
     speak: none;
     font-size: 3.5rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
     background:none;
     font-weight:0;
 }

.google_pay__ {
     font-family: 'google_pay';
     speak: none;
     font-size: 3rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
     background:none;
    font-weight:0;
 }
.mastercard__ {
     font-family: 'mastercard';
     speak: none;
     font-size: 2.6rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
     background:none;
    font-weight:0;
 }
.visa__ {
     font-family: 'visa';
     speak: none;
     font-size: 3.3rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
     background:none;
    font-weight:0;
 }

.tamara__ {
     font-family: 'tamara';
     speak: none;
     font-size: 4rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
     background:none;
    font-weight:0;
 }
.tabby__ {
     font-family: 'tabby';
     speak: none;
     font-size: 3.5rem;
     font-style: normal;
     /*font-weight: normal;*/
     font-variant: normal;
     text-transform: none;
     line-height: 1;
     background:none;
    font-weight:0;
}

.apple_pay-i::before {
    content: "\e910";
}
.google_pay-i::before {
    content: "\e922";
}
.mastercard-i::before {
    content: "\e923";
}
.visa-i::before {
    content: "\e924";
}
.tamara-i::before {
    content: "\e920";
}
.tabby-i::before {
    content: "\e919";
}
/* Professional grid for payments icons */
.payments_accept {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 18px; /* space between items */
    justify-items: center;
    align-items: center;
    margin: 24px auto;
    max-width: 700px; /* keeps it centered */
}

/* Force 3 per row on small screens */
@media (max-width: 640px) {
    .payments_accept {
        grid-template-columns: repeat(3, 1fr);
    }
}

.payments_accept i {
    /*font-size: 3rem;   !* adjust icon size *!*/
    display: flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 56px;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}






.wa__ {
    font-family: 'wa';
    speak: none;
    font-size: 1.5rem;
    font-style: normal;
    /*font-weight: normal;*/
    font-variant: normal;
    text-transform: none;
    line-height: 1;
}
.insta__ {
    font-family: 'insta';
    speak: none;
    font-size: 1.5rem;
    font-style: normal;
    /*font-weight: normal;*/
    font-variant: normal;
    text-transform: none;
    line-height: 1;

}
.tik__ {
    font-family: 'tik';
    speak: none;
    font-size: 1.5rem;
    font-style: normal;
    /*font-weight: normal;*/
    font-variant: normal;
    text-transform: none;
    line-height: 1;

}
.mail__ {
    font-family: 'mail';
    speak: none;
    font-size: 1.5rem;
    font-style: normal;
    /*font-weight: normal;*/
    font-variant: normal;
    text-transform: none;
    line-height: 1;

}
.landline__ {
    font-family: 'landline';
    speak: none;
    font-size: 1.5rem;
    font-style: normal;
    /*font-weight: normal;*/
    font-variant: normal;
    text-transform: none;
    line-height: 1;

}
#wa___ {
    position: relative;
    right: 1px;
    top: 4px;
    color: #fff;
    font-size: 1.4rem;
    margin-right: 5px;
}
#arrow_1___ {
    position: absolute;
    right: 1px;
    top: 4px;
    color: #fff;
    font-size: 8.4rem;
    margin-right: 5px;
    z-index: 1000;
}

#landline___{
    position: relative;
    right: 1px;
    top: 4px;
    font-size: 1.4rem;
    color: #fff;
    margin-right: 5px;
}

#mail___{
    position: relative;
    right: 1px;
    top: 1.5px;
    font-size: 1.4rem;
    color: #fff;
    margin-right: 5px;
}
#tiktok___{
    position: relative;
    right: 1px;
    top: 4px;
    font-size: 1.3rem;
    margin-right: 5px;
}
#insta___{
    position: relative;
    right: 1px;
    top: 4px;
    font-size: 1.3rem;
    color: #fff;
    margin-right: 5px;
}
#spa1982___{
    position: relative;
    right: 130px;
    margin-top: 10px;
    font-size: 2rem;
    color: #fff;
}

.mail-b::before {
    content: "\e902";
}
.spa1982-b::before {
    content: "\e900";
}
.landline-b::before {
    content: "\e901";
}
.wa-i::before {
    content: "\e906";
}
.insta-b::before {
    content: "\e900";
}
.tik-b::before {
    content: "\e903";
}



:root{
    --brand:#0077b6; /* teal */
    --brand-2:#5fb59e; /* light teal */
    --text:#0b1320;
    --muted:#667085;
    --bg:#f6f8f9;
    --bg-3:
    linear-gradient(217deg, rgb(6 214 160 / 0.8), transparent 70.71%),
    linear-gradient(127deg, rgb(17 138 178 / 0.8), transparent 70.71%),
    linear-gradient(336deg, rgb(239 71 111 / 0.8), transparent 70.71%);
    --bg-2:
    linear-gradient(217deg, rgb(31 185 232 / 0.8), transparent 70.71%),
    linear-gradient(120deg, rgb(253 227 51/ 0.8), transparent 70.71%),
    linear-gradient(127deg, rgb(60 179 79 / 0.8), transparent 70.71%),
    linear-gradient(336deg, rgb(236 74 79 / 0.8), transparent 70.71%);
    --card:#ffffff;
    --shadow:0 12px 40px 0 4px 20px rgba(0, 0, 0, 0.06), 0 12px 40px rgba(0, 0, 0, 0.08);
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;padding:0;font-family:system-ui,-apple-system,seg oe ui,Roboto,"Noto Naskh Arabic UI",Tahoma,Arial,sans-serif;color:var(--text);background:var(--bg)}

/* ===== Snap Layout (TikTok-style vertical pages) ===== */
.snap-container{
    height:100dvh; /* mobile-safe viewport */
    overflow-y:auto;
    scroll-snap-type:y mandatory;
    scroll-behavior:smooth;
    -webkit-overflow-scrolling:touch;
}
section.snap{scroll-snap-align:start;min-height:100dvh;position:relative;display:flex;align-items:center;justify-content:center;padding:0px}

/* generic content card so text stays readable over images */
.content-card{position:relative; color:#fff;font-family: 'mfont'; background:rgba(0,0,0,.3);backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(10px); border-radius:22px; box-shadow:var(--shadow);padding:50px;max-width:340px;width:min(92%,340px)}

.content-card-2 {
    position: relative;
    background: rgba(255, 255, 255, 0.12);
    border-radius: 20px;
    border: 1px solid rgba(255, 255, 255, 0.28);
    box-shadow:
            inset 0 1px 0 rgba(255, 255, 255, 0.28),
            0 10px 35px rgba(0, 0, 0, 0.16);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    padding: 30px;
    text-align: center;
    color: #000;
    padding:20px;
    max-width:340px;
    width:min(100%,340px);
    font-family: 'mfont';
}

.content-card-2::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
            radial-gradient(100% 100% at 50% 0%, rgba(255, 255, 255, 0.35) 0%, rgba(255, 255, 255, 0) 45%),
            radial-gradient(120% 120% at 50% 120%, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0) 55%);
    pointer-events: none;
}







/**/
.content-card-3{color:#000;font-family: 'mfont';padding:20px;max-width:440px;width:min(95%,350px)}

/* ===== Hero ===== */
.hero {
    position: relative;
    color: #fff;
    overflow: hidden; /* hide overflow edges from video */
    background: none; /* remove image */
}
/* Overlay for blur + darkness */
.hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.4); /* dark layer */
    backdrop-filter: blur(1px);   /* blur the video underneath */
    -webkit-backdrop-filter: blur(1px); /* Safari support */
    z-index: 1; /* above video, below text */
}
.hero video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 0; /* keep video behind content */
}
.hero .inner{width:min(92%,640px);margin-inline:auto;text-align:center}
.hero .inner {
    position: relative;
    z-index: 1; /* keep text above video */
}
.logo{width:82px;height:82px; margin:0 auto 16px;display:grid;place-items:center;}
h1{font-size: clamp(22px, 5.2vw, 34px);margin:6px 0 8px}
.lead{font-size: clamp(14px, 3.4vw, 18px);opacity:.95}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;background:var(--brand);color:#fff;text-decoration:none;font-weight:700;margin-top:14px;box-shadow:0 8px 24px rgba(42,157,143,.35)}
.btn-3{display:inline-block;padding:12px 18px;border-radius:999px;background:var(--brand);color:#fff;text-decoration:none;font-weight:700;margin-top:14px;box-shadow:0 8px 24px rgba(42,157,143,.35)}
.btn-2{display:inline-block;padding:12px 18px;border-radius:999px;background:none;color:#fff;text-decoration:none;font-weight:700;margin-top:14px;box-shadow:0 8px 24px rgba(42,157,143,.35); border: 2px solid #fff}
.btn--ghost{background:transparent;color:#fff;border:1.5px solid #fff}
/*.swipe-tip{position:absolute;bottom:14px;inset-inline:0;text-align:center;color:#fff;opacity:.85;font-size:12px; z-index: 2; font-family: 'mfont' }*/
/*.swipe-tip-2{position:absolute;bottom:14px;}*/
.swipe-tip-2 {
    position:absolute;
    bottom:15px;
    display: flex;
    align-items: center; /* Vertically center icon and text */
    gap: 10px;
    font-family: 'mfont';
    padding: 10px;
    color: #fff;
    font-size: 12px;

}
.swipe-tip-2 #arrow_1___ {
    font-size:.8rem;
    position: relative;
    left: 10px;
    top: 1px;
    color: #fff;
}.swipe-tip {
    position:absolute;
    bottom:15px;
    display: flex;
    align-items: center; /* Vertically center icon and text */
    gap: 10px;
    font-family: 'mfont';
    padding: 10px;
    color: #fff;
    font-size: 12px;
    z-index: 2;

}
.swipe-tip #arrow_2___ {
    font-size:.8rem;
    position: relative;
    left: -6px;
    top: 1px;
    color: #fff;
}


.swipe-tip-title{position:absolute;top:1px;inset-inline:0;text-align:center;color:#fff;opacity:.85;font-size:24px; z-index: 2; font-family: 'mfont' }



/* ===== Service highlight ===== */
.service{background:#000}
.service .content-card{text-align:left}
.service h2{margin:6px 0 10px;font-size: clamp(20px, 5vw, 28px)}
.service p{color:#e9ecef;margin:0 0 10px}
.cta-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.btn--primary-o{background:var(--brand)}
.btn--light{background:#fff;color:var(--brand);border:1.5px solid var(--brand)}

/* ===== Map ===== */
.map{background:linear-gradient(180deg,#e9f7f3,#f9fbfb)}
.map .content-card{padding:12px}
.map iframe{width:100%;height:50vh;border:1px solid rgba(0,0,0,.1); border-radius:16px; box-shadow:var(--shadow)}




.chip-row{display:flex;gap:15px;flex-wrap:wrap;justify-content:center}
.chip-row-2{position: relative; bottom: 50px; display:flex;gap:15px;flex-wrap:wrap;justify-content:center}
.chip{position:relative; background:none;padding:5px 5px}
.cards{
    width: 60%;
    height: auto;
}

/* ===== About + Contact ===== */
.about{background:#3a5a40}
/*.about{background:var(--bg-3)}*/
.about .content-card{padding:18px}
/*.about h3{margin:0 0 8px}*/
.about p{
    color:#adb5bd;
    direction: ltr;
    font-size: 14px;
    line-height: 1.8;
    margin: 0 0 10px;
    text-align: justify;
}
.kvs{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.kv{color:#1b4332; background:#fff;border-radius:12px;padding:12px;text-align:center;box-shadow:var(--shadow)}
/* Contact block: right aligned, neat spacing */
.contact {
    font-family: 'mfont';
    direction: rtl; /* keep Arabic reading order */
    display: flex;
    flex-direction: column;
    align-items: flex-end; /* align to the right */
    gap: 8px; /* space between rows */
    margin-top: 20px;
    color: #fff;
}

.contact > div {
    display: flex;
    align-items: center;
    gap: 8px; /* space between icon and text */
}

/* Icons — give them a consistent size */
.contact i {
    font-size: 1.2rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Make links look like normal text */
.contact a {
    text-decoration: none;
    color: inherit;
}

/* Optional hover effect */
.contact a:hover {
    opacity: 0.85;
}



/* ===== Nav dots ===== */
.dots{position:fixed;top:50%;inset-inline-start:10px;transform:translateY(-50%);display:flex;flex-direction:column;gap:8px;z-index:30}
.dot{width:10px;height:10px;border-radius:50%;background:#cdd5d3;opacity:.75}
.dot.active{position:relative; left:3px; border:3px solid #fff; background:var(--brand); width:16px;height:16px;}

/* ===== Floating WhatsApp ===== */
.wa{position:fixed;bottom:16px;inset-inline-end:16px;z-index:40;background:#25D366;color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.25);text-decoration:none}
.insta_{position:fixed;bottom:76px;inset-inline-end:16px;z-index:40;background:#ef476f;color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.25);text-decoration:none}
.tiktok{position:fixed;bottom:136px;inset-inline-end:16px;z-index:40;background:#010101;color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.25);text-decoration:none}
.mail{position:fixed;bottom:136px;inset-inline-end:16px;z-index:40;background:#010101;color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.25);text-decoration:none}
.landline{position:fixed;bottom:136px;inset-inline-end:16px;z-index:40;background:#010101;color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.25);text-decoration:none}



/* ===== Refund Policy Modal (independent) ===== */
.refundx-modal {font-family: 'mfont'; position: fixed; inset: 0; display: none; z-index: 10000; }
.refundx-modal.is-open { display: block; }

.refundx-modal__overlay {
    position: absolute; inset: 0; background: rgba(0,0,0,.6);
    backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}

/* Center nicely with safe top/bottom padding (works on mobile) */
.refundx-modal.is-open {
    display: flex; align-items: center; justify-content: center;
    padding-block: clamp(12px, 4vh, 32px);
}

.refundx-modal__dialog {
    width: min(92%, 560px);
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0,0,0,.25);
    display: flex; flex-direction: column;
    max-height: min(90vh, 720px);
    border: 1px solid rgba(255,255,255,.6);
    animation: refundx-slideUp .28s ease-out;
    position: relative;
}

.refundx-modal__close {
    position: absolute; top: 12px; inset-inline-end: 12px;
    width: 36px; height: 36px; border: 0; border-radius: 50%;
    background: #fff; box-shadow: 0 2px 6px rgba(0,0,0,.12);
    font-size: 1.2rem; cursor: pointer;
    top: 12px;
    inset-inline-end: 12px;
}

.refundx-modal__header {
    padding: 18px 22px;
    background: linear-gradient(90deg, #0ea5e9, #0284c7);
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,.25);
}
.refundx-modal__header h3 { margin: 0; font-weight: 800; font-size: 1.2rem; }

.refundx-modal__content {
    padding: 16px 18px;
    /*background: #f8fafc;*/
    background: #fff;
    overflow: auto; -webkit-overflow-scrolling: touch;
    line-height: 1.9; color: #333; font-size: 1rem;
}
.refundx-logo { display:block; width: 120px; height:auto; margin: 0 auto 10px; }
.refundx-text { margin: 0; text-align: justify; }

.refundx-modal__footer {
    padding: 10px 18px; font-size: 0.85rem; color:#667085; text-align: center; background:#fff;direction: ltr; text-align: center;
}

body.refundx-lock { overflow: hidden; }

@keyframes refundx-slideUp {
    from { transform: translateY(8px); opacity: 0; }
    to   { transform: translateY(0);  opacity: 1; }
}




.policy-text-ar {
    font-weight: bold;
    font-size: 1.3rem;
    /*line-height: 1.9;*/
    text-align: right;
    direction: rtl;
    color: #000;
    font-family: 'mfont';
}
/*.policy-text-en {*/
/*    font-weight: bold;*/
/*    font-size: 1.3rem;*/
/*    line-height: 1.9;*/
/*    text-align: left;*/
/*    direction: ltr;*/
/*    color: #000;*/
/*    font-family: 'mfont';*/
/*}*/
#refund-title {
    font-size: 22px;
    padding: 18px 20px;
    background: #f7f7f7;
    border-bottom: 1px solid #eee;
}


.link-like{text-align: right; background:none;border:none;color:#0096c7;text-decoration:underline;cursor:pointer;font-size: 14px;font-family: 'mfont';}

@media (min-width:768px){
    .dots{inset-inline-start:18px}
}

/* horizontal carousel */
.services-carousel{
    display:flex; overflow-x:auto; scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
}
.service-slide {
    flex: 0 0 100%;
    height: 100%;
    min-height: 100dvh;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    scroll-snap-align: start;
    background-size: cover;
    /*background-position: center;*/
    background-repeat: no-repeat;
}

.services-carousel::-webkit-scrollbar{ display:none }

/* per-slide image */
.slide-bg{
    position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
}
.slide-overlay{
    position:absolute; inset:0; background:linear-gradient(180deg,rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, .1) 15%, rgba(0, 0, 0, 0) 100%);;
}
.map{
    display: block;
}

/* keep your existing .content-card look and buttons */
.service .content-card{ text-align:center; z-index:2 }
.price-pill{ position:absolute; left:5px; top:5px; font-size: 22px; font-family: 'UAESymbol';
    background:#A7C957; color:#fff; font-weight:800; border-radius:999px; padding:6px 10px; z-index: 3 }

.h-dots {
    position: absolute;
    bottom: 45px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 5;
}
.h-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background:#cdd5d3;opacity:.75;
}
.h-dot.active {
    /*background: #ccc;*/
    background:var(--brand);
    width: 15px;
    height: 15px;
    position: relative;
    bottom: 3px;
    border: 3px solid #fff;
}

/*---------*/



/* --- OpenAI-style blurry gradient for p4 (no image) --- */
#p4 {
    position: relative;
    overflow: hidden;
    background: #eaf0ff;            /* pale base like the screenshot */
    font-family: 'mfont';
}

/* refine the cards image in p4 */
#p4 .cards-figure {
    text-align: center;        /* center horizontally */
    margin: 16px auto;
}

#p4 .cards-img {
    max-width: 220px;          /* adjust this number to control size */
    width: 100%;
    height: auto;
    display: inline-block;
}


#p4::before {
    content: "";
    position: absolute;
    inset: -10% -10% -10% -10%;     /* bleed outside to avoid edges when blurring */
    z-index: 0;

    /* layered radial gradients = colorful blobs */
    background:
            radial-gradient(40% 35% at 18% 30%, rgba(255, 99, 132, 0.60), transparent 60%),
            radial-gradient(38% 34% at 72% 22%, rgba(255, 205, 86, 0.55), transparent 62%),
            radial-gradient(42% 36% at 80% 70%, rgba(75, 192, 192, 0.55), transparent 62%),
            radial-gradient(44% 38% at 30% 80%, rgba(153, 102, 255, 0.55), transparent 64%),
            radial-gradient(30% 26% at 55% 50%, rgba(255, 159, 64, 0.35), transparent 70%);
    filter: blur(60px);
    -webkit-filter: blur(5px);

    /* gentle motion */
    animation: p4-bg-move 16s ease-in-out infinite;
    transform: scale(1.1);
}

/* keep your content above the background */
#p4 > .container { position: relative; z-index: 1; }

/* optional: stronger text contrast on this section */
#p4 .section-title,
#p4 .section-subtitle { color: #0b1320; }

/* Motion keyframes */
@keyframes p4-bg-move {
    0%   { transform: translate3d(0, 0, 0) scale(1.08); }
    50%  { transform: translate3d(0, -1.5%, 0) scale(1.12); }
    100% { transform: translate3d(0, 0, 0) scale(1.08); }
}

/* Accessibility: reduce motion */
@media (prefers-reduced-motion: reduce) {
    #p4::before { animation: none; }
}



/* ===== New Booking Modal ===== */
.booking-modal {
    position: fixed;
    inset: 0;
    display: none;
    z-index: 9999;
}

.booking-modal.is-open { display: block; }

.booking-modal__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
}

.booking-modal__dialog {
    position: relative;
    margin: 0;
    width: 100vw;
    height: 100vh;
    background: #fff;
    display: flex;
    flex-direction: column;
}

.booking-modal__close {
    position: absolute;
    top: 8px;
    inset-inline-end: 8px;
    border: none;
    background: #f2f2f2;
    border-radius: 50%;
    width: 36px;
    height: 36px;
    cursor: pointer;
}

.booking-modal__header {
    padding: 18px 20px;
    border-bottom: 1px solid #eee;
}

.booking-modal__subtitle {
    font-size: 14px;
    color: var(--muted);
}

.booking-modal__content {
    padding: 18px 20px;
    overflow-y: auto;
    line-height: 1.8;
}

.booking-modal__footer {
    font-size: 14px;
    margin: 0 auto 16px;
    display: grid;
    place-items: center;
}

.service-pill {
    background: var(--brand);
    color: #fff;
    padding: 6px 10px;
    border-radius: 999px;
    font-weight: bold;
    display: inline-block;
}

body.modal-lock { overflow: hidden; }


.contact .contact__item{
    display:flex; align-items:center; gap:.5rem;
    text-decoration:none; color:inherit;
    padding:6px 10px; border-radius:12px;
}
.contact .contact__item:hover{ background:rgba(255,255,255,.08); }
.contact .contact__item i{ pointer-events:none; }


/* ===== Policy Modal (match refund style) ===== */
.policy-modal {font-family: 'mfont'; position: fixed; inset: 0; display: none; z-index: 10000; }
.policy-modal.is-open {
    display: flex;                 /* center like refund */
    align-items: center;
    justify-content: center;
    padding-block: clamp(12px, 4vh, 32px); /* top/bottom air on mobile */
}

/* overlay (same blur/fade feel) */
.policy-modal__overlay{
    position: absolute; inset: 0; background: rgba(0,0,0,.6);
    backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}

/* dialog card (same sizing, radius, shadow) */
.policy-modal__dialog{
    position: relative;                           /* anchor the close button */
    width: min(92%, 560px);
    max-height: min(90vh, 720px);
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0,0,0,.25);
    display: flex; flex-direction: column;
    border: 1px solid rgba(255,255,255,.6);
    animation: policy-slideUp .28s ease-out;      /* same animation timing */
}

/* close button (same size/placement) */
.policy-modal__close{
    position: absolute; top: 12px; inset-inline-end: 12px;
    width: 36px; height: 36px; border: 0; border-radius: 50%;
    background: #fff; box-shadow: 0 2px 6px rgba(0,0,0,.12);
    font-size: 1.2rem; cursor: pointer;
}

/* header (same gradient bar as refund) */
.policy-modal__header{
    padding: 18px 22px;
    background: linear-gradient(90deg, #0ea5e9, #0284c7);
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,.25);
}
.policy-modal__header h3{ margin: 0; font-weight: 800; font-size: 1.2rem; }

/* content scroll area */
.policy-modal__content{
    padding: 16px 18px;
    /*background: #f8fafc;*/
    background: #fff;
    overflow: auto; -webkit-overflow-scrolling: touch;
    line-height: 1.9; color: #333; font-size: 1rem;
}

/* lock body scroll when open (use if your JS toggles .policy-lock) */
body.policy-lock{ overflow: hidden; }

/* animation keyframes — same feel as refund */
@keyframes policy-slideUp {
    from { transform: translateY(8px); opacity: 0; }
    to   { transform: translateY(0);  opacity: 1; }
}





