*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

:root{
  --text:#101010;
  --muted:#444;
  --black:#000;
  --white:#fff;
  --light:#f7f4ef;
  --gray:#343434;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:'Montserrat', sans-serif;
  color:var(--text);
  background:#fff;
  overflow-x:hidden;
}

img{
  display:block;
  max-width:100%;
}

a{
  color:inherit;
  text-decoration:none;
}

.container{
  width:min(1320px, calc(100% - 64px));
  margin:0 auto;
}

/* HEADER */
.site-header{
  position:sticky;
  top:0;
  z-index:999;
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,0.06);
}

.header-inner{
  min-height:102px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}

.site-logo img{
  width:96px;
  height:auto;
  object-fit:contain;
}

.desktop-nav{
  display:flex;
  align-items:center;
  gap:34px;
  margin-right:auto;
  margin-left:22px;
}

.desktop-nav a{
  font-size:16px;
  color:#212121;
}

.desktop-nav a.active{
  font-weight:600;
}

.header-right{
  display:flex;
  align-items:center;
  gap:20px;
}

.phone-link{
  font-size:15px;
  color:#333;
}

.btn-contact{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:44px;
  padding:0 22px;
  background:#000;
  color:#fff;
  border-radius:8px;
  font-size:15px;
  font-weight:600;
}

.mobile-toggle{
  display:none;
  border:none;
  background:none;
  font-size:28px;
  cursor:pointer;
}

.mobile-menu{
  display:none;
  background:#fff;
  border-top:1px solid rgba(0,0,0,0.08);
  padding:16px 32px 24px;
}

.mobile-menu a{
  display:block;
  margin:12px 0;
}

.mobile-phone{
  margin-top:18px;
}

.mobile-btn{
  width:max-content;
  margin-top:14px;
}

/* HOME HERO */
.hero-section{
  position:relative;
  height:590px;
  overflow:hidden;
}

.hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.02);
}

.hero-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.40);
}

.hero-bottom-shape{
  position:absolute;
  left:-3%;
  right:-3%;
  bottom:-45px;
  height:120px;
  background:#fff;
  border-top-left-radius:50% 100%;
  border-top-right-radius:50% 100%;
}

/* INTRO */
.intro-section{
  padding:120px 0 100px;
  background:#fff;
}

.intro-text{
  margin-bottom:58px;
}

.intro-text h1{
  font-family:'Playfair Display', serif;
  font-size:58px;
  line-height:1.08;
  font-weight:500;
  max-width:980px;
  margin-bottom:24px;
}

.intro-text p{
  font-size:18px;
  color:#222;
}

.intro-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:28px;
}

.intro-item img{
  width:100%;
  height:200px;
  object-fit:cover;
  border-radius:8px;
}

/* COLLAGE */
.collage-section{
  position:relative;
  background:#fff;
  padding:35px 0 80px;
}

.collage-shape{
  position:absolute;
  top:0;
  left:0;
  width:660px;
  height:220px;
  background:#373737;
  clip-path:polygon(0 0,100% 0,86% 100%,0 100%);
}

.collage-wrap{
  position:relative;
  z-index:2;
  width:min(1520px, calc(100% - 40px));
  margin:0 auto;
  display:grid;
  grid-template-columns:320px 480px 460px 280px;
  gap:18px;
  align-items:end;
}

.collage-item img{
  width:100%;
  object-fit:cover;
}

.small-left{
  margin-top:120px;
}

.small-left img{
  height:300px;
}

.tall-center img{
  height:430px;
}

.big-right img{
  height:475px;
}

.small-right{
  margin-top:120px;
}

.small-right img{
  height:330px;
}

.collage-text{
  padding-top:48px;
}

.collage-text h2{
  font-family:'Playfair Display', serif;
  font-size:56px;
  line-height:1.08;
  font-weight:500;
  margin-bottom:22px;
}

.collage-text p{
  max-width:1150px;
  font-size:18px;
  line-height:1.75;
  color:#222;
}

/* FEATURE / OVERLAP */
.feature-section{
  position:relative;
  padding:90px 0 120px;
  overflow:hidden;
}

.feature-bg-left{
  position:absolute;
  top:0;
  left:0;
  width:50%;
  height:100%;
  background:#000;
}

.feature-bg-right{
  position:absolute;
  top:0;
  right:0;
  width:50%;
  height:100%;
  background:#3b3b3b;
}

.feature-inner{
  position:relative;
  z-index:2;
  min-height:520px;
}

.feature-image{
  width:58%;
  background:#fff;
  padding:12px;
  border-radius:6px;
  position:relative;
  top:28px;
  box-shadow:0 12px 30px rgba(0,0,0,0.20);
}

.feature-image img{
  width:100%;
  height:425px;
  object-fit:cover;
  border-radius:3px;
}

.feature-box{
  position:absolute;
  right:0;
  top:78px;
  width:49%;
  background:#f3f3f3;
  border-radius:6px;
  padding:48px 40px;
}

.feature-title{
  font-size:20px;
  font-weight:500;
  margin-bottom:22px;
}

.feature-box p{
  font-size:17px;
  line-height:1.8;
  color:#1d1d1d;
  margin-bottom:16px;
}

/* SERVICES HOME */
.services-section{
  background:#000;
  color:#fff;
  padding:68px 0 120px;
}

.services-head{
  text-align:center;
  margin-bottom:46px;
}

.services-head h2{
  font-family:'Playfair Display', serif;
  font-size:50px;
  font-weight:500;
  margin-bottom:14px;
}

.services-head p{
  color:rgba(255,255,255,0.82);
  font-size:17px;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}

.service-card img{
  width:100%;
  height:265px;
  object-fit:cover;
  border-radius:8px;
}

/* LOGO BAND */
.logo-band{
  position:relative;
  background:#fff;
  height:180px;
  overflow:hidden;
}

.logo-band-shape{
  position:absolute;
  top:-78px;
  left:-2%;
  width:104%;
  height:170px;
  background:#fff;
  transform:rotate(-4deg);
}

.logo-band-inner{
  position:relative;
  z-index:2;
  height:100%;
  display:flex;
  align-items:center;
}

.logo-band-inner img{
  width:190px;
  height:auto;
  object-fit:contain;
}

/* FOOTER */
.site-footer{
  background:#000;
  color:#fff;
  padding:52px 0 26px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr;
  gap:80px;
}

.footer-col h3{
  font-family:'Playfair Display', serif;
  font-size:28px;
  margin-bottom:24px;
}

.footer-col h4{
  font-size:22px;
  margin-bottom:18px;
}

.footer-col p,
.footer-col a{
  color:#fff;
  font-size:17px;
  line-height:1.7;
}

.footer-bottom{
  padding-top:54px;
}

.footer-bottom p{
  font-size:15px;
}

.instagram-link{
  display:inline-block;
  margin-top:18px;
}

.instagram-link img{
  width:28px;
  height:28px;
  object-fit:contain;
}

.yb-link{
  color:#fff;
}

.yb-link:hover{
  text-decoration:underline;
}

/* PAGE HERO */
.page-hero{
  position:relative;
  height:220px;
  overflow:hidden;
  background:#111;
}

.page-hero-bg{
  position:absolute;
  inset:0;
  background-image:url('../images/project-feature.jpg');
  background-size:cover;
  background-position:center;
  filter:blur(1px);
  transform:scale(1.05);
}

.page-hero-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.45);
}

.page-hero-inner{
  position:relative;
  z-index:2;
  height:100%;
  display:flex;
  align-items:center;
}

.page-hero-inner h1{
  color:#fff;
  font-family:'Playfair Display', serif;
  font-size:52px;
  font-weight:500;
}

/* HIZMETLER SAYFASI */
.services-page-section{
  padding:80px 0;
  background:#f8f5f1;
}

.services-cards-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}

.service-box{
  background:#fff;
  border-radius:10px;
  overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,0.06);
  transition:transform .3s ease, box-shadow .3s ease;
}

.service-box:hover{
  transform:translateY(-6px);
  box-shadow:0 18px 40px rgba(0,0,0,0.10);
}

.service-box-image img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
}

.service-box-body{
  padding:22px 22px 26px;
}

.service-box-body h3{
  font-size:22px;
  font-family:'Playfair Display', serif;
  font-weight:500;
  color:#111;
}

.project-feature-section{
  background:#ece7df;
  padding:90px 0;
}

.project-feature-inner{
  position:relative;
  display:grid;
  grid-template-columns:1.15fr .85fr;
  align-items:center;
  gap:0;
}

.project-feature-image{
  position:relative;
  z-index:1;
}

.project-feature-image img{
  width:100%;
  height:560px;
  object-fit:cover;
  border-radius:10px;
}

.project-feature-box{
  position:relative;
  z-index:2;
  background:#fff;
  margin-left:-90px;
  padding:45px 40px;
  border-radius:10px;
  box-shadow:0 14px 35px rgba(0,0,0,0.08);
}

.project-feature-box h2{
  font-family:'Playfair Display', serif;
  font-size:38px;
  font-weight:500;
  margin-bottom:24px;
  color:#111;
}

.project-feature-box p{
  font-size:16px;
  line-height:1.8;
  color:#222;
  margin-bottom:14px;
}

.testimonials-section{
  background:#2f2f2f;
  padding:90px 0 120px;
  color:#fff;
}

.testimonial-slider{
  position:relative;
  max-width:860px;
  margin:0 auto;
}

.testimonial-item{
  display:none;
  position:relative;
  background:#fff;
  color:#111;
  padding:50px 55px 36px;
  border-radius:12px;
  text-align:center;
}

.testimonial-item.active{
  display:block;
}

.quote-icon{
  width:62px;
  height:62px;
  border-radius:50%;
  background:#f0e7db;
  color:#111;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:42px;
  margin:0 auto 22px;
  font-family:'Playfair Display', serif;
}

.testimonial-text{
  font-size:22px;
  line-height:1.7;
  margin-bottom:28px;
  font-family:'Playfair Display', serif;
}

.testimonial-author{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.testimonial-avatar{
  width:58px;
  height:58px;
  border-radius:50%;
  background:#d8d8d8;
}

.testimonial-controls{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  margin-top:28px;
}

.testimonial-controls button{
  width:44px;
  height:44px;
  border:none;
  border-radius:50%;
  background:#fff;
  color:#111;
  font-size:28px;
  cursor:pointer;
}

.testimonial-dots{
  display:flex;
  gap:10px;
}

.dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:rgba(255,255,255,0.35);
  cursor:pointer;
}

.dot.active{
  background:#fff;
}

/* HAKKIMIZDA */
.about-hero-bg{
  background-image:url('../images/about-1.jpg');
  background-size:cover;
  background-position:center;
}

.about-section{
  padding:80px 0;
}

.about-mission{
  background:#f6f2ec;
}

.about-vision{
  background:#ffffff;
}

.about-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:50px;
  align-items:center;
}

.about-grid.reverse{
  grid-template-columns:1.1fr .9fr;
}

.about-text-card{
  background:#ffffff;
  padding:48px 38px;
  border-radius:14px;
  box-shadow:0 12px 34px rgba(0,0,0,0.06);
}

.about-text-card h2,
.about-text-side h2{
  font-family:'Playfair Display', serif;
  font-size:42px;
  font-weight:500;
  color:#111;
  margin-bottom:24px;
}

.about-text-card p,
.about-text-side p{
  font-size:16px;
  line-height:1.9;
  color:#222;
  margin-bottom:16px;
}

.about-image-box img{
  width:100%;
  height:480px;
  object-fit:cover;
  border-radius:16px;
  box-shadow:0 12px 30px rgba(0,0,0,0.08);
}

.about-text-side{
  padding-right:10px;
}

.about-brand-section{
  background:#2f2f2f;
  color:#fff;
  padding:110px 0 130px;
  position:relative;
}

.about-brand-section::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:140px;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,0.05) 0, rgba(255,255,255,0.05) 18%, transparent 19%),
    radial-gradient(circle at 80% 60%, rgba(255,255,255,0.04) 0, rgba(255,255,255,0.04) 14%, transparent 15%);
  pointer-events:none;
}

.brand-content{
  position:relative;
  z-index:2;
  text-align:center;
  max-width:900px;
}

.brand-content h2{
  font-family:'Playfair Display', serif;
  font-size:52px;
  font-weight:500;
  margin-bottom:18px;
}

.brand-content p{
  font-size:18px;
  line-height:1.8;
  color:rgba(255,255,255,0.82);
}

/* ILETISIM */
.contact-hero-bg{
  background-image:url('../images/z.webp');
  background-size:cover;
  background-position:center;
}

.contact-section{
  background:#f7f3ee;
  padding:90px 0 110px;
}

.contact-layout{
  display:grid;
  grid-template-columns:1.25fr .75fr;
  gap:34px;
  align-items:start;
}

.contact-map-card{
  background:#fff;
  border-radius:18px;
  padding:20px;
  box-shadow:0 14px 36px rgba(0,0,0,0.07);
}

.map-frame{
  width:100%;
  height:500px;
  border-radius:14px;
  overflow:hidden;
  position:relative;
}

.map-frame iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
  filter:grayscale(15%) contrast(1.02);
}

.contact-text-under-map{
  padding:22px 8px 6px;
}

.contact-text-under-map p{
  font-size:17px;
  line-height:1.8;
  color:#222;
}

.contact-info-card{
  background:#ffffff;
  border-radius:18px;
  padding:34px 30px;
  box-shadow:0 14px 36px rgba(0,0,0,0.07);
  position:sticky;
  top:120px;
}

.contact-info-card h3{
  font-family:'Playfair Display', serif;
  font-size:34px;
  font-weight:500;
  margin-bottom:26px;
  color:#111;
}

.contact-info-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:24px;
}

.contact-info-list li{
  display:flex;
  align-items:flex-start;
  gap:14px;
  color:#222;
  font-size:16px;
  line-height:1.8;
}

.contact-icon{
  width:38px;
  height:38px;
  min-width:38px;
  border-radius:50%;
  background:#f1e8dd;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:17px;
}

.contact-info-list a{
  color:#111;
}

.contact-info-list a:hover{
  text-decoration:underline;
}

.contact-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:28px;
}

.contact-secondary-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:0 18px;
  border-radius:10px;
  background:#111;
  color:#fff;
  font-size:14px;
  font-weight:600;
}

.contact-secondary-btn.light{
  background:#efe7dc;
  color:#111;
}

/* RESPONSIVE */
@media (max-width: 1150px){
  .desktop-nav,
  .header-right{
    display:none;
  }

  .mobile-toggle{
    display:block;
  }

  .intro-grid,
  .services-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .collage-wrap{
    grid-template-columns:1fr 1fr;
    width:min(1320px, calc(100% - 40px));
  }

  .small-left,
  .small-right{
    margin-top:0;
  }

  .feature-inner{
    display:flex;
    flex-direction:column;
    gap:24px;
  }

  .feature-image,
  .feature-box{
    width:100%;
    position:relative;
    right:auto;
    top:auto;
  }

  .footer-grid{
    grid-template-columns:1fr;
    gap:36px;
  }

  .services-cards-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .project-feature-inner{
    grid-template-columns:1fr;
    gap:24px;
  }

  .project-feature-box{
    margin-left:0;
  }

  .about-grid,
  .about-grid.reverse,
  .contact-layout{
    grid-template-columns:1fr;
    gap:28px;
  }

  .about-text-side{
    padding-right:0;
  }

  .contact-info-card{
    position:relative;
    top:auto;
  }
}

@media (max-width: 768px){
  .container{
    width:min(100%, calc(100% - 32px));
  }

  .hero-section{
    height:430px;
  }

  .hero-bottom-shape{
    height:80px;
    bottom:-25px;
  }

  .intro-section{
    padding:85px 0 74px;
  }

  .intro-text h1,
  .collage-text h2,
  .services-head h2,
  .brand-content h2{
    font-size:34px;
  }

  .page-hero{
    height:180px;
  }

  .page-hero-inner h1{
    font-size:38px;
  }

  .intro-grid,
  .collage-wrap,
  .services-grid,
  .services-cards-grid{
    grid-template-columns:1fr;
  }

  .intro-item img,
  .service-card img{
    height:220px;
  }

  .small-left img,
  .tall-center img,
  .big-right img,
  .small-right img{
    height:240px;
  }

  .mobile-menu{
    padding:16px 20px 24px;
  }

  .logo-band-inner img{
    width:150px;
  }

  .project-feature-image img{
    height:320px;
  }

  .project-feature-box{
    padding:30px 22px;
  }

  .project-feature-box h2{
    font-size:30px;
  }

  .testimonial-item{
    padding:34px 22px 28px;
  }

  .testimonial-text{
    font-size:18px;
  }

  .about-section{
    padding:60px 0;
  }

  .about-text-card{
    padding:32px 22px;
  }

  .about-text-card h2,
  .about-text-side h2{
    font-size:30px;
  }

  .about-image-box img{
    height:280px;
  }

  .brand-content p{
    font-size:16px;
  }

  .contact-section{
    padding:60px 0 80px;
  }

  .contact-map-card,
  .contact-info-card{
    padding:16px;
    border-radius:14px;
  }

  .map-frame{
    height:320px;
    border-radius:10px;
  }

  .contact-info-card h3{
    font-size:28px;
  }

  .contact-text-under-map p{
    font-size:16px;
  }
}