/* GulfVestor Properties — premium design system */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=Inter:wght@400;500;600;700&display=swap');

:root{
  --blue:#1786c9; --blue-d:#1166a3; --navy:#0e2c47; --navy-2:#143a5c;
  --ink:#1f2a37; --muted:#5e6b7a; --line:#e6edf3; --bg:#f6f9fc; --gold:#c8941f;
  --shadow:0 10px 30px rgba(14,44,71,.08); --shadow-lg:0 24px 60px rgba(14,44,71,.16);
  --radius:16px; --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:#fff;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--blue-d);text-decoration:none}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,serif;color:var(--navy);line-height:1.12;margin:0 0 .4em;font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2.1rem,4.6vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.5rem)}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:'Inter';font-weight:700;letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;color:var(--blue);margin-bottom:.6rem}
.lead{font-size:1.12rem;color:var(--muted)}
.center{text-align:center}
.muted{color:var(--muted)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:'Inter';font-weight:600;font-size:.98rem;padding:13px 26px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 8px 20px rgba(23,134,201,.32)}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-2px);box-shadow:0 12px 26px rgba(23,134,201,.4)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-outline{background:#fff;color:var(--navy);border-color:var(--line)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue-d);transform:translateY(-2px)}

/* header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:22px;height:80px}
.nav .logo img{height:44px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);font-weight:500;font-size:.96rem;position:relative;padding:6px 1px;white-space:nowrap;transition:color .16s}
.nav-links a:hover,.nav-links a.active{color:var(--blue-d)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--blue);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:16px}
.nav-phone{display:inline-flex;align-items:center;gap:7px;font-weight:700;color:var(--navy);font-size:1rem;white-space:nowrap;transition:color .16s}
.nav-phone svg{width:16px;height:16px;fill:none;stroke:var(--blue-d);stroke-width:2}
.nav-phone:hover{color:var(--blue-d)}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px}
.burger span{display:block;width:26px;height:2.5px;background:var(--navy);margin:5px 0;border-radius:2px;transition:.2s}

/* hero */
.hero{position:relative;color:#fff;min-height:660px;display:flex;align-items:center;background:#0b2238;overflow:hidden}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-video{z-index:0;opacity:0;transition:opacity 1.4s ease;pointer-events:none}
.hero-video.playing{opacity:1}
.hero::before{content:"";position:absolute;inset:0;z-index:1;background:
  linear-gradient(95deg,rgba(6,20,36,.97) 0%,rgba(8,26,46,.92) 32%,rgba(10,34,58,.66) 64%,rgba(12,40,66,.38) 100%),
  linear-gradient(to top,rgba(5,16,30,.6) 0%,rgba(5,16,30,0) 50%)}
.hero .wrap{position:relative;z-index:2;padding-top:84px;padding-bottom:84px}
.hero-inner{max-width:660px}
.hero h1{color:#fff;text-shadow:0 2px 22px rgba(2,12,24,.55)}
.hero p{font-size:1.18rem;color:#eef4fa;max-width:560px;text-shadow:0 1px 12px rgba(2,12,24,.5)}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px}
.hero-trust{display:flex;gap:30px;margin-top:40px;flex-wrap:wrap}
.hero-trust div{font-size:.9rem;color:#cfe0ee}
.hero-trust strong{display:block;font-family:'Fraunces';font-size:1.7rem;color:#fff;font-weight:600;text-shadow:0 1px 10px rgba(2,12,24,.5)}
.hero .eyebrow{text-shadow:0 1px 10px rgba(2,12,24,.6)}
.hero-trust div{text-shadow:0 1px 8px rgba(2,12,24,.55)}

/* sections */
section{padding:84px 0}
.section-head{max-width:660px;margin:0 auto 52px;text-align:center}
.bg-soft{background:var(--bg)}
.bg-navy{background:var(--navy);color:#fff}
.bg-navy h2,.bg-navy h3{color:#fff}
.bg-navy .lead{color:#bcd0e2}

/* service cards */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px 28px;transition:.2s;box-shadow:var(--shadow)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:#d3e3f0}
.card .ic{width:54px;height:54px;border-radius:14px;background:linear-gradient(135deg,#1f93d6,#1166a3);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ic svg{width:26px;height:26px;stroke:#fff;fill:none;stroke-width:1.8}
.card h3{margin-bottom:.45rem}
.card p{color:var(--muted);font-size:.97rem;margin-bottom:.8rem}
.card a.more{font-weight:600;font-size:.92rem;display:inline-flex;align-items:center;gap:5px}
.card a.more::after{content:"→";transition:.2s}
.card:hover a.more::after{transform:translateX(4px)}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split img{border-radius:var(--radius);box-shadow:var(--shadow-lg);width:100%;height:100%;max-height:460px;object-fit:cover}
.split.rev .txt{order:2}

/* check list */
.checks{list-style:none;padding:0;margin:18px 0 0;display:grid;gap:12px}
.checks li{display:flex;gap:12px;align-items:flex-start;font-size:1rem}
.checks svg{flex:0 0 auto;width:22px;height:22px;margin-top:3px}

/* why-choose pills */
.pills{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px}
.pill{background:#fff;border-radius:var(--radius);padding:30px 26px;text-align:center;box-shadow:var(--shadow)}
.pill .ic{width:60px;height:60px;border-radius:50%;background:#eaf5fd;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.pill .ic svg{width:28px;height:28px;stroke:var(--blue-d);fill:none;stroke-width:1.8}

/* hours + cta */
.hours{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.hours th{background:var(--navy);color:#fff;text-align:left;padding:14px 22px;font-family:'Inter';font-weight:600;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase}
.hours td{padding:13px 22px;border-bottom:1px solid var(--line);font-size:.97rem}
.hours tr:last-child td{border-bottom:0}
.hours td:last-child{text-align:right;color:var(--muted)}

.cta-band{background:linear-gradient(120deg,var(--navy),var(--navy-2));border-radius:24px;padding:56px;text-align:center;color:#fff;box-shadow:var(--shadow-lg)}
.cta-band h2{color:#fff}
.cta-band p{color:#bcd0e2;max-width:540px;margin:0 auto 24px}

/* forms */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow);max-width:580px;margin:0 auto}
label{display:block;font-size:.86rem;font-weight:600;margin:16px 0 6px;color:var(--ink)}
input[type=text],input[type=tel],input[type=email],textarea,select{width:100%;padding:12px 14px;border:1px solid #cdd9e3;border-radius:10px;font-size:1rem;font-family:'Inter';color:var(--ink)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(23,134,201,.15)}
textarea{min-height:120px;resize:vertical}
.consent{display:flex;gap:12px;align-items:flex-start;margin:20px 0 4px;padding:16px;background:var(--bg);border:1px solid var(--line);border-radius:12px}
.consent input{margin-top:3px;width:18px;height:18px;flex:0 0 auto}
.consent label{font-weight:400;font-size:.8rem;color:var(--ink);margin:0;line-height:1.55}
.form-card button{margin-top:20px;width:100%;justify-content:center}
.ok-msg{display:none;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;padding:15px;border-radius:12px;margin-bottom:18px}
.fine{font-size:.78rem;color:var(--muted);margin-top:14px;text-align:center}

/* page hero (inner) */
.page-hero{background:linear-gradient(120deg,var(--navy),#16456c);color:#fff;padding:88px 0 76px;text-align:center}
.page-hero h1{color:#fff}
.page-hero p{color:#bcd0e2;max-width:620px;margin:0 auto}
.crumbs{font-size:.85rem;color:#9fc0db;margin-bottom:14px}
.crumbs a{color:#cfe0ee}

/* contact info */
.info-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:20px}
.info-row .ic{width:46px;height:46px;border-radius:12px;background:#eaf5fd;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.info-row .ic svg{width:22px;height:22px;stroke:var(--blue-d);fill:none;stroke-width:1.8}
.info-row b{display:block;color:var(--navy)}

/* footer */
footer.site{background:#0a2138;color:#aebfce;padding:64px 0 28px;font-size:.92rem}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
footer.site img.flogo{height:42px;margin-bottom:16px;filter:brightness(0) invert(1);opacity:.95}
footer.site h4{color:#fff;font-family:'Inter';font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;margin-bottom:16px}
footer.site ul{list-style:none;padding:0;margin:0;display:grid;gap:10px}
footer.site a{color:#aebfce}
footer.site a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:12px;font-size:.85rem;color:#7d91a5}
.social{display:flex;gap:12px}
.social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center}
.social a:hover{background:var(--blue)}
.social svg{width:18px;height:18px;fill:#fff}

/* legal pages */
.legal{max-width:780px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:44px 48px;box-shadow:var(--shadow)}
.legal h2{font-size:1.25rem;margin:30px 0 8px}
.legal h2:first-of-type{margin-top:0}
.legal p,.legal li{color:var(--ink);font-size:.97rem}
.legal .hl{background:var(--bg);border:1px solid var(--line);border-left:3px solid var(--blue);padding:14px 16px;border-radius:8px}
.legal .updated{color:var(--muted);font-style:italic;font-size:.9rem}

/* responsive */
@media(max-width:992px){
  .grid-3,.pills{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:30px}
  .split.rev .txt{order:0}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .nav-links,.nav-phone{display:none}
  .burger{display:block}
  .nav-links.open{display:flex;position:absolute;top:80px;left:0;right:0;flex-direction:column;background:#fff;padding:20px 24px;gap:16px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  section{padding:60px 0}
  .cta-band{padding:40px 24px}
}
@media(max-width:560px){
  .grid-3,.grid-2,.pills,.foot-grid{grid-template-columns:1fr}
  .hero{min-height:560px}
}

/* ===== round 2 premium additions ===== */
/* scroll reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* stats band */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stats .stat strong{display:block;font-family:'Fraunces';font-size:clamp(2rem,4vw,2.9rem);color:#fff;font-weight:600;line-height:1}
.stats .stat span{color:#bcd0e2;font-size:.92rem;margin-top:6px;display:block}

/* process steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;counter-reset:step}
.step{position:relative;padding:30px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.step .num{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#1f93d6,#1166a3);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Fraunces';font-weight:600;font-size:1.2rem;margin-bottom:16px}
.step h3{font-size:1.15rem}

/* service area */
.areas{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:10px}
.areas span{background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 20px;font-size:.92rem;font-weight:500;color:var(--navy);box-shadow:var(--shadow)}

/* testimonials */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.quote{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow)}
.quote .stars{color:#f0a500;font-size:1.05rem;letter-spacing:2px;margin-bottom:12px}
.quote p{font-size:.98rem;color:var(--ink)}
.quote .who{font-weight:600;color:var(--navy);font-size:.92rem;margin-top:14px}
.quote .who span{display:block;color:var(--muted);font-weight:400;font-size:.85rem}

/* faq */
.faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:4px 22px;box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:600;color:var(--navy);padding:16px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;font-size:1.02rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--blue);font-weight:400;line-height:1}
.faq details[open] summary::after{content:"\2013"}
.faq details p{color:var(--muted);margin:0 0 16px;font-size:.97rem}

/* map */
.map-embed{border:0;width:100%;height:340px;border-radius:var(--radius);box-shadow:var(--shadow);margin-top:30px}

@media(max-width:900px){.stats{grid-template-columns:1fr 1fr}.steps,.quotes{grid-template-columns:1fr}}
@media(max-width:560px){.stats{grid-template-columns:1fr 1fr}}
