/* ==========================================================================
   Kashmir View— Landscape & Pools, Dubai
   Shared stylesheet · Pool Blue theme · mobile-first, responsive
   ========================================================================== */

:root{
  --accent:#2E7DA6;        /* pool blue */
  --accent-dark:#16384A;   /* deep slate blue */
  --accent-soft:#F4F8FA;   /* very light blue wash */
  --accent-tint:#E2EBEF;   /* light blue border */
  --gold:#C9A86A;          /* subtle warm accent */
  --wa:#25D366;            /* whatsapp green */
  --wa-dark:#1da851;
  --ink:#1c2b30;           /* main text */
  --muted:#5a6b70;         /* secondary text */
  --line:#e8edef;          /* hairlines */
  --white:#ffffff;
  --radius:12px;
  --radius-lg:18px;
  --shadow:0 6px 24px rgba(22,56,74,.08);
  --shadow-lg:0 14px 40px rgba(22,56,74,.14);
  --maxw:1200px;
  --font-display:Georgia,'Times New Roman',serif;
  --font-body:'Segoe UI',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.18;color:var(--accent-dark)}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.center{text-align:center}

/* Buttons ---------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;justify-content:center;
  padding:13px 26px;border-radius:8px;font-weight:600;font-size:15px;
  font-family:var(--font-body);cursor:pointer;border:none;transition:.2s;
  line-height:1;
}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-dark)}
.btn-ghost{background:rgba(255,255,255,.92);color:var(--accent-dark)}
.btn-ghost:hover{background:#fff}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{background:var(--wa-dark)}
.btn svg{width:18px;height:18px;fill:currentColor}

/* Top bar ---------------------------------------------------------------- */
.topbar{
  background:var(--accent-dark);color:#fff;text-align:center;
  font-size:13.5px;padding:9px 12px;letter-spacing:.3px;
}
.topbar a{color:#fff;font-weight:600;white-space:nowrap}
.topbar a:hover{color:var(--gold)}
.topbar .tb-sep{opacity:.45;margin:0 9px}

/* Header ----------------------------------------------------------------- */
header{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:200}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;max-width:var(--maxw);margin:0 auto;gap:16px}
.brand{display:flex;align-items:center;gap:11px;flex:none}
.brand svg{width:46px;height:46px;flex:none}
.brand-text{line-height:1.02;display:flex;flex-direction:column}
.brand-sub{white-space:nowrap}
.brand-name{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--accent-dark);letter-spacing:.4px}
.brand-name span{color:var(--accent)}
.brand-sub{font-size:9px;letter-spacing:2.2px;color:var(--accent);font-weight:700;text-transform:uppercase}

.menu{display:flex;gap:22px;align-items:center;font-size:15px}
.menu>li{position:relative;list-style:none}
.menu>li>a{color:#33434a;font-weight:500;padding:20px 0;display:inline-flex;align-items:center;gap:5px;transition:color .2s}
.menu>li>a:hover{color:var(--accent)}
.menu .caret{font-size:10px;opacity:.7}

/* Dropdowns */
.dropdown{
  position:absolute;top:100%;left:0;min-width:230px;background:#fff;
  border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-lg);
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);
  transition:.18s;z-index:50;
}
.menu>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:block;padding:9px 14px;border-radius:7px;font-size:14px;color:#3a4a51;font-weight:500}
.dropdown a:hover{background:var(--accent-soft);color:var(--accent)}
.dropdown.tall{max-height:70vh;overflow-y:auto}

.nav-right{display:flex;align-items:center;gap:16px}
.socials{display:flex;gap:13px;align-items:center}
.socials a{color:#4a5a61;display:flex;transition:color .2s}
.socials a:hover{color:var(--accent)}
.socials svg{width:18px;height:18px;fill:currentColor}
.nav-wa{
  display:inline-flex;align-items:center;gap:7px;background:var(--wa);color:#fff;
  padding:9px 16px;border-radius:8px;font-weight:600;font-size:14px;transition:.2s;
}
.nav-wa:hover{background:var(--wa-dark)}
.nav-wa svg{width:17px;height:17px;fill:#fff}

.hamb{display:none;background:none;border:none;cursor:pointer;padding:6px;flex:none}
.hamb span{display:block;width:24px;height:2.4px;background:var(--accent-dark);margin:5px 0;border-radius:2px;transition:.3s}
.hamb.open span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.hamb.open span:nth-child(2){opacity:0}
.hamb.open span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

/* Mobile drawer */
.drawer{
  position:fixed;top:0;right:0;width:300px;max-width:85vw;height:100vh;height:100dvh;
  background:#fff;box-shadow:-10px 0 40px rgba(0,0,0,.15);z-index:300;
  transform:translateX(110%);visibility:hidden;
  transition:transform .3s ease,visibility .3s;
  overflow-y:auto;padding:24px 22px 60px;
}
.drawer.open{transform:translateX(0);visibility:visible}
.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.drawer-close{background:none;border:none;font-size:30px;line-height:1;color:var(--accent-dark);cursor:pointer}
.drawer nav a{display:block;padding:13px 4px;border-bottom:1px solid var(--line);font-size:16px;font-weight:500;color:#33434a}
.drawer nav a:hover{color:var(--accent)}
.drawer .sub{padding-left:16px;font-size:14.5px;color:var(--muted)}
.drawer-label{font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent);font-weight:700;margin:18px 0 4px;padding-left:4px}
.drawer .nav-wa{margin-top:22px;width:100%;justify-content:center;padding:13px}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:250;opacity:0;visibility:hidden;transition:.3s}
.overlay.open{opacity:1;visibility:visible}

/* Hero ------------------------------------------------------------------- */
.hero{position:relative;display:flex;flex-direction:column;overflow:hidden;background:var(--accent-dark)}
.hero-stage{position:relative;height:64vh;min-height:400px;max-height:600px;overflow:hidden;background:#c9d8e0}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.3s ease;transform:scale(1);
  filter:brightness(1.08) saturate(1.06);
}
.hero-slide.active{opacity:1;animation:kenburns 10s ease forwards}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.035)}}
.hero-stage::after{content:"";position:absolute;left:0;right:0;bottom:0;height:110px;background:linear-gradient(rgba(9,32,44,0),rgba(9,32,44,.38));z-index:2}

/* Hero ribbon — single scrolling brand border above the slideshow --------- */
.hero-ribbon{
  position:relative;z-index:5;background:var(--accent-dark);overflow:hidden;
  padding:11px 0;
}
.ribbon-top{border-bottom:1px solid rgba(201,168,106,.45)}
.ribbon-track{display:flex;width:max-content;animation:ribbon-scroll 75s linear infinite}
.hero-ribbon:hover .ribbon-track{animation-play-state:paused}
.ribbon-group{display:flex;align-items:center;flex:none}
.ribbon-group span{
  white-space:nowrap;color:#eaf2f6;font-size:12px;font-weight:600;
  letter-spacing:2.4px;text-transform:uppercase;padding:0 26px;
  font-family:var(--font-body);
}
.ribbon-group i{font-style:normal;color:var(--gold);font-size:12px;flex:none;line-height:1}
@keyframes ribbon-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Hero text panel — headline & buttons below the slideshow ---------------- */
.hero-panel{background:linear-gradient(120deg,#0d2836,#16384A 55%,#1d4a63);padding:48px 22px 52px}
.hero-panel-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr;gap:38px;align-items:center}
.hero-panel h1{color:#fff;font-size:clamp(26px,3.8vw,44px);margin-bottom:14px}
.hero-panel p{color:#d9e6ec;font-size:clamp(15px,1.6vw,18px);max-width:560px;line-height:1.7;margin:0}
.hero-cta{display:flex;flex-direction:column;gap:14px;width:100%;max-width:300px;justify-self:end}
.hero-cta .btn{width:100%;padding:15px 26px}
.btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.55)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:#fff}
.hero-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:9px}
.hero-dots button{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.45);border:none;cursor:pointer;padding:0;transition:.25s}
.hero-dots button.active{background:#fff;width:28px;border-radius:6px}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;background:rgba(255,255,255,.16);backdrop-filter:blur(4px);color:#fff;border:none;width:46px;height:46px;border-radius:50%;font-size:22px;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center}
.hero-arrow:hover{background:rgba(255,255,255,.32)}
.hero-arrow.prev{left:18px}
.hero-arrow.next{right:18px}

/* Section scaffolding ---------------------------------------------------- */
section{position:relative}
.sec{padding:72px 0}
.sec-sm{padding:54px 0}
.eyebrow{color:var(--accent);font-weight:700;letter-spacing:2px;text-transform:uppercase;font-size:12.5px;margin-bottom:10px;display:block;text-align:center}
.sec-title{font-size:clamp(24px,3.2vw,36px);text-align:center;margin-bottom:12px}
.sec-sub{text-align:center;color:var(--muted);max-width:640px;margin:0 auto 46px;font-size:16.5px}

/* Intro band ------------------------------------------------------------- */
.intro{text-align:center;padding:76px 22px 40px}
.intro h2{font-size:clamp(24px,3.4vw,38px);max-width:820px;margin:0 auto 18px}
.intro p{color:var(--muted);max-width:660px;margin:0 auto 26px;font-size:17px}

/* Projects carousel ------------------------------------------------------ */
.pcarousel-wrap{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.pcarousel{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;padding:6px 2px 22px;scrollbar-width:thin}
.pcarousel::-webkit-scrollbar{height:7px}
.pcarousel::-webkit-scrollbar-thumb{background:var(--accent-tint);border-radius:4px}
.pcard{flex:0 0 320px;scroll-snap-align:start;border-radius:var(--radius-lg);overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);transition:.25s}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.pcard-img{height:220px;background-size:cover;background-position:center}
.pcard-body{padding:18px 20px}
.pcard h3{font-size:20px;margin-bottom:4px}
.pcard .loc{color:var(--muted);font-size:13.5px;display:flex;align-items:center;gap:6px}
.pcard .loc svg{width:14px;height:14px;fill:var(--accent)}
.carousel-nav{display:flex;gap:10px;justify-content:center;margin-top:8px}
.carousel-nav button{width:44px;height:44px;border-radius:50%;border:1px solid var(--accent-tint);background:#fff;color:var(--accent);font-size:20px;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center}
.carousel-nav button:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Service rows ----------------------------------------------------------- */
.services{background:var(--accent-soft)}
.srow{
  display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;
  max-width:1080px;margin:0 auto 26px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);
}
.srow-text{padding:36px 40px}
.srow-img{min-height:300px;height:100%;background-size:cover;background-position:center}
.srow:nth-child(even) .srow-text{order:2}
.srow h3{font-size:30px;margin-bottom:18px}
.slist{list-style:none}
.slist li{padding:6px 0 6px 26px;position:relative;color:var(--muted);font-size:15.5px}
.slist li::before{content:"";position:absolute;left:0;top:13px;width:14px;height:8px;border-left:2.4px solid var(--accent);border-bottom:2.4px solid var(--accent);transform:rotate(-45deg)}

/* Why band --------------------------------------------------------------- */
.why{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:34px;align-items:center;padding:76px 22px}
.why h2{font-size:clamp(22px,2.8vw,31px)}
.why-img{height:300px;border-radius:var(--radius-lg);background-size:cover;background-position:center;box-shadow:var(--shadow)}
.why p{color:var(--muted);margin-bottom:14px;font-size:15.5px}

/* How steps -------------------------------------------------------------- */
.how{background:var(--accent-soft)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;max-width:1150px;margin:0 auto;padding:0 22px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.step-img{height:190px;background-size:cover;background-position:center}
.step-body{padding:20px 20px 24px}
.step-num{display:inline-block;font-family:var(--font-display);font-size:14px;color:var(--accent);font-weight:700;border:1.5px solid var(--accent-tint);border-radius:50%;width:32px;height:32px;line-height:29px;text-align:center;margin-bottom:12px}
.step h3{font-size:18px;margin-bottom:12px}
.step .slist li{font-size:13.5px;padding-left:22px}
.step .slist li::before{top:11px}

/* Feature grid (icons) --------------------------------------------------- */
.fgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px 30px;max-width:1080px;margin:0 auto;padding:0 22px}
.feature{text-align:center}
.feature-ic{width:60px;height:60px;margin:0 auto 16px;background:var(--accent-soft);border-radius:16px;display:flex;align-items:center;justify-content:center}
.feature-ic svg{width:30px;height:30px;fill:none;stroke:var(--accent);stroke-width:1.7}
.feature h3{font-size:18.5px;margin-bottom:8px;color:var(--accent-dark)}
.feature p{color:var(--muted);font-size:14.5px}

/* About band ------------------------------------------------------------- */
.about{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1.15fr;gap:44px;align-items:center;padding:76px 22px}
.about-img{height:360px;border-radius:var(--radius-lg);background-size:cover;background-position:center;box-shadow:var(--shadow-lg)}
.about h2{font-size:clamp(23px,3vw,33px);margin-bottom:18px}
.about p{color:var(--muted);margin-bottom:14px;font-size:15.5px}
.about .sister{background:var(--accent-soft);border-left:3px solid var(--accent);padding:14px 18px;border-radius:0 8px 8px 0;margin-top:8px;font-size:14.5px;color:var(--ink)}
.about .sister strong{color:var(--accent-dark)}

/* CTA strip -------------------------------------------------------------- */
.cta{background:linear-gradient(120deg,var(--accent-dark),var(--accent));color:#fff;text-align:center;padding:60px 22px}
.cta h2{color:#fff;font-size:clamp(23px,3vw,32px);margin-bottom:12px}
.cta p{opacity:.92;margin-bottom:24px;font-size:16.5px}

/* Page hero (sub pages) -------------------------------------------------- */
.phero{position:relative;height:360px;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center;background:var(--accent-dark)}
.phero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(rgba(9,32,44,.55),rgba(9,32,44,.62));z-index:1}
.phero-inner{position:relative;z-index:2;padding:0 22px}
.phero h1{color:#fff;font-size:clamp(26px,4vw,44px);text-shadow:0 2px 20px rgba(0,0,0,.4)}
.phero p{color:#eef4f6;margin-top:12px;font-size:clamp(15px,1.8vw,19px)}
.crumb{color:#cfe0e8;font-size:13.5px;margin-top:14px}
.crumb a:hover{color:#fff;text-decoration:underline}

/* Intro split (sub pages) ------------------------------------------------ */
.split{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;padding:70px 22px}
.split-img{height:340px;border-radius:var(--radius-lg);background-size:cover;background-position:center;box-shadow:var(--shadow)}
.split h2{font-size:clamp(22px,3vw,32px);margin-bottom:16px}
.split p{color:var(--muted);margin-bottom:14px;font-size:15.5px}

/* Photo cards (pool page) ------------------------------------------------ */
.pcards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;max-width:1150px;margin:0 auto;padding:0 22px}
.pc{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.pc-img{height:180px;background-size:cover;background-position:center}
.pc-body{padding:18px 18px 22px}
.pc h3{font-size:17px;margin-bottom:8px}
.pc p{color:var(--muted);font-size:14px}

/* Contact ---------------------------------------------------------------- */
.contact-grid{max-width:1000px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;padding:0 22px}
.ccard{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px 26px;text-align:center;box-shadow:var(--shadow);transition:.2s}
.ccard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.ccard-ic{width:58px;height:58px;margin:0 auto 16px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center}
.ccard-ic svg{width:26px;height:26px;fill:var(--accent)}
.ccard h3{font-size:19px;margin-bottom:10px}
.ccard a,.ccard p{color:var(--muted);font-size:15px;display:block;line-height:1.9}
.ccard a:hover{color:var(--accent)}
.contact-wa{text-align:center;margin-top:40px}

/* Footer ----------------------------------------------------------------- */
footer{background:#0f242e;color:#c5cfd4;padding:58px 22px 28px}
.fgrid-foot{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr 1.4fr;gap:44px}
footer h4{color:#fff;font-size:16px;margin-bottom:18px;font-weight:600}
footer p,footer li{font-size:14px;line-height:1.95;color:#b0bcc2}
footer a{color:#b0bcc2}
footer a:hover{color:var(--gold)}
.foot-brand{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.foot-brand svg{width:42px;height:42px}
.foot-brand .brand-name{color:#fff}
.foot-tag{font-size:14.5px;color:#9fabb1;margin-bottom:6px}
.foot-contact li{list-style:none;display:flex;gap:9px;align-items:flex-start;margin-bottom:10px}
.foot-contact svg{width:16px;height:16px;fill:var(--accent);margin-top:3px;flex:none}
.foot-social{display:flex;gap:14px;margin-top:16px}
.foot-social a{color:#9fabb1}
.foot-social a:hover{color:var(--gold)}
.foot-social svg{width:19px;height:19px;fill:currentColor}
.fareas{font-size:12.8px;line-height:1.95;color:#93a0a6}
.foot-bottom{max-width:var(--maxw);margin:38px auto 0;border-top:1px solid #1e3540;padding-top:20px;text-align:center;font-size:12.5px;color:#7d8b91}

/* Floating WhatsApp ------------------------------------------------------ */
.fab{position:fixed;bottom:22px;right:22px;width:58px;height:58px;background:var(--wa);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 22px rgba(37,211,102,.5);z-index:150;transition:.2s}
.fab:hover{background:var(--wa-dark);transform:scale(1.06)}
.fab svg{width:32px;height:32px;fill:#fff}
.fab::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--wa);animation:pulse 2.2s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}

/* Reveal on scroll ------------------------------------------------------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .45s ease,transform .45s ease}
.reveal.in{opacity:1;transform:none}

/* ========================================================================
   RESPONSIVE
   ======================================================================== */
@media(max-width:980px){
  .menu,.nav-right .socials{display:none}
  .nav-right .nav-wa{display:none}
  .hamb{display:block}
  .hero-panel-inner{grid-template-columns:1fr;gap:26px}
  .hero-cta{justify-self:start;flex-direction:row;flex-wrap:wrap;max-width:none}
  .hero-cta .btn{width:auto;flex:1 1 200px}
  .srow{grid-template-columns:1fr}
  .srow:nth-child(even) .srow-text{order:0}
  .srow-img{min-height:230px}
  .why{grid-template-columns:1fr;gap:22px}
  .steps{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr 1fr;gap:34px 26px}
  .about{grid-template-columns:1fr;gap:26px}
  .split{grid-template-columns:1fr;gap:26px}
  .pcards{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr;max-width:440px}
  .fgrid-foot{grid-template-columns:1fr 1fr;gap:34px}
  .fgrid-foot .foot-areas{grid-column:1/-1}
}
@media(max-width:560px){
  .sec{padding:52px 0}
  .hero-stage{height:46vh;min-height:300px}
  .hero-panel{padding:36px 22px 40px}
  .ribbon-group span{font-size:10.5px;letter-spacing:1.8px;padding:0 16px}
  .hero-ribbon{padding:9px 0}
  .steps{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .pcards{grid-template-columns:1fr}
  .fgrid-foot{grid-template-columns:1fr}
  .srow-text{padding:28px 24px}
  .hero-arrow{width:40px;height:40px}
  .pcard{flex-basis:280px}
}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .hero-slide.active{animation:none}
  .reveal{opacity:1;transform:none}
}
