/* === الساحل الشمالي — Soft Teal Theme, Mobile-First === */
:root{
  --bg:#0f2230;
  --bg-2:#152c3d;
  --panel:#1a3447;
  --panel-2:#21405a;
  --border:#2c5774;
  --text:#eaf6f6;
  --muted:#a8c0d0;
  --brand:#3ee6d6;
  --brand-2:#7fefe0;
  --accent:#3ee6d6;
  --grad:linear-gradient(135deg,#3ee6d6 0%,#7fefe0 100%);
  --grad-soft:linear-gradient(135deg,rgba(62,230,214,.18),rgba(127,239,224,.12));
  --shadow-sm:0 4px 14px rgba(0,0,0,.25);
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:16px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Tahoma,Arial,"Helvetica Neue",sans-serif;
  background:var(--bg);
  color:var(--text);
  direction:rtl;
  overflow-x:hidden;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  font-size:16px;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}

/* Scroll progress */
.scroll-progress{
  position:fixed;top:0;right:0;height:3px;width:0;
  background:var(--grad);z-index:1000;transition:width .1s;
}

/* Nav (mobile-first) */
.nav{
  position:sticky;top:0;z-index:100;
  background:rgba(13,27,42,.85);
  backdrop-filter:saturate(160%) blur(8px);
  -webkit-backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--border);
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:12px 16px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;min-width:0}
.brand .logo{
  width:38px;height:38px;border-radius:10px;flex-shrink:0;
  background:var(--grad);display:grid;place-items:center;color:#fff;
  box-shadow:var(--shadow-sm);font-size:20px;
}
.brand .name{font-size:14px;line-height:1.2;min-width:0}
.brand .name small{display:block;color:var(--muted);font-weight:500;font-size:11px}
.nav-links{
  display:none;position:absolute;top:100%;right:0;left:0;
  flex-direction:column;background:var(--panel);padding:10px;gap:4px;
  border-bottom:1px solid var(--border);box-shadow:var(--shadow);
  max-height:75vh;overflow-y:auto;
}
.nav-links.open{display:flex}
.nav-links a{
  padding:12px 14px;border-radius:10px;font-size:15px;font-weight:600;color:var(--text);
}
.nav-links a:hover,.nav-links a.active{background:var(--panel-2);color:var(--brand)}
.nav-cta{display:flex;gap:8px;align-items:center;flex-shrink:0}
.nav-toggle{
  display:grid;place-items:center;background:var(--panel-2);border:1px solid var(--border);
  color:var(--text);width:40px;height:40px;border-radius:10px;font-size:18px;cursor:pointer;
}
.nav-cta .btn-ghost{display:none}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;border-radius:12px;font-weight:700;font-size:15px;
  cursor:pointer;border:none;transition:transform .2s,box-shadow .2s;font-family:inherit;
}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 6px 18px rgba(20,224,208,.35)}
.btn-primary:active{transform:scale(.97)}
.btn-ghost{background:var(--panel);color:var(--text);border:1px solid var(--border)}
.btn-wa{background:#25d366;color:#fff;box-shadow:0 6px 18px rgba(37,211,102,.3)}
.btn-call{background:#ff5e62;color:#fff}
.btn-sm{padding:9px 14px;font-size:13px;border-radius:10px}

/* Layout */
.section{padding:56px 16px;position:relative}
.container{max-width:1280px;margin:0 auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--grad-soft);color:var(--brand);
  font-size:12px;font-weight:700;margin-bottom:14px;
}
h1,h2,h3{font-weight:800;line-height:1.25;color:var(--text)}
h1{font-size:30px;letter-spacing:-.3px}
h2{font-size:24px;margin-bottom:12px}
h3{font-size:18px;margin-bottom:8px}
.lead{font-size:16px;color:var(--muted);max-width:780px}
.gradient-text{
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-head{text-align:center;margin-bottom:32px}
.section-head .lead{margin:0 auto}

/* Hero */
.hero{
  padding:32px 16px 40px;max-width:1280px;margin:0 auto;
  display:flex;flex-direction:column;gap:28px;
}
.hero-text{text-align:center}
.hero-text .lead{margin:16px auto 22px}
.hero-cta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:22px}
.hero-cta .btn{flex:1 1 160px;min-width:0}
.trust-row{display:flex;flex-wrap:wrap;gap:14px;color:var(--muted);font-size:13px;justify-content:center}
.trust-row div{display:flex;align-items:center;gap:6px}
.trust-row span.ic{color:var(--brand);font-weight:700}

.hero-visual{position:relative}
.hero-card{
  position:relative;border-radius:20px;overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow);
  background:var(--panel);
}
.hero-card img{width:100%;height:auto;display:block;aspect-ratio:16/10;object-fit:cover}
.floating-badge{
  position:absolute;background:var(--panel);
  border:1px solid var(--border);border-radius:12px;padding:10px 12px;
  display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;
  box-shadow:var(--shadow);z-index:2;
}
.floating-badge .dot{width:8px;height:8px;border-radius:50%;background:#22c55e}
.fb-1{top:14px;right:14px}
.fb-2{bottom:14px;left:14px;color:var(--brand)}
.fb-3{display:none}

/* Counters */
.stats{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:28px;
}
.stat{
  background:var(--panel);border:1px solid var(--border);border-radius:14px;
  padding:18px 12px;text-align:center;box-shadow:var(--shadow-sm);
}
.stat .num{font-size:26px;font-weight:800;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{color:var(--muted);font-size:12px;margin-top:2px}

/* Grids / Cards */
.grid{display:grid;gap:14px;grid-template-columns:1fr}
.card{
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card .icon{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--grad-soft);color:var(--brand);
  font-size:22px;margin-bottom:14px;
}
.card p{color:var(--muted);font-size:14.5px}

.service-card{padding:0;overflow:hidden}
.service-card .img{aspect-ratio:16/10;overflow:hidden;position:relative;background:var(--panel-2)}
.service-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.service-card:hover .img img{transform:scale(1.04)}
.service-card .body{padding:20px}

/* Showcase */
.showcase{display:flex;flex-direction:column;gap:24px;align-items:stretch}
.showcase-img img{border-radius:18px;border:1px solid var(--border);box-shadow:var(--shadow);width:100%;aspect-ratio:16/10;object-fit:cover}
.feature-list{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.feature-list li{display:flex;gap:10px;align-items:flex-start;list-style:none;color:var(--text);font-size:15px}
.feature-list .chk{
  flex:0 0 24px;height:24px;border-radius:8px;background:var(--grad);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;
}

/* Timeline */
.timeline{display:grid;grid-template-columns:1fr;gap:18px;margin-top:24px}
.tl-item{text-align:center;padding:18px;background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm)}
.tl-item .step{
  width:56px;height:56px;margin:0 auto 12px;border-radius:50%;
  background:var(--grad);display:grid;place-items:center;
  font-weight:800;font-size:20px;color:#fff;box-shadow:var(--shadow-sm);
}

/* CTA banner */
.cta-banner{
  border-radius:20px;padding:36px 22px;text-align:center;
  background:var(--grad-soft);
  border:1px solid var(--border);
}

/* Areas */
.areas{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.area{
  padding:14px;border-radius:12px;background:var(--panel);border:1px solid var(--border);
  display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;
}
.area .pin{
  width:34px;height:34px;border-radius:9px;background:var(--grad-soft);flex-shrink:0;
  display:grid;place-items:center;color:var(--brand);font-size:16px;
}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.gallery .g{
  border-radius:14px;overflow:hidden;border:1px solid var(--border);position:relative;
  aspect-ratio:1/1;background:var(--panel-2);
}
.gallery .g.tall,.gallery .g.wide{grid-row:auto;grid-column:auto;aspect-ratio:1/1}
.gallery img{width:100%;height:100%;object-fit:cover}

/* Reviews */
.reviews{display:grid;grid-template-columns:1fr;gap:14px}
.review{
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow-sm);
}
.stars{color:#ffb400;margin-bottom:8px;letter-spacing:2px}
.review-text{color:var(--text);margin-bottom:14px;font-size:14.5px}
.reviewer{display:flex;align-items:center;gap:10px}
.reviewer .av{
  width:42px;height:42px;border-radius:50%;background:var(--grad);
  display:grid;place-items:center;font-weight:800;color:#fff;
}
.reviewer .meta b{display:block;font-size:14px}
.reviewer .meta small{color:var(--muted);font-size:12px}

/* FAQ */
.faq{max-width:880px;margin:0 auto}
.faq details{
  background:var(--panel);border:1px solid var(--border);border-radius:12px;
  margin-bottom:10px;overflow:hidden;
}
.faq summary{
  list-style:none;padding:16px 18px;font-weight:700;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:15px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brand);font-size:22px;transition:.2s;font-weight:300}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 18px 18px;color:var(--muted);font-size:14.5px}

/* Footer */
footer{
  background:var(--panel);border-top:1px solid var(--border);padding:40px 16px 20px;margin-top:40px;
}
.foot-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:28px}
.foot-grid h4{margin-bottom:12px;font-size:15px;color:var(--text)}
.foot-grid a,.foot-grid p{color:var(--muted);font-size:14px;display:block;padding:3px 0}
.foot-grid a:hover{color:var(--brand)}
.socials{display:flex;gap:8px;margin-top:12px}
.socials a{
  width:38px;height:38px;border-radius:10px;background:var(--panel-2);
  display:grid;place-items:center;font-size:16px;
}
.foot-bot{max-width:1280px;margin:28px auto 0;padding-top:18px;border-top:1px solid var(--border);text-align:center;color:var(--muted);font-size:12.5px}

/* Floating call/whatsapp */
.fab{
  position:fixed;z-index:999;width:54px;height:54px;border-radius:50%;
  display:grid;place-items:center;color:#fff;font-size:24px;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
.fab-wa{right:14px;bottom:78px;background:#25d366}
.fab-call{left:14px;bottom:78px;background:#ff5e62}
.fab-top{
  position:fixed;left:14px;bottom:142px;z-index:999;width:42px;height:42px;border-radius:50%;
  background:var(--panel);border:1px solid var(--border);color:var(--text);
  display:none;place-items:center;font-size:18px;box-shadow:var(--shadow-sm);
}
.fab-top.show{display:grid}

/* Mobile sticky bar */
.mobile-bar{
  display:flex;position:fixed;bottom:0;left:0;right:0;z-index:998;
  background:rgba(10,25,36,.95);backdrop-filter:blur(10px);
  border-top:1px solid var(--border);padding:8px;gap:8px;
}
.mobile-bar a{flex:1;padding:12px;text-align:center;border-radius:10px;font-weight:700;font-size:14px;color:#fff;display:flex;align-items:center;justify-content:center;gap:6px}
.mb-call{background:#ff5e62}
.mb-wa{background:#25d366}
body{padding-bottom:74px}

/* Reveal — soft, no transform on mobile for perf */
.reveal{opacity:0;transition:opacity .5s ease}
.reveal.in{opacity:1}

/* Page hero */
.page-hero{
  padding:48px 16px 28px;text-align:center;position:relative;
  background:var(--grad-soft);
}
.page-hero h1{font-size:28px}
.page-hero .crumbs{color:var(--muted);font-size:13px;margin-top:10px}
.page-hero .crumbs a{color:var(--brand)}

/* Form */
.form-grid{display:grid;grid-template-columns:1fr;gap:12px;max-width:780px;margin:0 auto}
.form-grid .full{grid-column:1/-1}
.input,.textarea{
  width:100%;padding:13px 14px;border-radius:11px;border:1px solid var(--border);
  background:var(--panel);color:var(--text);font-family:inherit;font-size:15px;
}
.input:focus,.textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(20,224,208,.25)}
.textarea{min-height:130px;resize:vertical}

/* ===== Tablet ===== */
@media (min-width:720px){
  .section{padding:72px 24px}
  h1{font-size:42px}
  h2{font-size:32px}
  .nav-inner{padding:14px 24px}
  .brand .name{font-size:16px}
  .brand .name small{font-size:12px}
  .grid{gap:18px}
  .grid-2{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .areas{grid-template-columns:repeat(3,1fr)}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:repeat(4,1fr)}
  .timeline{grid-template-columns:repeat(2,1fr)}
  .reviews{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .page-hero{padding:80px 24px 50px}
  .page-hero h1{font-size:40px}
  .form-grid{grid-template-columns:1fr 1fr}
  .hero{padding:60px 24px;gap:40px}
  .hero-text{text-align:right}
  .hero-cta,.trust-row{justify-content:flex-start}
  .hero-cta .btn{flex:initial}
  .floating-badge{padding:12px 16px;font-size:13px}
  .cta-banner{padding:50px 36px}
}

/* ===== Desktop ===== */
@media (min-width:1024px){
  .section{padding:90px 32px}
  h1{font-size:52px}
  h2{font-size:38px}
  .nav-links{
    display:flex;position:static;flex-direction:row;background:transparent;
    padding:0;box-shadow:none;border:none;max-height:none;overflow:visible;gap:2px;
  }
  .nav-links a{padding:9px 12px;font-size:13.5px}
  .nav-toggle{display:none}
  .nav-cta .btn-ghost{display:inline-flex}
  .grid-3{grid-template-columns:repeat(3,1fr)}
  .grid-4{grid-template-columns:repeat(4,1fr)}
  .areas{grid-template-columns:repeat(4,1fr)}
  .gallery{grid-template-columns:repeat(4,1fr)}
  .gallery .g.tall{grid-row:span 2;aspect-ratio:1/2}
  .gallery .g.wide{grid-column:span 2;aspect-ratio:2/1}
  .timeline{grid-template-columns:repeat(4,1fr)}
  .reviews{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}
  .hero{flex-direction:row;align-items:center;padding:90px 32px}
  .hero-text{flex:1.1}
  .hero-visual{flex:.9}
  .showcase{flex-direction:row;align-items:center;gap:50px}
  .showcase>*{flex:1}
  .mobile-bar{display:none}
  body{padding-bottom:0}
  .fab-wa{bottom:24px;right:24px}
  .fab-call{bottom:24px;left:24px}
  .fab-top{bottom:90px}
}
