
:root{
  --paper:#fff;
  --ink:#111;
  --muted:#706a63;
  --line:rgba(17,17,17,.12);
  --soft:#f7f4ee;
  --soft2:#f0ebe4;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Avenir Next","Avenir","Helvetica Neue",Arial,sans-serif;
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit}
img,video{max-width:100%}
::selection{background:#111;color:#fff}
.wrap{width:min(1120px,calc(100% - 48px));margin:0 auto}
.top{
  position:sticky;top:0;z-index:20;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line);
}
.bar{
  width:min(1120px,calc(100% - 48px));
  margin:0 auto;
  padding:16px 0;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.id{
  text-decoration:none;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:700;
}
nav{display:flex;gap:24px;align-items:center;flex-wrap:wrap}
nav a{
  text-decoration:none;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:#57514a;
  font-weight:650;
}
nav a:hover{color:#111}
.hero{
  min-height:78vh;
  display:grid;
  place-items:center;
  text-align:center;
  padding:88px 0 76px;
}
.kicker,.label,.eyebrow{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:750;
}
.hero h1,.display,.page-title,.project-title,footer h2{
  font-family:"Didot","Bodoni 72","Bodoni 72 Display","Hoefler Text","Iowan Old Style",Georgia,serif;
  font-weight:400;
  letter-spacing:-.055em;
}
.hero h1{
  font-size:clamp(4.1rem,12vw,9rem);
  line-height:.86;
  margin:18px 0 18px;
}
.role{
  font-family:"Didot","Bodoni 72","Hoefler Text",Georgia,serif;
  font-size:clamp(1.15rem,2.2vw,1.55rem);
  font-style:italic;
  color:#302c27;
  max-width:32ch;
  margin:0 auto;
}
.meta{
  display:flex;justify-content:center;gap:20px;flex-wrap:wrap;
  margin-top:28px;color:#5d574f;font-size:14px;
}
.meta a{text-decoration:none;border-bottom:1px solid rgba(0,0,0,.35)}
section{padding:82px 0;border-top:1px solid var(--line)}
.label{display:inline-block;margin-bottom:28px}
.about-copy{
  font-family:"Didot","Bodoni 72","Hoefler Text",Georgia,serif;
  font-size:clamp(2.2rem,5.3vw,4.7rem);
  line-height:.92;
  letter-spacing:-.055em;
  max-width:14ch;
}



/* ===== Apple-like polish pass ===== */
body{
  text-rendering:optimizeLegibility;
}
.top{
  background:rgba(255,255,255,.78);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
}
.hero{
  min-height:86vh;
}
.hero h1{
  letter-spacing:-.065em;
}
.display, .page-title, .project-title{
  letter-spacing:-.06em;
}

.project-index{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:26px;
  margin-top:40px;
  align-items:stretch;
}
.project-card{
  position:relative;
  min-height:450px;
  display:flex;
  flex-direction:column;
  text-decoration:none;
  border-radius:34px;
  overflow:hidden;
  border:1px solid rgba(0,0,0,.08);
  background:linear-gradient(180deg,#faf8f5 0%,#f2ece4 100%);
  box-shadow:0 8px 30px rgba(0,0,0,.05);
  transition:
    transform .65s cubic-bezier(.22,1,.36,1),
    box-shadow .65s cubic-bezier(.22,1,.36,1),
    border-color .5s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.project-card::before{
  content:"";
  position:absolute;
  inset:auto auto -90px -60px;
  width:240px;
  height:240px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.8) 0%, rgba(255,255,255,0) 72%);
  pointer-events:none;
}
.project-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0));
  pointer-events:none;
}
.project-card:hover{
  transform:translateY(-12px) scale(1.01);
  box-shadow:0 36px 90px rgba(0,0,0,.14);
  border-color:rgba(0,0,0,.12);
}
.tile-media{
  height:255px;
  padding:16px;
  display:grid;
  place-items:center;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.72), rgba(255,255,255,.35));
}
.tile-media img,
.tile-media video{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
  border-radius:24px;
  background:#fff;
  box-shadow:0 22px 48px rgba(0,0,0,.10);
  transition:transform .8s cubic-bezier(.22,1,.36,1), box-shadow .8s cubic-bezier(.22,1,.36,1);
}
.project-card:hover .tile-media img,
.project-card:hover .tile-media video{
  transform:scale(1.03);
  box-shadow:0 30px 60px rgba(0,0,0,.14);
}
.tile-body{
  position:relative;
  padding:26px 26px 28px;
  display:flex;
  flex-direction:column;
  flex:1;
  z-index:1;
}
.project-card .eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  margin-bottom:12px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.58);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.6);
}
.project-card h3{
  font-size:clamp(2rem,3.6vw,3.4rem);
  line-height:.9;
  margin-bottom:14px;
}
.project-card p{
  font-size:1rem;
  color:#504a43;
  max-width:44ch;
}
.arrow{
  margin-top:auto;
  padding-top:24px;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
}
.arrow span{
  border-bottom:1px solid currentColor;
  padding-bottom:4px;
  transition:padding-right .35s cubic-bezier(.22,1,.36,1);
}
.project-card:hover .arrow span{
  padding-right:10px;
}
.video-thumb{
  position:relative;
  width:100%;
  height:100%;
}
.video-thumb img{
  width:100%;
  height:100%;
  object-fit:cover; /* real preview feel */
}
.play-badge{
  position:absolute;
  left:20px;
  bottom:20px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(17,17,17,.78);
  color:#fff;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  font-size:10px;
  letter-spacing:.13em;
  text-transform:uppercase;
  font-weight:800;
  box-shadow:0 8px 24px rgba(0,0,0,.18);
}
.play-badge::before{content:"▶";font-size:10px;line-height:1}
.tile-bike{
  background:linear-gradient(180deg,#f3f8fb 0%,#e7eff5 100%);
}
.tile-bike .tile-media{
  background:linear-gradient(180deg,#eef6fb 0%,#dce8f1 100%);
}
.tile-bike .tile-media img{
  object-fit:cover;
  object-position:center;
}
.tile-housing{
  background:linear-gradient(180deg,#f7f6f4 0%,#ece9e3 100%);
}
.tile-erdem{
  background:linear-gradient(180deg,#f8f1ea 0%,#eee3d5 100%);
}
.tile-erdem .tile-media{
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  align-items:center;
}
.tile-erdem .tile-media img{
  object-fit:cover;
  height:100%;
}
.tile-erdem .tile-media img:nth-child(1){transform:translateY(8px)}
.tile-erdem .tile-media img:nth-child(2){transform:translateY(-12px)}
.tile-erdem .tile-media img:nth-child(3){transform:translateY(16px)}
.project-card:hover.tile-erdem .tile-media img:nth-child(1){transform:translateY(2px) scale(1.02)}
.project-card:hover.tile-erdem .tile-media img:nth-child(2){transform:translateY(-18px) scale(1.03)}
.project-card:hover.tile-erdem .tile-media img:nth-child(3){transform:translateY(8px) scale(1.02)}
.tile-puma{
  background:linear-gradient(180deg,#eef2f6 0%,#e0e6eb 100%);
}

.media-frame{
  padding:20px;
  border-radius:32px;
  background:linear-gradient(180deg,#f7f4ef 0%,#efe9df 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6);
}
.media-frame img,
.media-frame video{
  border-radius:24px;
  box-shadow:0 24px 65px rgba(0,0,0,.12);
  transition:transform .6s cubic-bezier(.22,1,.36,1), box-shadow .6s cubic-bezier(.22,1,.36,1);
}
.media-frame:hover img,
.media-frame:hover video{
  transform:translateY(-5px) scale(1.01);
  box-shadow:0 34px 80px rgba(0,0,0,.14);
}
.gallery-row img{
  border-radius:26px;
  box-shadow:0 18px 50px rgba(0,0,0,.12);
}
.gallery-row img:nth-child(2){transform:translateY(-10px)}
.gallery-row img:hover{transform:translateY(-10px) scale(1.01)}

/* reveal animations */
.reveal, .reveal-item{
  opacity:0;
  transform:translateY(34px);
  transition:
    opacity .85s cubic-bezier(.22,1,.36,1),
    transform .85s cubic-bezier(.22,1,.36,1);
}
.reveal.in-view, .reveal-item.in-view{
  opacity:1;
  transform:none;
}
.project-card.reveal-item:nth-child(1){transition-delay:.02s}
.project-card.reveal-item:nth-child(2){transition-delay:.08s}
.project-card.reveal-item:nth-child(3){transition-delay:.14s}
.project-card.reveal-item:nth-child(4){transition-delay:.2s}

@media(max-width:860px){
  .project-index{
    grid-template-columns:1fr;
    gap:18px;
  }
  .project-card{
    min-height:0;
  }
  .tile-media{
    height:235px;
  }
  .gallery-row img:nth-child(2){
    transform:none;
  }
}

@media(prefers-reduced-motion:reduce){
  .project-card,
  .project-card:hover,
  .tile-media img,
  .tile-media video,
  .media-frame img,
  .media-frame video,
  .gallery-row img,
  .gallery-row img:hover,
  .reveal,
  .reveal-item{
    transition:none !important;
    transform:none !important;
    opacity:1 !important;
  }
}


/* Project pages */
.page-hero{padding:88px 0 50px}
.back{
  display:inline-block;
  text-decoration:none;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:750;
  color:#4b453e;
  border-bottom:1px solid currentColor;
  padding-bottom:4px;
  margin-bottom:34px;
}
.page-title{
  font-size:clamp(3.3rem,9vw,7rem);
  line-height:.86;
  max-width:9.5ch;
  margin:18px 0 20px;
}
.project-copy{
  max-width:58ch;
  font-size:1.04rem;
  color:#403b35;
}
.project-layout{
  display:grid;
  grid-template-columns:.84fr 1.16fr;
  gap:58px;
  align-items:center;
}
.project-title{
  font-size:clamp(2.35rem,5.5vw,5rem);
  line-height:.9;
  margin:14px 0 18px;
}
.project-actions{display:flex;gap:20px;flex-wrap:wrap;margin-top:28px}
.project-actions a{
  text-decoration:none;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
  border-bottom:1px solid currentColor;
  padding-bottom:4px;
}
.media-frame{
  padding:18px;
  border-radius:30px;
  background:#f7f4ef;
}
.media-frame img,
.media-frame video{
  width:100%;
  max-height:680px;
  object-fit:contain;
  display:block;
  border-radius:22px;
  background:#fff;
  box-shadow:0 22px 65px rgba(0,0,0,.12);
}
.media-frame video{background:#111;aspect-ratio:16/9}
.case-notes{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:28px;
  margin-top:42px;
  padding-top:26px;
  border-top:1px solid var(--line);
}
.case-notes h3{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin-bottom:8px;
}
.case-notes p{font-size:.95rem;color:#423d37}
.gallery-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:center;
  margin-top:26px;
}
.gallery-row img{
  width:100%;
  height:auto;
  object-fit:contain;
  display:block;
  border-radius:24px;
  box-shadow:0 22px 65px rgba(0,0,0,.12);
  transition:transform .45s cubic-bezier(.16,1,.3,1),box-shadow .45s cubic-bezier(.16,1,.3,1);
}
.gallery-row img:hover{
  transform:translateY(-7px);
  box-shadow:0 34px 90px rgba(0,0,0,.16);
}

/* Experience */
.experience-list{display:grid;gap:30px}
.entry{border-top:1px solid var(--line);padding-top:28px}
.entry:first-child{border-top:0;padding-top:0}
.entry .head{display:flex;justify-content:space-between;gap:18px;align-items:baseline;flex-wrap:wrap;margin-bottom:12px}
.entry h3{
  font-family:"Didot","Bodoni 72","Hoefler Text",Georgia,serif;
  font-size:1.5rem;font-weight:400;letter-spacing:-.04em;
}
.entry .when{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}
.entry ul{list-style:none;display:grid;gap:10px}
.entry li{padding-left:18px;position:relative;color:#3c3732}
.entry li::before{content:"";position:absolute;left:0;top:.75em;width:8px;height:1px;background:#111}

/* Footer */
footer{padding:84px 0;text-align:center;background:#fbfaf8;border-top:1px solid var(--line)}
footer h2{
  font-size:clamp(2.2rem,6vw,4.8rem);
  line-height:.95;
  margin-bottom:30px;
}
.contact{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.contact a{
  background:#111;color:#fff;text-decoration:none;border-radius:999px;
  padding:14px 24px;font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:750;
}
.colophon{margin-top:32px;font-size:12px;color:var(--muted)}

@media(max-width:860px){
  .wrap,.bar{width:min(100% - 36px,1120px)}
  nav{display:none}
  .hero{min-height:auto;padding:78px 0 64px}
  section{padding:64px 0}
  .project-index,
  .project-layout,
  .case-notes,
  .gallery-row{grid-template-columns:1fr}
  .tile-media{height:240px}
  .project-card{min-height:0}
  .page-title{font-size:clamp(3rem,16vw,5.2rem)}
}


/* ===== creative refinement pass ===== */

/* overall art direction */
body{
  background:
    radial-gradient(circle at 8% 12%, rgba(190,220,238,.34), transparent 26%),
    radial-gradient(circle at 92% 32%, rgba(241,224,205,.34), transparent 24%),
    linear-gradient(180deg, #fffdf9 0%, #ffffff 28%, #fcfaf6 100%);
}
.hero{
  position:relative;
  overflow:hidden;
}
.hero::before,
.hero::after{
  content:"";
  position:absolute;
  border-radius:999px;
  filter:blur(40px);
  pointer-events:none;
  opacity:.65;
}
.hero::before{
  width:340px;height:340px;left:-70px;top:90px;
  background:radial-gradient(circle, rgba(177,214,233,.75) 0%, rgba(177,214,233,0) 72%);
}
.hero::after{
  width:300px;height:300px;right:-70px;bottom:60px;
  background:radial-gradient(circle, rgba(242,221,201,.72) 0%, rgba(242,221,201,0) 72%);
}
.display{
  max-width:11ch;
}

/* make project grid feel more designed */
.project-index{
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:28px;
  margin-top:44px;
}

/* featured bike lane card */
.feature-bike{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:.86fr 1.14fr;
  min-height:400px;
  align-items:stretch;
}
.feature-bike .tile-media{
  grid-column:2;
  grid-row:1;
  height:auto;
  padding:24px 26px 24px 8px;
  background:linear-gradient(180deg,#eaf4fb 0%, #dfeef8 100%);
}
.feature-bike .tile-body{
  grid-column:1;
  grid-row:1;
  justify-content:center;
  padding:34px 34px 34px 36px;
}
.feature-bike .tile-media img{
  object-fit:contain !important;
  object-position:center center !important;
  background:transparent;
  box-shadow:none;
  border-radius:0;
  padding:0;
}
.feature-bike::before{
  width:280px;
  height:280px;
  left:-50px;
  bottom:-85px;
  background:radial-gradient(circle, rgba(255,255,255,.92) 0%, rgba(255,255,255,0) 72%);
}
.feature-bike::after{
  inset:auto 34px 20px auto;
  width:150px;
  height:150px;
  border-radius:28px;
  background:linear-gradient(135deg, rgba(255,255,255,.85), rgba(255,255,255,0));
  transform:rotate(18deg);
  opacity:.55;
}
.feature-bike h3{
  font-size:clamp(2.4rem, 4.6vw, 4rem);
  max-width:10ch;
}
.feature-bike p{
  max-width:34ch;
}
.feature-bike .eyebrow{
  background:rgba(255,255,255,.74);
}

/* make the other cards more expressive */
.tile-housing{
  background:linear-gradient(145deg,#faf7f2 0%, #ebe6de 100%);
}
.tile-housing::before{
  background:radial-gradient(circle, rgba(255,255,255,.88) 0%, rgba(255,255,255,0) 72%);
}
.tile-puma{
  background:linear-gradient(145deg,#edf2f6 0%, #dbe3ea 100%);
}
.tile-erdem{
  background:linear-gradient(145deg,#fbf2e8 0%, #eadbcb 100%);
}
.tile-housing .tile-media,
.tile-puma .tile-media,
.tile-erdem .tile-media{
  padding:18px;
}

/* apple-like motion */
.project-card{
  transition:
    transform .7s cubic-bezier(.22,1,.36,1),
    box-shadow .7s cubic-bezier(.22,1,.36,1),
    border-color .5s cubic-bezier(.22,1,.36,1),
    background .6s cubic-bezier(.22,1,.36,1);
}
.project-card:hover{
  transform:translateY(-14px) scale(1.012);
}
.project-card .tile-body{
  transition:transform .65s cubic-bezier(.22,1,.36,1);
}
.project-card:hover .tile-body{
  transform:translateY(-2px);
}
.project-card .eyebrow{
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.7),
    0 6px 16px rgba(0,0,0,.04);
}
.arrow span{
  position:relative;
}
.arrow span::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-1px;
  width:100%;
  height:1px;
  background:currentColor;
  transform-origin:left;
  transition:transform .45s cubic-bezier(.22,1,.36,1);
}
.project-card:hover .arrow span::after{
  transform:scaleX(1.06);
}

/* page polish */
.page-hero{
  background:
    radial-gradient(circle at 10% 10%, rgba(238,245,251,.8), transparent 28%),
    radial-gradient(circle at 90% 25%, rgba(248,235,223,.76), transparent 24%);
}
.media-frame{
  background:linear-gradient(180deg,#f7f4ef 0%, #efe7dd 100%);
}
.case-notes{
  gap:32px;
}
.case-notes div{
  padding-top:10px;
  position:relative;
}
.case-notes div::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:34px;
  height:2px;
  background:#111;
}

/* responsive */
@media(max-width:860px){
  .feature-bike{
    grid-column:auto;
    grid-template-columns:1fr;
    min-height:0;
  }
  .feature-bike .tile-media,
  .feature-bike .tile-body{
    grid-column:auto;
    grid-row:auto;
  }
  .feature-bike .tile-media{
    padding:18px;
  }
  .feature-bike .tile-body{
    padding:26px;
  }
  .feature-bike .tile-media img{
    border-radius:24px;
  }
}


/* ===== resume-focused about section ===== */
.about-resume .label{
  margin-bottom:30px;
}
.about-grid{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:54px;
  align-items:start;
}
.about-grid .about-copy{
  max-width:13ch;
}
.about-details{
  max-width:620px;
  display:grid;
  gap:18px;
  padding-top:6px;
}
.about-details p{
  font-size:1.04rem;
  color:#3f3933;
  line-height:1.7;
}
.about-tags{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.about-tags span{
  display:inline-flex;
  padding:9px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(0,0,0,.1);
  box-shadow:0 8px 22px rgba(0,0,0,.045);
  font-size:10px;
  letter-spacing:.13em;
  text-transform:uppercase;
  font-weight:800;
  color:#4d4741;
}

@media(max-width:860px){
  .about-grid{
    grid-template-columns:1fr;
    gap:26px;
  }
  .about-grid .about-copy{
    max-width:12ch;
  }
  .about-details{
    padding-top:0;
  }
}


/* ===== bold sans-serif font refresh ===== */
body{
  font-family:"Avenir Next","Segoe UI","Helvetica Neue",Arial,sans-serif !important;
}

.hero h1,
.display,
.page-title,
.project-title,
footer h2,
.project-card h3,
.entry h3,
.role,
.about-copy{
  font-family:"Avenir Next","Segoe UI","Helvetica Neue",Arial,sans-serif !important;
  font-weight:800 !important;
  letter-spacing:-.05em !important;
  font-style:normal !important;
}

.role{
  max-width:34ch;
  color:#2f2a25;
}

.project-card h3,
.project-title,
.page-title,
.display,
footer h2{
  line-height:.9 !important;
}

.kicker,
.label,
.eyebrow,
.id,
nav a,
.arrow,
.case-notes h3,
.project-actions a,
.back,
.play-badge,
.about-tags span,
.entry .when{
  font-family:"Avenir Next","Segoe UI","Helvetica Neue",Arial,sans-serif !important;
  font-weight:800 !important;
}

.project-copy,
.project-card p,
.about-details p,
.entry li,
.meta,
.meta a{
  font-family:"Avenir Next","Segoe UI","Helvetica Neue",Arial,sans-serif !important;
}

.about-copy{
  max-width:14ch;
}


/* ===== tighter layout pass ===== */
.wrap{
  width:min(1040px, calc(100% - 44px)) !important;
}

.bar{
  width:min(1040px, calc(100% - 44px)) !important;
  padding:12px 0 !important;
}

.hero{
  min-height:64vh !important;
  padding:54px 0 46px !important;
}

.hero h1{
  font-size:clamp(3.5rem, 9vw, 7rem) !important;
  margin:10px 0 10px !important;
  line-height:.86 !important;
}

.role{
  font-size:clamp(1rem, 1.7vw, 1.25rem) !important;
}

.meta{
  margin-top:18px !important;
  gap:14px !important;
}

section{
  padding:54px 0 !important;
}

.label{
  margin-bottom:18px !important;
}

.about-copy{
  font-size:clamp(1.9rem, 4.4vw, 3.6rem) !important;
}

.about-grid{
  gap:34px !important;
}

.about-details{
  gap:12px !important;
}

.about-details p{
  font-size:.98rem !important;
  line-height:1.58 !important;
}

.about-tags{
  margin-top:4px !important;
  gap:8px !important;
}

.about-tags span{
  padding:7px 10px !important;
}

.display{
  font-size:clamp(2.15rem, 5.6vw, 4.8rem) !important;
}

.project-index{
  gap:18px !important;
  margin-top:28px !important;
}

.project-card{
  min-height:350px !important;
  border-radius:28px !important;
}

.feature-bike{
  min-height:320px !important;
}

.tile-media{
  height:200px !important;
  padding:12px !important;
}

.feature-bike .tile-media{
  padding:16px 18px 16px 6px !important;
}

.tile-body{
  padding:20px 22px 22px !important;
}

.feature-bike .tile-body{
  padding:26px 26px 26px 30px !important;
}

.project-card .eyebrow{
  margin-bottom:9px !important;
  padding:7px 10px !important;
  font-size:10px !important;
}

.project-card h3{
  font-size:clamp(1.7rem, 2.9vw, 2.75rem) !important;
  margin-bottom:10px !important;
}

.feature-bike h3{
  font-size:clamp(2rem, 4vw, 3.35rem) !important;
}

.project-card p{
  font-size:.93rem !important;
  line-height:1.45 !important;
}

.arrow{
  padding-top:16px !important;
}

.page-hero{
  padding:54px 0 34px !important;
}

.back{
  margin-bottom:22px !important;
}

.page-title{
  font-size:clamp(2.65rem, 7.6vw, 5.8rem) !important;
  margin:12px 0 14px !important;
}

.project-layout{
  gap:38px !important;
}

.project-title{
  font-size:clamp(2rem, 4.7vw, 4.1rem) !important;
  margin:10px 0 12px !important;
}

.project-copy{
  font-size:.98rem !important;
  line-height:1.58 !important;
}

.project-actions{
  margin-top:20px !important;
  gap:16px !important;
}

.media-frame{
  padding:14px !important;
  border-radius:26px !important;
}

.media-frame img,
.media-frame video{
  border-radius:20px !important;
  max-height:560px !important;
}

.case-notes{
  gap:20px !important;
  margin-top:30px !important;
  padding-top:20px !important;
}

.case-notes p{
  font-size:.9rem !important;
  line-height:1.5 !important;
}

.gallery-row{
  gap:16px !important;
  margin-top:18px !important;
}

.gallery-row img{
  border-radius:20px !important;
}

.experience-list{
  gap:22px !important;
}

.entry{
  padding-top:20px !important;
}

.entry .head{
  margin-bottom:8px !important;
}

.entry h3{
  font-size:1.25rem !important;
}

.entry ul{
  gap:7px !important;
}

.entry li{
  font-size:.94rem !important;
  line-height:1.48 !important;
}

footer{
  padding:58px 0 !important;
}

footer h2{
  font-size:clamp(1.9rem, 5vw, 3.8rem) !important;
  margin-bottom:22px !important;
}

.contact a{
  padding:11px 18px !important;
}

.colophon{
  margin-top:22px !important;
}

@media(max-width:860px){
  .wrap,.bar{
    width:min(100% - 32px, 1040px) !important;
  }

  .hero{
    padding:48px 0 40px !important;
  }

  section{
    padding:46px 0 !important;
  }

  .project-index{
    gap:14px !important;
  }

  .tile-media{
    height:190px !important;
  }

  .feature-bike .tile-media{
    padding:12px !important;
  }

  .feature-bike .tile-body{
    padding:22px !important;
  }

  .project-layout,
  .about-grid,
  .case-notes,
  .gallery-row{
    gap:20px !important;
  }
}


/* ===== final bike tile + professional about fix ===== */
.feature-bike .tile-media,
.tile-bike .tile-media{
  display:grid !important;
  place-items:center !important;
  overflow:hidden !important;
}

.feature-bike .tile-media img,
.tile-bike .tile-media img{
  width:auto !important;
  height:100% !important;
  max-width:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#fff !important;
  border-radius:18px !important;
  padding:0 !important;
  box-shadow:0 18px 44px rgba(0,0,0,.12) !important;
}

.feature-bike .tile-media{
  background:linear-gradient(180deg,#eef6fb 0%,#e2edf6 100%) !important;
}

.about-details p{
  color:#37322d !important;
}


/* ===== bike tile full-page preview + favicon pass ===== */
.tile-bike.feature-bike .tile-media,
.tile-bike .tile-media{
  align-items:center !important;
  justify-items:center !important;
}

.tile-bike.feature-bike .tile-media img,
.tile-bike .tile-media img{
  width:auto !important;
  height:100% !important;
  max-width:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#fff !important;
  border-radius:18px !important;
  padding:0 !important;
  box-shadow:0 22px 55px rgba(0,0,0,.12) !important;
}

.tile-bike.feature-bike{
  min-height:340px !important;
}

.tile-bike.feature-bike .tile-media{
  padding:14px 18px 14px 8px !important;
  background:linear-gradient(180deg,#eef6fb 0%,#e2edf6 100%) !important;
}

.tile-bike.feature-bike .tile-body{
  padding:24px 24px 24px 28px !important;
}

@media(max-width:860px){
  .tile-bike.feature-bike .tile-media{
    padding:12px !important;
  }
}


/* ===== homepage name bounce intro ===== */
.bounce-name{
  display:flex;
  justify-content:center;
  align-items:baseline;
  flex-wrap:wrap;
  gap:0;
  overflow:visible;
}

.bounce-letter{
  display:inline-block;
  opacity:0;
  transform:translateY(34px) scale(.86);
  animation:nameBounceIn .72s cubic-bezier(.18, 1.35, .32, 1) forwards;
  animation-delay:calc(.12s + var(--i) * .045s);
  will-change:transform, opacity;
}

.bounce-space{
  display:inline-block;
  width:.18em;
}

@keyframes nameBounceIn{
  0%{
    opacity:0;
    transform:translateY(34px) scale(.86);
  }
  58%{
    opacity:1;
    transform:translateY(-10px) scale(1.045);
  }
  82%{
    transform:translateY(3px) scale(.99);
  }
  100%{
    opacity:1;
    transform:translateY(0) scale(1);
  }
}

@media(prefers-reduced-motion:reduce){
  .bounce-letter{
    animation:none!important;
    opacity:1!important;
    transform:none!important;
  }
}


/* ===== symmetrical balanced project tiles ===== */
.project-index{
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  gap:22px !important;
  margin-top:32px !important;
  align-items:stretch !important;
}

.project-card,
.feature-bike{
  grid-column:auto !important;
  display:flex !important;
  flex-direction:column !important;
  min-height:390px !important;
  height:100% !important;
  border-radius:30px !important;
}

.project-card .tile-media,
.feature-bike .tile-media{
  grid-column:auto !important;
  grid-row:auto !important;
  height:220px !important;
  padding:14px !important;
}

.project-card .tile-body,
.feature-bike .tile-body{
  grid-column:auto !important;
  grid-row:auto !important;
  padding:22px 24px 24px !important;
  justify-content:flex-start !important;
  flex:1 !important;
}

.project-card h3,
.feature-bike h3{
  font-size:clamp(1.85rem, 3vw, 2.9rem) !important;
  max-width:none !important;
  margin-bottom:10px !important;
}

.project-card p,
.feature-bike p{
  max-width:42ch !important;
}

.tile-bike .tile-media img{
  width:auto !important;
  height:100% !important;
  max-width:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#fff !important;
  border-radius:18px !important;
  box-shadow:0 18px 44px rgba(0,0,0,.12) !important;
}

.tile-erdem .tile-media{
  grid-template-columns:repeat(3, 1fr) !important;
  gap:8px !important;
}

.tile-erdem .tile-media img{
  height:100% !important;
  object-fit:cover !important;
}

.tile-housing .tile-media img,
.tile-puma .tile-media img{
  object-fit:cover !important;
}

.arrow{
  margin-top:auto !important;
  padding-top:18px !important;
}

@media(max-width:860px){
  .project-index{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }

  .project-card,
  .feature-bike{
    min-height:0 !important;
  }

  .project-card .tile-media,
  .feature-bike .tile-media{
    height:210px !important;
  }
}


/* ===== bike tile explicit image fix ===== */
.tile-bike .tile-media{
  background:#edf5fb !important;
  padding:12px !important;
}

.tile-bike .tile-media img{
  display:block !important;
  width:100% !important;
  height:100% !important;
  max-width:100% !important;
  max-height:100% !important;
  object-fit:contain !important;
  object-position:center center !important;
  background:#ffffff !important;
  border-radius:16px !important;
  padding:0 !important;
  box-shadow:0 16px 36px rgba(0,0,0,.10) !important;
}


/* ===== personal logo + favicon pass ===== */
.brandmark{
  display:inline-flex !important;
  align-items:center;
  gap:10px;
}

.brandmark-logo{
  width:28px;
  height:28px;
  object-fit:contain;
  display:block;
  border-radius:50%;
}

.brandmark span{
  display:inline-block;
  line-height:1;
}

.hero-logo-wrap{
  display:flex;
  justify-content:center;
  margin-bottom:14px;
}

.hero-logo{
  width:86px;
  height:86px;
  object-fit:contain;
  display:block;
  border-radius:50%;
  filter:drop-shadow(0 12px 24px rgba(0,0,0,.08));
}

@media(max-width:860px){
  .brandmark-logo{
    width:24px;
    height:24px;
  }
  .hero-logo{
    width:74px;
    height:74px;
  }
}




/* IMPORTANT: styles.css lives inside /assets, so the URL must be relative to that folder */
.logo-i-letter::before{
  content:"";
  position:absolute;
  left:50%;
  top:-0.38em;
  width:.5em;
  height:.5em;
  transform:translateX(-50%);
  background-image:url("personal-logo-transparent.png");
  background-position:center;
  background-repeat:no-repeat;
  background-size:contain;
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.08));
  pointer-events:none;
  z-index:2;
}

.brandmark-text .logo-i-letter{
  margin-right:.01em;
}

.bounce-name{
  display:flex;
  justify-content:center;
  align-items:flex-end;
  flex-wrap:wrap;
  gap:0;
  overflow:visible;
}

.bounce-name .logo-i-letter{
  padding-top:.2em;
}

.bounce-name .logo-i-letter::before{
  top:-0.34em;
  width:.52em;
  height:.52em;
}

@media(max-width:860px){
  .brandmark-logo{
    width:25px !important;
    height:25px !important;
  }
  .hero-logo{
    width:72px !important;
    height:72px !important;
  }

  .logo-i-letter::before{
    width:.48em;
    height:.48em;
  }
}


/* ===== normal name dots + logo styling ===== */
.brandmark-logo{
  width:30px !important;
  height:30px !important;
  object-fit:contain !important;
  border-radius:0 !important;
}

.hero-logo{
  width:84px !important;
  height:84px !important;
  object-fit:contain !important;
  border-radius:0 !important;
}

@media(max-width:860px){
  .brandmark-logo{
    width:25px !important;
    height:25px !important;
  }
  .hero-logo{
    width:72px !important;
    height:72px !important;
  }
}






/* ===== refined project tile system ===== */
.project-index{
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  gap:22px !important;
  margin-top:30px !important;
  align-items:stretch !important;
}

.project-card{
  position:relative !important;
  min-height:390px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-start !important;
  border-radius:28px !important;
  overflow:hidden !important;
  border:1px solid rgba(17,17,17,.08) !important;
  box-shadow:0 10px 28px rgba(0,0,0,.055) !important;
  transition:
    transform .45s cubic-bezier(.22,1,.36,1),
    box-shadow .45s cubic-bezier(.22,1,.36,1),
    border-color .45s cubic-bezier(.22,1,.36,1) !important;
}

.project-card::before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,0) 34%) !important;
  pointer-events:none !important;
  z-index:0 !important;
}

.project-card::after{
  display:none !important;
  content:none !important;
}

.project-card:hover{
  transform:translateY(-7px) !important;
  box-shadow:0 22px 54px rgba(0,0,0,.10) !important;
  border-color:rgba(17,17,17,.12) !important;
}

.tile-bike{
  background:linear-gradient(180deg, #efe1be 0%, #e8d7b2 100%) !important;
}
.tile-housing{
  background:linear-gradient(180deg, #f7f3ee 0%, #ece3d8 100%) !important;
}
.tile-erdem{
  background:linear-gradient(180deg, #fbf4eb 0%, #eadccc 100%) !important;
}
.tile-puma{
  background:linear-gradient(180deg, #edf2f5 0%, #dee5ea 100%) !important;
}

.project-card .tile-media{
  position:relative !important;
  height:222px !important;
  padding:18px !important;
  display:grid !important;
  place-items:center !important;
  background:transparent !important;
  z-index:1 !important;
}

.project-card .tile-media img,
.project-card .tile-media video{
  display:block !important;
  width:100% !important;
  height:100% !important;
  border-radius:18px !important;
  background:rgba(255,255,255,.86) !important;
  box-shadow:0 16px 38px rgba(0,0,0,.10) !important;
  transition:
    transform .6s cubic-bezier(.22,1,.36,1),
    box-shadow .6s cubic-bezier(.22,1,.36,1) !important;
}

.project-card:hover .tile-media img,
.project-card:hover .tile-media video{
  transform:scale(1.025) !important;
  box-shadow:0 22px 48px rgba(0,0,0,.13) !important;
}

.tile-bike .tile-media{
  padding:16px !important;
}
.tile-bike .tile-media img{
  object-fit:contain !important;
  object-position:center center !important;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:0 !important;
}

.tile-housing .video-thumb,
.tile-puma .video-thumb{
  position:relative !important;
  width:100% !important;
  height:100% !important;
}
.tile-housing .video-thumb img,
.tile-puma .video-thumb img{
  object-fit:cover !important;
  object-position:center center !important;
}

.tile-erdem .tile-media{
  grid-template-columns:repeat(3, minmax(0,1fr)) !important;
  gap:10px !important;
  align-items:end !important;
}
.tile-erdem .tile-media img{
  height:100% !important;
  object-fit:cover !important;
}
.tile-erdem .tile-media img:nth-child(1){
  transform:translateY(8px) !important;
}
.tile-erdem .tile-media img:nth-child(2){
  transform:translateY(-8px) !important;
}
.tile-erdem .tile-media img:nth-child(3){
  transform:translateY(12px) !important;
}
.project-card:hover.tile-erdem .tile-media img:nth-child(1){
  transform:translateY(4px) scale(1.02) !important;
}
.project-card:hover.tile-erdem .tile-media img:nth-child(2){
  transform:translateY(-12px) scale(1.03) !important;
}
.project-card:hover.tile-erdem .tile-media img:nth-child(3){
  transform:translateY(8px) scale(1.02) !important;
}

.tile-body{
  position:relative !important;
  z-index:1 !important;
  display:flex !important;
  flex-direction:column !important;
  flex:1 !important;
  padding:20px 22px 22px !important;
}

.project-card .eyebrow{
  display:inline-flex !important;
  align-items:center !important;
  width:max-content !important;
  margin-bottom:12px !important;
  padding:7px 11px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.58) !important;
  backdrop-filter:blur(8px) !important;
  -webkit-backdrop-filter:blur(8px) !important;
  color:#5d554c !important;
  font-size:10px !important;
  letter-spacing:.12em !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65) !important;
}

.project-card h3{
  font-size:clamp(1.8rem, 2.9vw, 2.6rem) !important;
  line-height:.94 !important;
  margin-bottom:10px !important;
  color:#111 !important;
  letter-spacing:-.045em !important;
}

.project-card p{
  font-size:.95rem !important;
  line-height:1.5 !important;
  color:#4d463e !important;
  max-width:40ch !important;
}

.arrow{
  margin-top:auto !important;
  padding-top:16px !important;
  font-size:10px !important;
  letter-spacing:.13em !important;
  color:#111 !important;
}
.arrow span{
  position:relative !important;
  padding-right:15px !important;
}
.arrow span::after{
  content:"→" !important;
  position:absolute !important;
  right:0 !important;
  top:50% !important;
  transform:translateY(-52%) !important;
  transition:transform .3s cubic-bezier(.22,1,.36,1) !important;
}
.project-card:hover .arrow span::after{
  transform:translate(4px,-52%) !important;
}

.play-badge{
  position:absolute !important;
  left:14px !important;
  bottom:14px !important;
  padding:8px 11px !important;
  border-radius:999px !important;
  background:rgba(17,17,17,.82) !important;
  color:#fff !important;
  font-size:9px !important;
  letter-spacing:.13em !important;
  text-transform:uppercase !important;
  box-shadow:0 8px 18px rgba(0,0,0,.15) !important;
}
.play-badge::before{
  content:"▶" !important;
  margin-right:7px !important;
}

@media(max-width:860px){
  .project-index{
    grid-template-columns:1fr !important;
    gap:16px !important;
  }
  .project-card{
    min-height:0 !important;
  }
  .project-card .tile-media{
    height:205px !important;
    padding:14px !important;
  }
  .tile-body{
    padding:18px 18px 20px !important;
  }
}




/* ===== final project tile CTA fix ===== */
.project-card .arrow,
.project-card .arrow *,
.project-card .arrow span,
.project-card .arrow .tile-cta-label{
  text-decoration:none !important;
  box-shadow:none !important;
}

.project-card .arrow{
  display:block !important;
  margin-top:auto !important;
  padding-top:18px !important;
  line-height:1 !important;
  border:0 !important;
}

.project-card .arrow::before,
.project-card .arrow::after,
.project-card .arrow span::before{
  content:none !important;
  display:none !important;
}

.project-card .arrow span,
.project-card .arrow .tile-cta-label{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:8px !important;
  width:auto !important;
  white-space:nowrap !important;
  padding:10px 14px !important;
  border:1px solid rgba(17,17,17,.12) !important;
  border-bottom:1px solid rgba(17,17,17,.12) !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.84) !important;
  color:#111 !important;
  font-size:10px !important;
  letter-spacing:.12em !important;
  text-transform:uppercase !important;
  font-weight:800 !important;
  position:relative !important;
}

.project-card .arrow span::after,
.project-card .arrow .tile-cta-label::after{
  content:"→" !important;
  position:static !important;
  transform:none !important;
  margin-left:2px !important;
  transition:transform .25s cubic-bezier(.22,1,.36,1) !important;
}

.project-card:hover .arrow span::after,
.project-card:hover .arrow .tile-cta-label::after{
  transform:translateX(3px) !important;
}

.project-card .arrow span{
  padding-right:14px !important;
}

.project-card:hover .arrow span,
.project-card:hover .arrow .tile-cta-label{
  background:#fff !important;
  border-color:rgba(17,17,17,.16) !important;
}

/* kill older underline styles that may still be applying */
.arrow span{
  border-bottom:none !important;
  padding-bottom:10px !important;
}


/* ===== restored website logo ===== */
.brandmark{
  display:inline-flex !important;
  align-items:center !important;
  gap:10px !important;
}

.brandmark-logo{
  width:30px !important;
  height:30px !important;
  object-fit:contain !important;
  display:block !important;
  border-radius:0 !important;
}

.brandmark span{
  display:inline-block !important;
  line-height:1 !important;
}

@media(max-width:860px){
  .brandmark-logo{
    width:25px !important;
    height:25px !important;
  }
}


/* ===== front page hero logo ===== */
.front-page-logo-wrap{
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
  margin-bottom:18px !important;
}

.front-page-logo{
  width:92px !important;
  height:92px !important;
  object-fit:contain !important;
  display:block !important;
  border-radius:0 !important;
  filter:drop-shadow(0 14px 24px rgba(0,0,0,.08)) !important;
}

@media(max-width:860px){
  .front-page-logo{
    width:76px !important;
    height:76px !important;
  }
}
