/* =========================================================
   Root Variables
========================================================= */
:root {
  /* Colors */
  --clr-primary: #ff305b;
  /* اللون الرئيسي */
  --clr-text: rgb(66, 66, 66);
  --clr-text-muted: rgb(88, 88, 88);
  --clr-text-light: rgb(201, 201, 201);
  --clr-heading: rgb(95, 95, 95);
  --clr-white: #ffffff;
  --clr-black: #000000;

  --clr-bg-muted: rgb(236, 236, 236);
  /* services + blog */
  --clr-bg-lighter: rgb(226, 226, 226);
  /* more-info */
  --clr-bg-footer: rgb(43, 41, 41);

  --clr-overlay-hero: rgba(0, 0, 0, 0.801);
  --clr-overlay-portfolio: rgba(0, 0, 0, 0.603);
  --clr-overlay-about: rgba(0, 0, 0, 0.61);
  --clr-overlay-viewer: rgba(0, 0, 0, 0.685);

  --clr-star: rgb(255, 187, 0);

  /* Typography */
  --font-sans: 'Source Sans Pro', system-ui, -apple-system, Segoe UI, Roboto, 'Helvetica Neue', Arial, 'Noto Sans', 'Liberation Sans', sans-serif;

  /* Layout */
  --container-lg: 1100px;
  --container-md: 900px;
  --container-sm: 700px;
  --container-xs: 500px;

  --section-pad-block: 90px;
  --gap-1: 10px;
  --gap-2: 20px;

  /* Radius */
  --radius-sm: 4px;
  --radius-md: 5px;
  --radius-lg: 10px;

  /* Transitions */
  --dur-fast: 0.2s;
  --dur-base: 0.3s;
  --easing: linear;
}

/* =========================================================
   Global Reset & Base
========================================================= */
* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-sans);
  color: var(--clr-text);
}

.container {
  width: var(--container-lg);
  margin-inline: auto;
}

/* =========================================================
   Header
========================================================= */
header {
  position: fixed;
  top: 0;
  width: 100%;
  background-color: transparent;
  z-index: 1000;
  transition: background-color var(--dur-base) var(--easing);
}

header .container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

header .container i {
  color: var(--clr-white);
  font-size: 25px;
  cursor: pointer;
  display: none;
}

header .container .logo a {
  color: var(--clr-primary);
  font-size: 25px;
  font-weight: 600;
  text-decoration: none;
}

header .container a {
  display: block;
  text-decoration: none;
  padding: 7px;
  color: var(--clr-white);
  transition: color var(--dur-fast) var(--easing);
}

header .container a:hover,
header .container a.active {
  color: var(--clr-primary);
}


header .container nav ul {
  display: flex;
  list-style-type: none;
  gap: 5px;



}

/* =========================================================
   Home / Hero
========================================================= */
#Home {
  height: 100vh;
  background-image:
    linear-gradient(var(--clr-overlay-hero), var(--clr-overlay-hero)),
    url(./../images/slider-02.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

#Home .container {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

#Home .container .main-content {
  color: var(--clr-white);
  text-align: center;
}

#Home .container .main-content h1 {
  color: var(--clr-primary);
  font-size: 4em;
  padding: 10px;
  font-weight: 700;
  line-height: 70px;
}

#Home .container .main-content span,
#Home .container .main-content p {
  font-size: 20px;
  text-transform: capitalize;
}

#Home .container .main-content p {
  font-weight: 100;
  color: var(--clr-text-light);
}

#Home .container .main-content p::after {
  content: " | ";
  animation: write 1s var(--easing) infinite alternate;
}

@keyframes write {
  0% {
    content: " D |";
  }

  10% {
    content: " De |";
  }

  20% {
    content: " Dev |";
  }

  30% {
    content: " Deve |";
  }

  40% {
    content: " Devel |";
  }

  50% {
    content: " Develo |";
  }

  60% {
    content: " Develop |";
  }

  70% {
    content: " Develope |";
  }

  80%,
  90%,
  100% {
    content: " Developer |";
  }
}

/* =========================================================
   About
========================================================= */
#About .container {
  padding-block: var(--section-pad-block);
  display: flex;
  gap: 50px;
  flex-wrap: wrap;
  justify-content: center;
}

.img-container {
  border: 8px solid rgba(0, 0, 0, 0.603);
  border-radius: var(--radius-md);
  width: 400px;
  height: auto;
  align-self: self-start;
}

.img-container .img-for-me {
  width: 100%;
  height: 100%;
  transform: translate(30px, 30px);
  position: relative;
  overflow: hidden;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.219);
}

.overLay {
  position: absolute;
  top: 100%;
  left: 0;
  height: 100%;
  right: 0;
  background-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: top var(--dur-base) var(--easing), background-color var(--dur-base) var(--easing);
}

.socialMedia {
  display: flex;
  gap: var(--gap-1);
  align-items: center;
  justify-content: center;
}

.socialMedia i {
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--gap-1);
  font-size: 20px;
  width: 30px;
  height: 30px;
}

.socialMedia i:hover {
  color: var(--clr-primary);
}

.img-container .img-for-me:hover .overLay {
  top: 0;
  background-color: var(--clr-overlay-about);
}

.img-container .img-for-me img {
  width: 100%;
  display: block;
}

.content-about-me {
  display: flex;
  flex-direction: column;
  gap: var(--gap-1);
  width: 50%;
  align-items: start;
}

.content-about-me h2 {
  font-size: 30px;
}

.content-about-me h2::before {
  content: "I ";
  color: var(--clr-primary);
}

.content-about-me>p {
  color: var(--clr-text-muted);
  line-height: 30px;
  border-bottom: 1px dotted gray;
  padding-block: var(--gap-1);
}

.info-about-me {
  display: flex;
  gap: 40px;
}

.info-about-me p {
  font-size: 14px;
  font-weight: 700;
}

.info-about-me span {
  color: gray;
}

.left-info,
.right-info {
  display: flex;
  flex-direction: column;
  gap: var(--gap-1);
}

.btns {
  display: flex;
  justify-content: start;
  gap: var(--gap-2);
  margin-block: var(--gap-2);
}

.btns a {
  text-decoration: none;
  display: inline-flex;
  color: var(--clr-white);
  background-color: var(--clr-primary);
  padding: 10px 20px;
  border-radius: var(--radius-md);
  align-items: center;
  justify-content: center;
  gap: var(--gap-1);
  transition: background-color var(--dur-fast) var(--easing);
}

.btns a:hover {
  background-color: red;
}

.btns a i {
  font-size: 16px;
}

/* =========================================================
   Services
========================================================= */
#services {
  background-color: var(--clr-bg-muted);
}

#services .container {
  padding-block: var(--section-pad-block);
}

section .container h2 {
  text-align: center;
  font-size: 35px;
  margin-bottom: var(--gap-1);
}

section .container .lins {
  text-align: center;
  margin-bottom: 50px;
}

section .container .lins hr {
  border: none;
  height: 1px;
  background-color: var(--clr-primary);
  border-radius: 3px;
}

section .container .lins hr:nth-child(odd) {
  width: 100px;
  margin: auto;
}

section .container .lins hr:nth-child(even) {
  width: 200px;
  margin: 5px auto;
}

.services-items {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: var(--gap-1);
  justify-content: center;
}

.item-services {
  text-align: center;
  padding-block: 30px;
  transition: background-color var(--dur-base) var(--easing);
}

.item-services:hover {
  background-color: var(--clr-white);
}

.item-services h3 {
  margin-block: var(--gap-1);
  color: var(--clr-heading);
}

.item-services p {
  color: gray;
  line-height: 25px;
}

.item-services i {
  color: var(--clr-primary);
  font-size: 30px;
}

/* =========================================================
   Generic section padding
========================================================= */
section .container {
  padding-block: var(--section-pad-block);
}

/* =========================================================
   Portfolio
========================================================= */
.header-Links {
  margin-bottom: 40px;
}

.header-Links ul {
  list-style: none;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--gap-2);
}

.header-Links ul li {
  text-transform: uppercase;
  color: rgb(85, 85, 85);
  letter-spacing: 2px;
  cursor: pointer;
}

#Portfolio {
  position: relative;
}

#Portfolio .items {
  display: grid;
  grid-template-columns: repeat(3, minmax(200px, 1fr));
  grid-gap: 20px;
}

#Portfolio .items .item {
  position: relative;
  overflow: hidden;
}

#Portfolio .items .item .overLay {
  top: 100%;
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: var(--clr-overlay-portfolio);
  pointer-events: none;
}

#Portfolio .items .item:hover .overLay {
  top: 0;
}

#Portfolio .items .item img {
  width: 100%;
  cursor: pointer;
  display: block;
}

/* Image viewer overlay */
.overLay-img {
  top: 0;
  position: fixed;
  width: 100%;
  height: 110%;
  background-color: var(--clr-overlay-viewer);
  z-index: 99;
  display: none;
  align-items: center;
  justify-content: center;
}

.overLay-img img {
  width: 100%;
}

.overLay-img .imge {
  position: relative;
  max-width: 570px;
}

.overLay-img i {
  position: absolute;
  top: -10%;
  right: 0;
  color: var(--clr-white);
  font-size: 25px;
  cursor: pointer;
  z-index: 2;
}

.overLay-img #right-arr {
  top: 50%;
  color: var(--clr-primary);
  right: 10px;
}

.overLay-img #left-arr {
  top: 50%;
  color: var(--clr-primary);
  left: 10px;
}

/* =========================================================
   Utilities
========================================================= */
.active {
  color: var(--clr-primary) !important;
}

/* =========================================================
   More Info (Counters)
========================================================= */
.more-info {
  background-color: var(--clr-bg-lighter);
}

.more-info .container {
  display: grid;
  grid-template-columns: repeat(4, minmax(150px, 1fr));
  justify-content: center;
  gap: var(--gap-2);
}

.more-info .item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--gap-1);
}

.more-info .item i {
  color: var(--clr-primary);
  font-size: 25px;
}

.more-info .item span {
  font-weight: bold;
  font-size: 20px;
}

.more-info .item p {
  color: rgb(78, 78, 78);
}

/* =========================================================
   Feedback
========================================================= */
.FeedBackCards {
  padding-inline: var(--gap-1);
  max-width: 700px;
  margin: auto;
  display: flex;
  gap: 20px;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
}

.FeedBackCards::-webkit-scrollbar {
  height: 0;
}

.FeedBackCard {
  scroll-snap-align: center;
  scroll-snap-stop: center;
  min-width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  padding: 20px;
  cursor: grab;
  border-radius: var(--radius-lg);
  background-image: linear-gradient(130deg, var(--clr-primary) 0% 15%, rgb(238, 238, 238) 15% 100%);
}

.FeedBackCard .img {
  width: 130px;
  height: 130px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}

.FeedBackCard .img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.clint-info {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 15px;
}

.clint-info h3 {
  color: rgb(54, 54, 54);
  font-weight: 500;
}

.clint-info span {
  font-size: 14px;
  letter-spacing: 1px;
  color: rgb(59, 59, 59);
}

.clint-info p {
  line-height: 26px;
  font-style: italic;
  color: rgb(59, 59, 59);
}

.clint-info .stars {
  color: var(--clr-star);
}

#Clients-Feedback ul {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 20px;
  list-style: none;
  gap: 5px;
}

#Clients-Feedback ul li {
  border: 1px solid var(--clr-primary);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  cursor: pointer;
}

#Clients-Feedback ul li.active-icon {
  background-color: var(--clr-primary);
  width: 30px;
  border-radius: 10px;
}

/* =========================================================
   Blog
========================================================= */
#Our-Blog {
  background-color: var(--clr-bg-muted);
}

.blogs,
.blog-inf {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--gap-2);
}

.blog-inf {
  flex-direction: column;
  align-items: start;
  padding-inline: var(--gap-1);
  padding-bottom: var(--gap-1);
}

.blog {
  background-color: var(--clr-white);
  display: flex;
  flex-direction: column;
  gap: 15px;
  width: calc(100% / 3.5);
  border-radius: 5px;
  overflow: hidden;
}

.blog img {
  display: block;
  width: 100%;
}

.blog span {
  color: rgb(78, 78, 78);
  font-weight: 500;
}

.blog h4 {
  color: rgb(78, 78, 78);
  text-transform: capitalize;
  letter-spacing: 1px;
}

.blog p {
  line-height: 25px;
  color: var(--clr-text);
}

.blog a {
  text-decoration: none;
  color: var(--clr-text);
  transition: color var(--dur-fast) var(--easing);
}

.blog a:hover {
  color: var(--clr-primary);
}

/* =========================================================
   Contact
========================================================= */
#Contact-Us form {
  display: flex;
  flex-direction: column;
  gap: var(--gap-2);
}

#Contact-Us form div {
  display: flex;
  gap: var(--gap-2);
}

#Contact-Us form div input {
  flex-grow: 1;
}

#Contact-Us form input,
#Contact-Us form textarea {
  padding: 10px;
  outline: none;
  border: 1px solid rgba(65, 65, 65, 0.445);
  border-radius: var(--radius-md);
}

#Contact-Us form textarea {
  resize: none;
  height: 250px;
}

#Contact-Us form input:focus,
#Contact-Us form textarea:focus {
  box-shadow: 0 0 5px var(--clr-primary);
}

#Contact-Us form button {
  background-color: var(--clr-primary);
  border: none;
  color: var(--clr-white);
  padding: 15px;
  width: fit-content;
  cursor: pointer;
  border-radius: var(--radius-sm);
}

/* =========================================================
   Footer
========================================================= */
footer {
  background-color: var(--clr-bg-footer);
  color: var(--clr-white);
  padding-block: var(--section-pad-block);
}

footer p {
  padding-top: 15px;
  text-align: center;
}

footer span:not(#Date) {
  color: var(--clr-primary);
}

/* =========================================================
   Media Queries
========================================================= */
@media (max-width: 683px) {
  .more-info .container {
    grid-template-columns: repeat(2, minmax(150px, 1fr));
    grid-row-gap: 30px;
  }
}

@media (max-width: 484px) {
  .more-info .container {
    grid-template-columns: repeat(1, minmax(100px, 1fr));
    grid-row-gap: 30px;
  }
}

@media only screen and (max-width: 1200px) {
  .container {
    width: var(--container-md);
  }
}

@media only screen and (max-width: 980px) {
  .container {
    width: var(--container-sm);
  }

  .img-container,
  .content-about-me {
    width: 100%;
  }

  .info-about-me {
    flex-direction: column;
    gap: var(--gap-1);
  }

  .img-container {
    border: none;
  }

  .img-container .img-for-me {
    transform: translate(0, 0);
    width: 100%;
  }

  .services-items {
    grid-template-columns: repeat(2, minmax(300px, 1fr));
  }
}

@media only screen and (max-width: 752px) {
  #Portfolio .items {
    grid-template-columns: repeat(2, minmax(200px, 1fr));
  }
}

@media only screen and (max-width: 750px) {
  .container {
    width: var(--container-xs);
  }

  .blogs {
    flex-direction: column;
  }

  #Home .container .main-content h1 {
    font-size: 2em;
  }

  .blog {
    width: 300px;
  }

  nav {
    position: absolute;
    background-color: rgb(53, 53, 53);
    top: 100%;
    left: 50%;
    transform: translate(-50%);
    width: 90%;
    height: 0;
    overflow: hidden;
    transition: height var(--dur-base) var(--easing);
  }

  nav ul {
    flex-direction: column;
  }

  nav ul li a {
    text-align: center;
  }

  header .container i {
    display: block;
  }

  .services-items {
    grid-template-columns: repeat(1, minmax(300px, 1fr));
  }
}

@media only screen and (max-width: 555px) {
  #Portfolio .items {
    grid-template-columns: repeat(1, minmax(200px, 1fr));
  }

  .header-Links ul {
    gap: var(--gap-1);
  }

  .header-Links ul li {
    font-size: 13px;
  }

  .FeedBackCard {
    flex-direction: column;
    align-items: center;
  }
}

@media (max-width: 530px) {
  #Contact-Us form div {
    flex-direction: column;
  }
}

@media only screen and (max-width: 515px) {
  .container {
    width: 95%;
  }
}