:root{
    --brand-primary:#8EDAF0;
    --brand-secondary:#BFEFFF;
    --brand-dark:#1F2D3D;
    --brand-soft:#F4FCFF;
    --white:#FFFFFF;
    --shadow-lg:0 20px 45px rgba(31,45,61,.10);
    --shadow-md:0 12px 30px rgba(31,45,61,.08);
    --text-main:#1F2D3D;
    --text-soft:#5f6f7d;
    --surface:rgba(255,255,255,.82);
    --surface-strong:rgba(255,255,255,.92);
    --surface-border:rgba(255,255,255,.85);
    --line-color:rgba(142,218,240,.18);
    --site-header:rgba(255,255,255,.72);
    --site-footer:rgba(255,255,255,.75);
    --page-bg:radial-gradient(circle at top right, rgba(191,239,255,.55), transparent 35%), linear-gradient(180deg, #ffffff 0%, #f7fdff 48%, #f3fbff 100%);
    --input-bg:#ffffff;
    --theme-btn-bg:rgba(255,255,255,.68);
}
html[data-theme="dark"]{
    --brand-dark:#EAF7FE;
    --text-main:#EAF7FE;
    --text-soft:#AEBFCC;
    --surface:rgba(12,24,36,.78);
    --surface-strong:rgba(14,27,40,.88);
    --surface-border:rgba(142,218,240,.14);
    --line-color:rgba(142,218,240,.12);
    --site-header:rgba(8,18,29,.76);
    --site-footer:rgba(8,18,29,.82);
    --page-bg:radial-gradient(circle at top right, rgba(31,98,124,.36), transparent 34%), linear-gradient(180deg, #07131d 0%, #0a1823 50%, #0d1d29 100%);
    --input-bg:rgba(11,25,38,.9);
    --theme-btn-bg:rgba(14,27,40,.86);
    --shadow-lg:0 20px 45px rgba(0,0,0,.28);
    --shadow-md:0 12px 30px rgba(0,0,0,.20);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    margin:0;
    font-family:"Cairo", Tahoma, Arial, sans-serif;
    background:var(--page-bg);
    color:var(--text-main);
    min-height:100vh;
    position:relative;
    overflow-x:hidden;
    transition:background .35s ease, color .35s ease;
}
.ambient{
    position:fixed;border-radius:999px;filter:blur(55px);opacity:.38;pointer-events:none;z-index:-1;animation:floatBlob 16s ease-in-out infinite;
}
.ambient-1{width:280px;height:280px;background:rgba(142,218,240,.45);top:6%;right:4%;}
.ambient-2{width:220px;height:220px;background:rgba(191,239,255,.70);left:5%;top:34%;animation-delay:2s;}
.ambient-3{width:320px;height:320px;background:rgba(142,218,240,.28);bottom:8%;right:18%;animation-delay:4s;}
html[data-theme="dark"] .ambient-1{background:rgba(87,189,220,.24);}
html[data-theme="dark"] .ambient-2{background:rgba(59,119,144,.25);}
html[data-theme="dark"] .ambient-3{background:rgba(124,213,242,.12);}
@keyframes floatBlob{0%,100%{transform:translate3d(0,0,0) scale(1);}50%{transform:translate3d(18px,-22px,0) scale(1.06);}}
a{text-decoration:none;}
.text-muted{color:var(--text-soft)!important;}
.site-header{position:sticky;top:0;z-index:20;backdrop-filter:blur(12px);background:var(--site-header);border-bottom:1px solid rgba(142,218,240,.15);transition:background .35s ease;}
.navbar{padding:1rem 0;}
.brand-logo{width:58px;height:58px;border-radius:18px;object-fit:cover;box-shadow:var(--shadow-md);border:1px solid rgba(255,255,255,.8);}
.brand-logo-footer{width:54px;height:54px;}
.brand-title{font-size:1.05rem;}
.nav-link{color:var(--text-main)!important;font-weight:700;padding:.8rem 1rem!important;border-radius:14px;transition:.25s ease;}
.nav-link:hover{background:rgba(191,239,255,.20);}
.btn-brand,.btn-outline-brand,.btn-soft,.btn-theme-toggle{border-radius:16px;padding:.85rem 1.35rem;font-weight:800;transition:.25s ease;}
.btn-brand{background:linear-gradient(135deg, var(--brand-primary), #d7f7ff);border:0;color:#153243;box-shadow:0 10px 22px rgba(142,218,240,.35);}
.btn-brand:hover{transform:translateY(-2px);color:#153243;box-shadow:0 16px 28px rgba(142,218,240,.45);}
.btn-soft{background:var(--surface-strong);border:1px solid rgba(142,218,240,.28);color:var(--text-main);}
.btn-soft:hover{background:rgba(191,239,255,.16);color:var(--text-main);}
.btn-outline-brand{background:transparent;border:1px solid rgba(142,218,240,.75);color:var(--text-main);}
.btn-outline-brand:hover{background:rgba(191,239,255,.18);color:var(--text-main);}
.btn-theme-toggle{background:var(--theme-btn-bg);color:var(--text-main);border:1px solid rgba(142,218,240,.28);display:inline-flex;align-items:center;gap:.55rem;box-shadow:var(--shadow-md);}
.btn-theme-toggle:hover{background:rgba(191,239,255,.16);color:var(--text-main);}
.site-main{min-height:calc(100vh - 220px);}
.hero-section{padding:4.8rem 0 3rem;}
.hero-badge,.section-kicker{display:inline-flex;align-items:center;gap:.5rem;padding:.55rem 1rem;border-radius:999px;background:rgba(191,239,255,.20);color:#205872;font-weight:800;margin-bottom:1rem;}
html[data-theme="dark"] .hero-badge,html[data-theme="dark"] .section-kicker{color:#93def5;background:rgba(74,159,191,.18);}
.hero-title{font-size:clamp(2.2rem, 4vw, 4.1rem);line-height:1.25;font-weight:900;margin-bottom:1rem;}
.hero-subtitle{font-size:1.08rem;color:var(--text-soft);max-width:720px;line-height:2;}
.mini-stat-card,.hero-visual-card,.unit-card,.info-banner,.content-card,.booking-box{background:var(--surface);backdrop-filter:blur(14px);border:1px solid var(--surface-border);box-shadow:var(--shadow-lg);transition:background .35s ease,border-color .35s ease,box-shadow .35s ease;}
.hero-visual-card{border-radius:30px;padding:1.4rem;position:relative;overflow:hidden;}
.hero-visual-card::before{content:"";position:absolute;inset:0;background:linear-gradient(160deg, rgba(191,239,255,.24), transparent 45%);pointer-events:none;}
.hero-logo-wrap{padding:1rem;border-radius:26px;background:linear-gradient(145deg, rgba(191,239,255,.5), rgba(255,255,255,.95));display:flex;align-items:center;justify-content:center;margin-bottom:1rem;min-height:260px;}
.hero-logo-wrap img{max-width:100%;max-height:240px;border-radius:24px;object-fit:contain;}
.hero-features{display:flex;flex-wrap:wrap;gap:.75rem;}
.hero-features span,.amenity-chip{display:inline-flex;align-items:center;gap:.4rem;border-radius:999px;padding:.55rem .9rem;background:rgba(191,239,255,.18);font-size:.92rem;font-weight:700;color:var(--text-main);}
.mini-stat-card{padding:1.2rem;border-radius:22px;text-align:center;height:100%;}
.mini-stat-value{font-size:1.45rem;font-weight:900;}
.mini-stat-label{color:var(--text-soft);font-size:.95rem;}
.section-block{padding:3.2rem 0;}
.section-heading{display:flex;justify-content:space-between;gap:1rem;align-items:end;margin-bottom:1.6rem;}
.section-heading h2{margin:0;font-size:2rem;font-weight:900;}
.unit-card{border-radius:28px;overflow:hidden;height:100%;transition:.3s ease;}
.unit-card:hover{transform:translateY(-6px);box-shadow:0 24px 40px rgba(31,45,61,.14);}
html[data-theme="dark"] .unit-card:hover{box-shadow:0 24px 40px rgba(0,0,0,.28);}
.unit-card-image{display:block;height:240px;overflow:hidden;background:linear-gradient(135deg, rgba(191,239,255,.9), rgba(255,255,255,.9));}
.unit-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .35s ease;}
.unit-card:hover .unit-card-image img{transform:scale(1.04);}
.unit-placeholder{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;color:#527083;font-weight:700;background:linear-gradient(135deg, rgba(191,239,255,.75), rgba(255,255,255,.95));}
.unit-placeholder i{font-size:2.3rem;}
.unit-placeholder-lg{min-height:420px;}
.unit-card-body{padding:1.35rem;}
.unit-card-body h3{font-size:1.22rem;font-weight:900;margin-bottom:.25rem;}
.price-badge{background:rgba(142,218,240,.18);color:#134e67;padding:.55rem .85rem;border-radius:14px;font-weight:900;white-space:nowrap;}
.unit-card-text{color:var(--text-soft);line-height:2;margin-top:1rem;min-height:92px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.unit-meta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1rem;color:var(--text-soft);font-size:.95rem;}
.unit-meta span{display:inline-flex;align-items:center;gap:.35rem;}
.info-banner,.content-card{border-radius:28px;padding:1.6rem;}
.page-hero-sm{padding:3rem 0 1rem;}
.back-link{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#205872;font-weight:800;}
.details-gallery{display:flex;flex-direction:column;gap:1rem;}
.details-gallery-main{overflow:hidden;border-radius:30px;box-shadow:var(--shadow-lg);}
.details-gallery-main img{width:100%;min-height:420px;max-height:520px;object-fit:cover;}
.details-gallery-thumbs{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;}
.details-gallery-thumbs img{width:100%;height:110px;object-fit:cover;border-radius:18px;box-shadow:var(--shadow-md);cursor:pointer;}
.details-description{line-height:2.1;font-size:1.04rem;}
.amenity-row{display:flex;align-items:center;gap:.85rem;padding:1rem;border-radius:18px;background:rgba(191,239,255,.12);height:100%;font-weight:700;}
.amenity-row i{color:#1a6d8d;font-size:1.2rem;}
.booking-box{border-radius:28px;padding:1.4rem;top:110px;}
.price-panel{background:linear-gradient(145deg, rgba(191,239,255,.30), rgba(255,255,255,.92));border-radius:22px;padding:1.2rem;}
html[data-theme="dark"] .price-panel{background:linear-gradient(145deg, rgba(54,116,138,.24), rgba(14,27,40,.92));}
.price-main{font-size:2rem;font-weight:900;}
.price-main span{font-size:1rem;color:var(--text-soft);}
.price-sub{color:var(--text-soft);font-size:.95rem;}
.quick-specs{display:grid;grid-template-columns:1fr 1fr;gap:.85rem;margin-top:1.2rem;}
.quick-specs div{padding:.85rem;border-radius:16px;background:rgba(191,239,255,.12);font-size:.95rem;display:flex;align-items:center;gap:.5rem;}
.form-control{border-radius:16px;padding:.85rem 1rem;border:1px solid rgba(142,218,240,.26);background:var(--input-bg);color:var(--text-main);box-shadow:none!important;}
.form-control:focus{border-color:rgba(142,218,240,.9);background:var(--input-bg);color:var(--text-main);box-shadow:0 0 0 .18rem rgba(142,218,240,.16)!important;}
.form-label{font-weight:800;margin-bottom:.45rem;}
.divider{height:1px;background:linear-gradient(90deg, transparent, rgba(142,218,240,.6), transparent);margin:1.3rem 0;}
.contact-row{display:flex;gap:1rem;align-items:flex-start;padding:1rem 0;border-bottom:1px solid var(--line-color);}
.contact-row:last-child{border-bottom:none;}
.contact-row i{font-size:1.25rem;color:#1c7493;}
.site-footer{padding:2rem 0 2.4rem;background:var(--site-footer);backdrop-filter:blur(10px);border-top:1px solid rgba(142,218,240,.16);transition:background .35s ease;}
.footer-links a{color:var(--text-main);font-weight:700;}
.social-links .social-btn,.floating-whatsapp a{width:48px;height:48px;display:inline-flex;align-items:center;justify-content:center;border-radius:16px;background:linear-gradient(145deg, rgba(191,239,255,.34), rgba(255,255,255,.98));color:var(--text-main);box-shadow:var(--shadow-md);}
html[data-theme="dark"] .social-links .social-btn,html[data-theme="dark"] .floating-whatsapp a{background:linear-gradient(145deg, rgba(35,71,87,.85), rgba(14,27,40,.98));}
.floating-whatsapp{position:fixed;left:22px;bottom:22px;z-index:50;}
.floating-whatsapp a{width:62px;height:62px;font-size:1.6rem;animation:pulseFloat 3.4s ease-in-out infinite;}
@keyframes pulseFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-6px);}}
.copyright{color:var(--text-soft);font-size:.95rem;}
.hero-carousel{border-radius:26px;overflow:hidden;box-shadow:var(--shadow-lg);background:#dceef6;}
.hero-carousel-inner,.hero-carousel .carousel-item,.hero-carousel .carousel-item img{height:420px;}
.hero-carousel .carousel-item img{object-fit:cover;}
.hero-carousel-caption{position:absolute;inset:auto 18px 18px 18px;display:flex;flex-direction:column;gap:.15rem;padding:1rem 1.1rem;border-radius:18px;background:linear-gradient(180deg, rgba(7,25,38,.15), rgba(7,25,38,.62));color:#fff;backdrop-filter:blur(10px);}
.hero-carousel-caption span{font-size:.88rem;opacity:.86;}
.hero-carousel-caption strong{font-size:1.1rem;font-weight:800;}
.hero-carousel-indicators{margin-bottom:.65rem;}
.hero-carousel-indicators [data-bs-target]{width:10px;height:10px;border-radius:999px;border:none;background:rgba(255,255,255,.8);}
.hero-carousel-control{width:44px;height:44px;top:50%;transform:translateY(-50%);bottom:auto;margin:0 1rem;border-radius:999px;background:rgba(7,25,38,.28);backdrop-filter:blur(10px);}
.hero-carousel .carousel-control-prev{right:auto;left:12px;}
.hero-carousel .carousel-control-next{left:auto;right:12px;}
.alert{border-radius:18px;}
.table,.table > :not(caption) > * > *{color:var(--text-main);}
html[data-theme="dark"] .navbar-toggler{filter:invert(1);}
html[data-theme="dark"] .hero-carousel{background:#102230;}
@media (max-width: 991.98px){.hero-section{padding:3rem 0 2rem;}.booking-box{top:0;}.details-gallery-main img{min-height:320px;}.hero-carousel-inner,.hero-carousel .carousel-item,.hero-carousel .carousel-item img{height:360px;}}
@media (max-width: 575.98px){.brand-logo{width:48px;height:48px;}.hero-title{font-size:2rem;}.section-heading{flex-direction:column;align-items:start;}.quick-specs{grid-template-columns:1fr;}.btn-theme-toggle .theme-toggle-text{display:none;}.hero-carousel-inner,.hero-carousel .carousel-item,.hero-carousel .carousel-item img{height:280px;}}
