/* ============ Services Page ============ */
:root{
  --navy:#05103A;
  --ink:#0d1b2a;
  --muted:#5b6b82;
  --accent:#ffb367;
  --paper:#ffffff;
  --line:#e6e9f0;
}

/* HERO */
.svc-hero{
  position:relative; min-height: 320px; color:#fff;
  display:grid; place-items:center; text-align:center; overflow:hidden;
}
.svc-hero-bg{
  position:absolute; inset:0;
  background:url('../images/services-hero.jpg') center/cover no-repeat, linear-gradient(180deg,#102044,#05103A);
  filter: brightness(.85);
}
.svc-hero-overlay{
  position:absolute; inset:0;
  background: radial-gradient(800px 400px at 50% 8%, rgba(255,179,103,.25), transparent 60%),
              linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.55));
}
.svc-hero-inner{ position:relative; z-index:2; width:min(1100px,92%); padding:34px 0; }
.svc-title{
  margin:0 0 8px; font-size: clamp(26px, 4vw, 44px);
  font-weight: 900; letter-spacing:.02em; text-shadow:0 6px 20px rgba(0,0,0,.35);
}
.svc-sub{ margin:0 0 16px; font-size:clamp(14px,2.2vw,16px); opacity:.95; }

/* Toolbar */
.svc-toolbar{ display:grid; gap:12px; justify-items:center; }
.svc-filters{
  display:flex; gap:10px; flex-wrap:wrap; justify-content:center;
}
.svc-filter{
  appearance:none; border:1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.08); color:#fff; font-weight:800;
  padding:10px 14px; border-radius:999px; cursor:pointer;
  transition: background .2s, border-color .2s, transform .2s, color .2s;
}
.svc-filter:hover{ transform: translateY(-1px); }
.svc-filter.is-active{ background:#ffb367; color:#05103A; border-color:#ffb367; }

/* search + sort */
.svc-controls{ display:flex; gap:12px; flex-wrap:wrap; justify-content:center; }
.svc-search, .svc-sort{
  display:flex; align-items:center; gap:8px;
  background: rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.35);
  padding: 8px 12px; border-radius: 999px; color:#fff;
}
.svc-search input{
  background: transparent; border:0; outline:0; color:#fff; min-width:220px;
}
.svc-search input::placeholder{ color:rgba(255,255,255,.85); }
.svc-sort label{ font-weight:700; }
.svc-sort select{ background: transparent; border:0; color:#fff; outline:0; }

/* GRID */
.svc-wrap{ background:#f7f8fb; padding: clamp(30px,5vw,60px) 0; }
.svc-grid{
  width:min(1200px,92%);
  margin-inline:auto;
  display:grid; gap: clamp(14px, 2.2vw, 20px);
  grid-template-columns: repeat(auto-fill, minmax(270px, 1fr));
}

/* CARD */
.svc-card{
  background: var(--paper);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:0 8px 18px rgba(0,0,0,.05);
  overflow:hidden;
  transition: transform .2s, box-shadow .2s, border-color .2s;
}
.svc-card:hover{ transform: translateY(-2px); box-shadow:0 14px 26px rgba(0,0,0,.08); border-color:#ffd7a8; }

.svc-link{ display:block; color:inherit; text-decoration:none; }

.svc-img{ position:relative; aspect-ratio: 16 / 10; overflow:hidden; background:#eef1f6; }
.svc-img img{ width:100%; height:100%; object-fit:cover; display:block; transform:scale(1); transition: transform .6s ease; }

/* overlay + corner */
.svc-overlay{
  position:absolute; inset:0;
  background: linear-gradient(to bottom, rgba(0,0,0,.55) 0%, rgba(0,0,0,.25) 40%, rgba(0,0,0,0) 100%);
  opacity:0; translate: 0 -10px;
  transition: opacity .35s ease, translate .35s ease;
  pointer-events:none;
}
.svc-corner{
  position:absolute; top:0; left:0; width:120%; height:120%;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  background: linear-gradient(0deg, rgba(209,138,82,.45) 0%, rgba(231,169,106,.30) 50%, rgba(231,169,106,0) 100%);
  opacity:0; transition: opacity .35s ease;
}
[dir="rtl"] .svc-corner{ left:auto; right:0; clip-path: polygon(0 0, 100% 100%, 100% 0); }

.svc-card:hover .svc-overlay{ opacity:1; translate:0 0; }
.svc-card:hover .svc-corner{ opacity:1; }
.svc-card:hover .svc-img img{ transform: scale(1.06); }

/* body */
.svc-body{ padding: 14px 14px 16px; }
.svc-name{ margin:0 0 6px; font-size:18px; font-weight:900; color:#05103A; }
.svc-desc{
  margin:0 0 10px; color:#334155;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
  font-size:14px; line-height:1.55;
}
.svc-cta{
  display:inline-flex; align-items:center; gap:8px;
  font-weight:800; color:#0f3a7a;
}

/* empty */
.svc-empty{
  width:min(1200px,92%); margin: 0 auto; text-align:center; color:#52606d;
  background:#fff; border:1px dashed #d6dbe3; border-radius:12px; padding:16px;
}

/* RTL */
[dir="rtl"] .svc-search input{ text-align:right; }
