/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
    --navy:#003760;--blue:#0092c8;--blue-light:#2e96db;
    --blue-pale:#e8f4fb;--accent:#f0a500;
    --text:#2d3748;--text-muted:#718096;
    --border:#e2e8f0;--bg:#f7fafc;--white:#ffffff;
    --radius:10px;
    --shadow:0 2px 12px rgba(0,55,96,.09);
    --shadow-md:0 6px 24px rgba(0,55,96,.14);
    --trans:all .25s ease;
}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;font-size:15px;line-height:1.7}
a{text-decoration:none;color:var(--blue)}
a:hover{color:var(--navy)}
img{max-width:100%;display:block}

/* ── Reading progress ── */
#read-progress{position:fixed;top:0;left:0;height:3px;width:0%;background:linear-gradient(90deg,var(--blue),var(--accent));z-index:9999;transition:width .1s linear}

/* ── Top bar ── */
.top-bar{background:var(--navy);color:rgba(255,255,255,.75);font-size:12px;text-align:center;padding:7px 20px;letter-spacing:.2px}
.top-bar a{color:#7dd4f8}
.top-bar a:hover{text-decoration:underline}

/* ── Header ── */
header{background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:900;box-shadow:0 2px 16px rgba(0,0,0,.07);transition:box-shadow .3s ease}
header.scrolled{box-shadow:0 4px 28px rgba(0,55,96,.15)}
.header-wrap{max-width:1280px;margin:auto;padding:12px 30px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.logo-block{display:flex;align-items:center;gap:12px}
.logo-block img{width:150px;height:auto}
.logo-text .tagline{display:block;color:var(--blue);font-weight:600;font-size:12px}
.logo-text small{display:block;font-size:11px;color:var(--text-muted);line-height:1.4}
.header-cta{display:flex;gap:8px;align-items:center;flex-shrink:0}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:6px;font-family:'Poppins',sans-serif;font-size:13px;font-weight:600;border:2px solid transparent;cursor:pointer;transition:var(--trans);white-space:nowrap}
.btn-primary{background:var(--blue);color:var(--white);border-color:var(--blue)}
.btn-primary:hover{background:var(--navy);border-color:var(--navy);color:var(--white)}
.btn-outline{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-outline:hover{background:var(--blue);color:var(--white)}

/* ── Nav ── */
nav.main-nav{background:linear-gradient(90deg,var(--navy) 0%,#01518a 60%,var(--blue) 100%)}
.nav-wrap{max-width:1280px;margin:auto;padding:0 30px;display:flex;align-items:center;overflow-x:auto;scrollbar-width:none}
.nav-wrap::-webkit-scrollbar{display:none}
.nav-wrap a{color:rgba(255,255,255,.85);padding:13px 14px;font-size:13px;font-weight:500;white-space:nowrap;transition:var(--trans)}
.nav-wrap a:hover,.nav-wrap a.active{color:var(--white);background:rgba(255,255,255,.13)}
/* fade hint that nav is scrollable on mobile */
.nav-scroll-wrap{position:relative}
.nav-scroll-wrap::after{content:'';position:absolute;top:0;right:0;bottom:0;width:32px;background:linear-gradient(to left,rgba(0,55,96,.7),transparent);pointer-events:none}

/* ── Breadcrumb ── */
.breadcrumb{background:var(--blue-pale);border-bottom:1px solid #d1e9f5;padding:8px 30px;font-size:12px;color:var(--text-muted)}
.breadcrumb-inner{max-width:1280px;margin:auto;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.breadcrumb a{color:var(--blue)}
.breadcrumb i{font-size:9px;color:#b0c8d8}

/* ── Page title banner ── */
.page-title-bar{background:linear-gradient(135deg,var(--navy) 0%,#015088 100%);color:var(--white);padding:30px 30px 28px;text-align:center;position:relative;overflow:hidden}
.page-title-bar::before,.page-title-bar::after{content:'';position:absolute;border-radius:50%;background:rgba(255,255,255,.04);animation:orb 8s ease-in-out infinite alternate}
.page-title-bar::before{width:320px;height:320px;top:-100px;right:-60px}
.page-title-bar::after{width:220px;height:220px;bottom:-80px;left:-40px;animation-delay:-4s}
@keyframes orb{from{transform:scale(1) translate(0,0)}to{transform:scale(1.18) translate(20px,10px)}}
.page-title-bar h1{position:relative;z-index:1;font-size:clamp(1.15rem,2.5vw,2rem);font-weight:600;color:var(--white);line-height:1.3;margin-bottom:6px;text-transform: uppercase;}
.page-title-bar h1 span{color:#7dd4f8}
.page-title-bar .page-sub{position:relative;z-index:1;font-size:13px;color:rgba(255,255,255,.65);display:flex;align-items:center;justify-content:center;gap:6px;margin-top:6px}
.page-title-bar .page-sub i{font-size:12px}

/* ── 2-col layout ── */
.page-body{max-width:1280px;margin:32px auto;padding:0 30px;display:grid;grid-template-columns:1fr 270px;gap:32px;align-items:start}
.main-content{min-width:0}

/* ── Intro block ── */
.intro-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow);margin-bottom:40px}
.intro-card p{color:#6B7C93;margin-bottom:14px;font-size:1rem;line-height:1.7}
.intro-card p:last-of-type{margin-bottom:0}
.intro-lead{color:#2C3E50 !important;font-size:1rem !important;font-weight:500}

/* ── Space cards ── */
.spaces-label{
    display:inline-flex;align-items:center;gap:6px;
    font-size:1rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
    color:var(--blue);margin:18px 0 12px;
}
.spaces-label::before{content:'';display:block;width:20px;height:2px;background:var(--blue);border-radius:2px;flex-shrink:0}

.space-cards{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:16px;
    margin-bottom:20px;
}

/* Card — icon + text, no photo */
.space-card{
    --card-accent:#0092c8;
    background:var(--white);
    border:1.5px solid var(--border);
    border-radius:14px;
    padding:28px 22px 24px;
    box-shadow:0 2px 12px rgba(0,55,96,.07);
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
    transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
    position:relative;
    overflow:hidden;
}
/* top accent bar */
.space-card::before{
    content:'';
    position:absolute;
    top:0;left:0;right:0;
    height:4px;
    background:var(--card-accent);
    transform:scaleX(0);
    transform-origin:left;
    transition:transform .35s cubic-bezier(.4,0,.2,1);
}
.space-card:hover::before{transform:scaleX(1)}
.space-card:hover{
    transform:translateY(-5px);
    box-shadow:0 12px 32px rgba(0,55,96,.13);
    border-color:var(--card-accent);
}
.space-card:nth-child(1){--card-accent:#0092c8}
.space-card:nth-child(2){--card-accent:#1a8a5a}
.space-card:nth-child(3){--card-accent:#9b4dc8}

/* large icon circle */
.sc-icon{
    width:54px;height:54px;border-radius:14px;
    background:color-mix(in srgb, var(--card-accent) 10%, #fff);
    display:flex;align-items:center;justify-content:center;
    font-size:22px;
    color:var(--card-accent);
    flex-shrink:0;
    transition:background .3s ease, transform .3s ease;
}
.space-card:hover .sc-icon{
    background:var(--card-accent);
    color:#fff;
    transform:scale(1.08);
}
/* icon fallback for older browsers */
@supports not (color:color-mix(in srgb,red 10%,#fff)){
    .sc-icon{background:var(--blue-pale)}
}

/* FOR HIRE pill */
.sc-label{
    display:inline-block;
    background:color-mix(in srgb, var(--card-accent) 12%, #fff);
    color:var(--card-accent);
    font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
    padding:3px 10px;border-radius:50px;
    border:1px solid color-mix(in srgb, var(--card-accent) 25%, #fff);
}
@supports not (color:color-mix(in srgb,red 12%,#fff)){
    .sc-label{background:var(--blue-pale);color:var(--blue);border-color:#d1e9f5}
}

.sc-body{display:flex;flex-direction:column;gap:10px;width:100%}
.sc-title{
    font-size:15px;font-weight:700;
    color:#003760;
    line-height:1.3;
}
.sc-chips{display:flex;flex-wrap:wrap;gap:5px}
.chip{
    font-size:11px;font-weight:600;padding:3px 10px;border-radius:50px;
    background:var(--blue-pale);color:var(--navy);
    letter-spacing:.15px;border:1px solid #d1e9f5;
    transition:background .22s ease, color .22s ease, border-color .22s ease;
}
.space-card:hover .chip{
    background:color-mix(in srgb, var(--card-accent) 12%, #fff);
    color:var(--card-accent);
    border-color:color-mix(in srgb, var(--card-accent) 30%, #fff);
}
@supports not (color:color-mix(in srgb,red 12%,#fff)){
    .space-card:hover .chip{background:var(--blue-pale);color:var(--blue)}
}

@media (max-width:700px){
    .space-cards{grid-template-columns:1fr;gap:12px}
}
.scroll-hint{display:none}

/* ── Photo gallery strip ── */
.gallery-section{margin-bottom:40px}
.gallery-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.gallery-item{position:relative;border-radius:var(--radius);overflow:hidden;cursor:zoom-in;box-shadow:var(--shadow)}
.gallery-item img{width:100%;height:230px;object-fit:cover;display:block;transition:transform .45s cubic-bezier(.25,.46,.45,.94)}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item::after, .reception-block::after{
    content:'\f065';font-family:'FontAwesome';font-weight:200;
    position:absolute;top:50%;left:50%;
    transform:translate(-50%,-50%) scale(0);
    color:#fff;font-size:20px;
    background:rgba(0,55,96,.55);
    width:44px;height:44px;border-radius:50%;line-height:44px;text-align:center;
    transition:transform .3s cubic-bezier(.34,1.56,.64,1), opacity .3s ease;
    opacity:0;pointer-events:none;
}
.gallery-item:hover::after, .reception-block:hover::after{transform:translate(-50%,-50%) scale(1);opacity:1}
.gallery-caption{
    position:absolute;bottom:0;left:0;right:0;
    background:linear-gradient(transparent,rgba(0,25,50,.75));
    color:#fff;padding:18px 10px 8px;font-size:11px;font-weight:600;
}
@media (max-width:540px){.gallery-strip{grid-template-columns:1fr 1fr}}

/* ── Reception block ── */
.reception-block{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);cursor:zoom-in;transition:box-shadow .3s ease}
.reception-block:hover{box-shadow:var(--shadow-md)}
.reception-block img{width:100%;display:block;transition:transform .45s ease}
.reception-block:hover img{transform:scale(1.02)}

/* ── Section headings — aligned with results.css ── */
.section-heading{
    display:flex;align-items:center;gap:10px;
    font-size:clamp(1.15rem,2vw,1.25rem);font-weight:800;
    letter-spacing:-.02em;color:#003760;
    margin-bottom:14px;padding-bottom:10px;
    border-bottom:2px solid var(--blue-pale);position:relative;
    line-height:1.2;
}
.section-heading::after{
    content:'';position:absolute;bottom:-2px;left:0;
    height:2px;width:60px;background:var(--blue);
}
.section-heading i{
    width:32px;height:32px;background:var(--blue-pale);color:var(--blue);
    border-radius:8px;display:flex;align-items:center;justify-content:center;
    font-size:14px;flex-shrink:0;
    transition:background .25s ease, color .25s ease, transform .25s ease;
}
.section-heading.underlined i{background:var(--blue);color:#fff;transform:rotate(-6deg) scale(1.08)}

/* ── Contact line — static, no animation ── */
.contact-line{
    display:flex;flex-wrap:wrap;gap:10px 20px;align-items:center;
    background:var(--blue-pale);border-left:4px solid var(--blue);
    border-radius:0 var(--radius) var(--radius) 0;
    padding:14px 20px;margin-top:20px;font-size:1rem;
    color:#2C3E50;
}
.contact-line strong{color:#003760;font-weight:600}
.contact-line a{color:var(--blue);font-weight:600}
.contact-line a:hover{text-decoration:underline}

/* ── Reveal animation ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease, transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── SIDEBAR ── */
.sidebar{display:flex;flex-direction:column;gap:14px}
.sb-banner{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .3s ease, box-shadow .3s ease;display:block;position:relative}
.sb-banner:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.sb-banner img{width:100%;display:block;transition:transform .4s ease}
.sb-banner:hover img{transform:scale(1.03)}
.sb-banner::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.18) 50%,transparent 60%);transform:translateX(-100%);transition:transform .5s ease;pointer-events:none}
.sb-banner:hover::after{transform:translateX(100%)}
.sb-menu{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.sb-menu-title{background:var(--navy);color:var(--white);font-size:11px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;padding:9px 14px}
.sb-menu a{display:flex;align-items:center;gap:10px;padding:10px 14px;color:var(--text);font-size:13px;font-weight:500;border-bottom:1px solid var(--border);transition:var(--trans)}
.sb-menu a:last-child{border-bottom:none}
.sb-menu a:hover{background:var(--blue-pale);color:var(--blue);padding-left:20px}
.sb-menu a i{color:var(--blue);font-size:12px;width:16px;text-align:center}
.sb-quote{background:var(--navy);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.sb-quote .quote-mark{color:rgba(255,255,255,.22);font-size:32px;line-height:1;margin-bottom:6px}
.sb-quote p{color:rgba(255,255,255,.88);font-size:12.5px;line-height:1.6;font-style:italic;margin-bottom:10px}
.sb-quote footer{color:#7dd4f8;font-size:11.5px;font-weight:600}

/* ── Footer ── */
footer.site-footer{background:var(--navy);margin-top:48px}
.footer-inner{max-width:1280px;margin:auto;padding:44px 30px 28px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
.footer-brand img{width:120px;margin-bottom:10px}
.footer-brand p{font-size:12px;color:rgba(255,255,255,.52);line-height:1.7;margin-bottom:14px}
.footer-socials{display:flex;gap:8px}
.soc{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.72);font-size:13px;transition:var(--trans)}
.soc:hover{background:var(--blue);color:#fff}
.footer-col h5{color:#fff;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.footer-col ul li a{font-size:12px;color:rgba(255,255,255,.52);transition:var(--trans)}
.footer-col ul li a:hover{color:#7dd4f8;padding-left:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:16px 30px;max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:rgba(255,255,255,.38)}
.footer-bottom a{color:#7dd4f8}

/* ── Float buttons ── */
.float-wa{position:fixed;bottom:22px;right:22px;width:52px;height:52px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(37,211,102,.4);z-index:9999;transition:var(--trans)}
.float-wa:hover{transform:scale(1.1)}
.float-wa i{color:#fff;font-size:22px}
.scroll-top{position:fixed;bottom:84px;right:22px;width:40px;height:40px;border-radius:50%;background:var(--blue);color:#fff;border:none;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);z-index:9998;opacity:0;pointer-events:none;transition:var(--trans)}
.scroll-top.visible{opacity:1;pointer-events:all}
.scroll-top:hover{background:var(--navy)}

/* ── Lightbox ── */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:99999;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;backdrop-filter:blur(4px)}
.lightbox.open{opacity:1;pointer-events:all}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:var(--radius);object-fit:contain;box-shadow:0 20px 80px rgba(0,0,0,.6);transition:opacity .22s ease, transform .35s cubic-bezier(.34,1.56,.64,1);transform:scale(.92);z-index: 1111;}
.lightbox.open img{transform:scale(1)}
.lb-close{position:absolute;top:16px;right:20px;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:22px;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease}
.lb-close:hover{background:rgba(255,255,255,.25)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.30);border:none;color:#fff;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;transition:background .2s ease;z-index: 99999;}
.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-nav:focus{outline: unset;}
.lb-prev{left:18px}
.lb-next{right:18px}
.lb-counter{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:12px;letter-spacing:.5px}

/* ── Responsive ── */
@media(max-width:900px){
    .page-body{grid-template-columns:1fr}
    .sidebar{display:grid;grid-template-columns:1fr 1fr}
    .sb-quote{grid-column:1/-1}
}
@media(max-width:768px){
    .header-wrap{padding:10px 16px}
    .logo-text{display:none}
    .nav-wrap{padding:0 8px}
    .breadcrumb{padding:8px 16px}
    .page-body{padding:0 16px;margin:20px auto;gap:20px}
    .intro-card{padding:18px}
    .footer-inner{grid-template-columns:1fr 1fr;gap:20px;padding:30px 16px 18px}
    .footer-bottom{flex-direction:column;gap:8px;text-align:center;padding:14px}
    .sidebar{grid-template-columns:1fr}
}
@media(max-width:480px){
    .header-cta .btn-outline{display:none}
    .page-title-bar{padding:22px 16px}
    .lb-prev{left:8px}
    .lb-next{right:8px}
    .gallery-strip{grid-template-columns:1fr 1fr}
}