/* ============================================================
   canelmasmimarlık — mimari portfolyo
   Beyaz · mineral · fotoğraf öncelikli · scroll-yolculuğu
   Archivo (tek aile, güçlü ağırlık kontrastı). Serif/italik/mono YOK.
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-2:#F6F6F5;
  --carbon:#141817;
  --bone:#EDEBE4;
  --ink:#1A1E1F;
  --ink-2:#3f4546;
  --gray:#6c706e;
  --slate:#425967;
  --violet:#76689B;
  --line:#E7E6E3;
  --line-d:rgba(237,235,228,.14);
  --disp:'Archivo', system-ui, sans-serif;
  --e:cubic-bezier(.22,1,.36,1);
  --maxw:1440px;
  --pad:clamp(1.4rem,4vw,4.5rem);
  --rail:max(1.4rem,2.4vw);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{font-family:var(--disp);background:var(--bg);color:var(--ink);font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--ink);color:#fff}
h1,h2,h3,h4{font-weight:700;line-height:.98;letter-spacing:-.04em;color:var(--ink);text-wrap:balance}
p{text-wrap:pretty}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
section{position:relative}

/* ============ HEADER ============ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:70;padding:1.9rem 0;transition:background .5s var(--e),padding .45s var(--e)}
.site-header.stuck{background:rgba(255,255,255,.94);backdrop-filter:blur(16px);padding:1rem 0;box-shadow:0 1px 0 var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.brand{display:inline-flex;align-items:center}
.brand img{height:64px;width:auto;display:block;transition:height .45s var(--e);filter:drop-shadow(0 8px 26px rgba(0,0,0,.32))}
.stuck .brand{}
.stuck .brand img{height:48px}
.ham{display:flex;flex-direction:column;align-items:flex-end;gap:7px;background:none;border:0;cursor:pointer;padding:.5rem 0;width:46px}
.ham span{height:2px;background:#fff;display:block;transition:width .4s var(--e),background .4s var(--e)}
.ham span:nth-child(1){width:46px}.ham span:nth-child(2){width:30px}
.site-header.stuck .ham span{background:var(--ink)}
.ham:hover span:nth-child(2){width:46px}

/* ============ HERO ============ */
.hero{height:100vh;min-height:600px;position:relative;overflow:hidden;display:flex;align-items:flex-end;background:var(--carbon)}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,12,12,.62) 0%,rgba(10,12,12,.14) 15%,transparent 34%,rgba(10,12,12,.5) 64%,rgba(10,12,12,.9) 100%),linear-gradient(78deg,rgba(10,12,12,.55) 0%,rgba(10,12,12,.12) 42%,transparent 60%)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(4.5rem,8vw,7rem)}
.hero-line{color:#fff;font-size:clamp(2.4rem,6vw,5.4rem);font-weight:700;line-height:.98;letter-spacing:-.045em;max-width:17ch;text-shadow:0 2px 50px rgba(0,0,0,.55),0 1px 12px rgba(0,0,0,.4);animation:rise 1s var(--e) .15s both}
.hero-sub{color:rgba(255,255,255,.9);font-size:clamp(1rem,1.35vw,1.2rem);max-width:46ch;margin-top:1.7rem;line-height:1.55;text-shadow:0 1px 16px rgba(0,0,0,.5);animation:rise 1s var(--e) .35s both}
@keyframes rise{from{transform:translateY(24px)}to{transform:none}}
.hero-rule{position:absolute;left:0;right:0;bottom:3.1rem;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.hero-rule i{display:block;height:1px;background:rgba(255,255,255,.24);transform-origin:left;transform:scaleX(0);animation:ruleIn 1.2s var(--e) .7s forwards;position:relative}
.hero-rule i::before{content:'';position:absolute;left:0;top:-1px;height:3px;width:62px;background:var(--violet)}
@keyframes ruleIn{to{transform:scaleX(1)}}
.hero-foot{position:absolute;left:0;right:0;bottom:1.4rem;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad);display:flex;justify-content:space-between;gap:1rem;color:rgba(255,255,255,.72);font-size:.74rem;letter-spacing:.04em}
.hero-foot b{color:#fff;font-weight:600}
/* dönen 25 yıl mührü */
.seal{position:absolute;right:clamp(1.4rem,4vw,4.5rem);bottom:clamp(5rem,9vw,7.5rem);z-index:3;width:clamp(80px,7.7vw,106px);height:clamp(80px,7.7vw,106px);pointer-events:none}
.seal::before{content:'';position:absolute;inset:0;border:1px solid rgba(255,255,255,.2);border-radius:50%}
.seal::after{content:'';position:absolute;inset:8px;border:1px solid rgba(255,255,255,.09);border-radius:50%}
.seal-svg{position:absolute;inset:0;width:100%;height:100%;animation:spin 32s linear infinite}
.seal-svg .st{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:.04em;fill:rgba(255,255,255,.58);text-transform:uppercase}.seal-svg .sstar{font-size:11px;fill:rgba(255,255,255,.4)}
.seal-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center}
.seal-c b{font-size:clamp(1.25rem,1.8vw,1.7rem);font-weight:700;line-height:.85;letter-spacing:-.03em;color:rgba(255,255,255,.82)}
.seal-c span{font-size:.5rem;letter-spacing:.3em;margin-top:.15rem;color:rgba(255,255,255,.55)}
@keyframes spin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.seal-svg{animation:none}}
@media(max-width:680px){.seal{display:none}}

/* ============ KESİT RAYI — scroll yolculuğu ============ */
.rail{position:fixed;left:var(--rail);top:0;height:100vh;width:1px;z-index:45;pointer-events:none}
.rail::before{content:'';position:absolute;inset:0;background:var(--line)}
.rail .fill{position:absolute;top:0;left:-1px;width:3px;height:100%;background:var(--violet);transform:scaleY(var(--p,0));transform-origin:top;transition:transform .12s linear}
.rail .dot{position:absolute;left:-4px;width:9px;height:9px;border-radius:50%;background:var(--violet);top:calc(var(--p,0) * 100%);transform:translateY(-50%);box-shadow:0 0 0 5px rgba(118,104,155,.16)}
.rail .cap{position:absolute;left:14px;top:calc(var(--p,0) * 100%);transform:translateY(-50%);white-space:nowrap;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slate);font-weight:600}
.rail.on-dark::before{background:var(--line-d)}.rail.on-dark .cap{color:var(--bone)}
@media(max-width:900px){.rail{display:none}}

/* shared section heads (no eyebrow / no numbers — düz) */
.sec{padding:clamp(5rem,11vw,11rem) 0}
.sec-title{font-size:clamp(2.2rem,5vw,4.4rem);font-weight:700;letter-spacing:-.04em;line-height:.98;max-width:18ch}
.sec-kick{font-size:clamp(1rem,1.3vw,1.18rem);color:var(--gray);max-width:52ch;margin-top:1.4rem;line-height:1.6}

/* ============ ORIGINS — ekolojik kök (scroll timeline) ============ */
.origins{background:var(--carbon);color:var(--bone);padding:clamp(5rem,11vw,11rem) 0;overflow:hidden}
.origins .og-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.origins .og-lead{position:sticky;top:18vh}
.origins .og-lead h2{color:#fff;font-size:clamp(2rem,4.4vw,3.8rem)}
.origins .og-lead p{color:rgba(237,235,228,.62);font-size:1.05rem;line-height:1.7;margin-top:1.5rem;max-width:36ch}
.origins .og-lead .mark{margin-top:2rem;font-size:.8rem;letter-spacing:.04em;color:var(--violet);font-weight:600}
.tl{position:relative;padding-left:clamp(2rem,4vw,3.4rem)}
.tl .spine{position:absolute;left:0;top:.6rem;bottom:.6rem;width:1px;background:var(--line-d)}
.tl .spine i{position:absolute;inset:0;background:var(--violet);transform:scaleY(var(--tp,0));transform-origin:top}
.tl-item{padding:clamp(2rem,4vw,3.2rem) 0;border-bottom:1px solid var(--line-d);position:relative}
.tl-item:first-child{padding-top:0}.tl-item:last-child{border-bottom:0}
.tl-item::before{content:'';position:absolute;left:calc(clamp(2rem,4vw,3.4rem) * -1 - .5px);top:calc(clamp(2rem,4vw,3.2rem) + .2rem);width:11px;height:11px;border-radius:50%;background:var(--carbon);border:2px solid var(--violet);transform:translateX(-5px)}
.tl-item:first-child::before{top:.2rem}
.tl-item .yr{font-size:clamp(2rem,4vw,3.2rem);font-weight:700;letter-spacing:-.03em;color:#fff;line-height:1}
.tl-item h3{color:#fff;font-size:1.35rem;margin-top:.6rem;font-weight:600;letter-spacing:-.02em}
.tl-item p{color:rgba(237,235,228,.6);font-size:1rem;line-height:1.65;margin-top:.6rem;max-width:44ch}

/* ============ WORKS — stacking scroll cards ============ */
.works{padding:clamp(5rem,11vw,11rem) 0 0}
.works .head{margin-bottom:clamp(1.5rem,3vw,2.5rem)}
.cards{position:relative}
.cardp{position:sticky;top:0;height:100vh;min-height:540px;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.cardp .cinner{width:min(92vw,940px)}
.cardp .cframe{position:relative;overflow:hidden;aspect-ratio:16/10;background:#e9e9e7}
.cardp .cimg{width:100%;height:100%;object-fit:cover;will-change:transform}
.cardp .ccap{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-top:1.2rem;flex-wrap:wrap}
.cardp .cnm{color:var(--ink);font-size:clamp(1.4rem,2.4vw,2.1rem);font-weight:700;letter-spacing:-.03em;line-height:1}
.cardp .cmt{color:var(--gray);font-size:.95rem;margin-top:.55rem;letter-spacing:.01em}
.cardp .cmt .aw{color:var(--violet);font-weight:600}
.cardp .cmt .d{color:var(--violet);margin:0 .45rem;font-weight:700}
.cardp .cidx{color:var(--gray);font-size:.9rem;white-space:nowrap}
.cardp .cidx b{font-size:1.15rem;font-weight:700;color:var(--ink)}
@media(max-width:680px){.cardp .cframe{aspect-ratio:4/3}.cardp .ccap{gap:.4rem}}

/* ============ APPROACH — solda yazı, sağda accordion ============ */
.approach{background:var(--bg-2);padding:clamp(5rem,11vw,11rem) 0;border-top:1px solid var(--line)}
.ap-wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,5vw,5.5rem);align-items:center}
.ap-left h2{font-size:clamp(2rem,4vw,3.6rem);line-height:1}
.ap-detail{margin-top:clamp(1.8rem,3vw,2.6rem);max-width:42ch}
.ad-t{font-size:clamp(1.4rem,2.2vw,2rem);font-weight:700;letter-spacing:-.03em;color:var(--ink);line-height:1;transition:opacity .3s var(--e)}
.ad-d{color:var(--ink-2);font-size:clamp(1rem,1.15vw,1.08rem);line-height:1.65;margin-top:.9rem;transition:opacity .3s var(--e)}
.ad-en{display:block;font-style:italic;color:var(--violet);font-weight:600;margin-top:1.1rem;font-size:.9rem;letter-spacing:.02em}
.ap-acc{display:flex;gap:.55rem;height:clamp(380px,48vh,480px)}
.ap-acc .p{position:relative;flex:1 1 0;flex-grow:1;min-width:52px;background:var(--carbon);border-radius:16px;overflow:hidden;cursor:pointer;transition:flex-grow .6s var(--e)}
.ap-acc .p.active{flex-grow:5}
.ap-acc .p img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.3;transition:opacity .6s var(--e)}
.ap-acc .p.active img{opacity:.6}
.ap-acc .p::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(10,12,12,.18) 0%,transparent 42%,rgba(10,12,12,.72) 100%)}
.ap-acc .pt{position:absolute;z-index:2;color:#fff;font-weight:600;white-space:nowrap;transition:left .5s var(--e),bottom .5s var(--e),font-size .5s var(--e);text-shadow:0 1px 12px rgba(0,0,0,.55);bottom:1.4rem;left:50%;transform:translateX(-50%) rotate(180deg);writing-mode:vertical-rl;font-size:1rem}
.ap-acc .p.active .pt{writing-mode:horizontal-tb;transform:none;left:1.5rem;bottom:1.5rem;font-size:1.2rem}
@media(max-width:860px){
  .ap-wrap{grid-template-columns:1fr;gap:2.5rem}
  .ap-acc{height:clamp(300px,52vw,400px)}
}

/* ============ AWARDS — sinematik sahne ============ */
.awards{position:relative;background:var(--carbon);color:var(--bone);padding:clamp(6rem,13vw,12rem) 0;overflow:hidden}
.aw-bg{position:absolute;inset:0;z-index:0;pointer-events:none;background:radial-gradient(120% 75% at 50% -5%,rgba(118,104,155,.26),transparent 55%),radial-gradient(85% 60% at 82% 105%,rgba(66,89,103,.34),transparent 60%)}
.aw-draw{position:absolute;inset:0;z-index:0;width:100%;height:100%;pointer-events:none;color:#EDEBE4;opacity:.16;-webkit-mask-image:radial-gradient(ellipse 75% 85% at 50% 45%,#000 6%,transparent 78%);mask-image:radial-gradient(ellipse 75% 85% at 50% 45%,#000 6%,transparent 78%)}.aw-draw svg{width:100%;height:100%}
.aw-grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.aw-inner{position:relative;z-index:2}
.aw-head{text-align:center;font-size:clamp(2.4rem,6vw,5rem);font-weight:700;letter-spacing:-.045em;line-height:.95;color:#fff}
.aw-flag{text-align:center;max-width:34ch;margin:clamp(3rem,6vw,5rem) auto clamp(2.6rem,5vw,4rem);position:relative;z-index:2}
.aw-flag .ff{font-size:clamp(2rem,4.6vw,3.7rem);font-weight:700;letter-spacing:-.04em;line-height:1;color:#fff}
.aw-flag .ff em{color:#C7B9E6;font-style:normal}
.aw-flag .fs{font-size:clamp(.95rem,1.2vw,1.1rem);color:rgba(237,235,228,.68);margin-top:1.2rem;line-height:1.55}
.aw-row{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line-d);max-width:1080px;margin:0 auto;position:relative;z-index:2}
.aw-col{padding:clamp(1.7rem,2.6vw,2.4rem) clamp(.9rem,1.8vw,1.5rem);border-right:1px solid var(--line-d);text-align:center}
.aw-col:last-child{border-right:0}
.aw-col .y{display:block;font-size:1.7rem;font-weight:700;color:#C7B9E6;letter-spacing:-.02em;line-height:1}
.aw-col .t{display:block;font-size:.96rem;font-weight:600;color:#fff;margin-top:.7rem;line-height:1.25}
.aw-col .s{display:block;font-size:.8rem;color:rgba(237,235,228,.55);margin-top:.4rem;line-height:1.4}
@media(max-width:760px){
  .aw-row{grid-template-columns:repeat(2,1fr)}
  .aw-col:nth-child(2n){border-right:0}
  .aw-col:nth-child(-n+2){border-bottom:1px solid var(--line-d)}
}

/* ============ CLIENTS — isim duvarı ============ */
.clients{padding:clamp(4rem,9vw,8rem) 0}
.clients .ch{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:clamp(1.8rem,3.5vw,3rem)}
.clients .ch h2{font-size:clamp(1.8rem,3.6vw,3rem);font-weight:700;letter-spacing:-.035em}
.clients .ch p{color:var(--gray);max-width:34ch;font-size:1rem;line-height:1.55}
.cl-grid{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.cl-grid .cell{border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:center;text-align:center;padding:1rem;min-height:clamp(96px,11vw,150px);font-size:clamp(1.05rem,1.7vw,1.55rem);font-weight:600;letter-spacing:-.02em;color:var(--ink-2);transition:background .45s var(--e),color .45s var(--e)}
.cl-grid .cell:hover{background:var(--carbon);color:#fff}
@media(max-width:780px){.cl-grid{grid-template-columns:repeat(2,1fr)}}

/* ============ CONTACT (final, koyu) ============ */
.contact{background:var(--carbon);color:var(--bone);padding:clamp(6rem,12vw,12rem) 0;overflow:hidden}
.contact .big{font-size:clamp(2.8rem,8vw,7rem);font-weight:700;letter-spacing:-.045em;line-height:.92;color:#fff}
.contact .sub{color:rgba(237,235,228,.62);font-size:1.15rem;margin:2rem 0 3rem;max-width:40ch;line-height:1.6}
.contact .cbtn{display:inline-flex;align-items:center;gap:.9rem;background:#fff;color:var(--carbon);padding:1.15rem 2.2rem;font-size:.98rem;font-weight:600;transition:.4s var(--e)}
.contact .cbtn:hover{background:var(--violet);color:#fff}
.contact .cbtn .ar{transition:transform .4s var(--e)}.contact .cbtn:hover .ar{transform:translateX(6px)}
.contact .cgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:start}
.cinfo{display:grid;gap:0}
.cinfo .row{padding:1.3rem 0;border-top:1px solid var(--line-d)}
.cinfo .k{color:var(--violet);font-size:.74rem;letter-spacing:.04em;margin-bottom:.5rem;font-weight:600}
.cinfo .v{font-size:1.08rem;color:var(--bone);line-height:1.5;display:block}
.cinfo a.v:hover{color:#fff}

/* ============ FOOTER ============ */
.site-footer{background:var(--carbon);color:rgba(237,235,228,.5);padding:0 0 2.5rem;border-top:1px solid var(--line-d)}
.foot-top{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:2.5rem 0}
.foot-top img{height:54px}
.foot-top .soc{display:flex;gap:1.8rem}
.foot-top .soc a{font-size:.9rem;color:rgba(237,235,228,.6);transition:.3s}
.foot-top .soc a:hover{color:#fff}
.foot-copy{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.82rem;color:rgba(237,235,228,.4);border-top:1px solid var(--line-d);padding-top:2rem}

/* ============ MENU — tam ekran ============ */
.menu-ov{position:fixed;inset:0;z-index:80;background:var(--carbon);color:var(--bone);opacity:0;pointer-events:none;transition:opacity .55s var(--e);display:flex;flex-direction:column;overflow-y:auto}
.menu-ov.open{opacity:1;pointer-events:auto}
.menu-ov.snap{transition:none}
.menu-top{display:flex;align-items:center;justify-content:space-between;padding:1.9rem var(--pad)}
.menu-top img{height:58px}
.menu-x{background:none;border:0;color:var(--bone);cursor:pointer;width:46px;height:30px;position:relative}
.menu-x span{height:2px;width:42px;background:var(--bone);display:block;position:absolute;top:14px;transition:.4s var(--e)}
.menu-x span:first-child{transform:rotate(45deg)}.menu-x span:last-child{transform:rotate(-45deg)}
.menu-x:hover span{background:var(--violet)}
.menu-body{flex:1;display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:var(--maxw);margin:0 auto;width:100%;padding:clamp(2rem,4vw,4rem) var(--pad) clamp(3rem,6vw,5rem)}
.menu-nav a{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:baseline;padding:clamp(.55rem,1.5vw,1.05rem) 0;border-top:1px solid var(--line-d);font-size:clamp(2rem,5.2vw,4.2rem);font-weight:600;letter-spacing:-.04em;color:var(--bone);transition:padding .4s var(--e),color .4s var(--e)}
.menu-nav a:last-child{border-bottom:1px solid var(--line-d)}
.menu-nav a .x{font-size:.85rem;font-weight:600;color:var(--violet);transform:translateY(-.6em)}
.menu-nav a:hover{padding-left:1.2rem;color:#fff}
.menu-side{align-self:center}
.menu-side .blk{margin-bottom:1.9rem}
.menu-side .lab{font-size:.74rem;letter-spacing:.04em;color:var(--violet);margin-bottom:.6rem;font-weight:600}
.menu-side .val{font-size:1.08rem;color:var(--bone);line-height:1.5;display:block}
.menu-side a.val+a.val{margin-top:.25rem}.menu-side a.val:hover{color:#fff}
.menu-side .soc{display:flex;gap:.7rem;margin-top:.5rem}
.menu-side .soc a{width:40px;height:40px;border:1px solid var(--line-d);color:var(--bone);display:flex;align-items:center;justify-content:center;transition:.35s var(--e)}
.menu-side .soc a:hover{background:var(--violet);border-color:var(--violet);color:#fff}
.menu-side .soc svg{width:15px;height:15px}
@media(max-width:860px){.menu-body{grid-template-columns:1fr;gap:2.4rem;align-items:start}.menu-side{align-self:start}}

/* ============ REVEAL (görünür-güvenli) ============ */
.js .reveal{opacity:0;filter:blur(14px);transition:opacity .9s var(--e),filter .9s var(--e)}.js .works .reveal{filter:none}
.js .reveal.in{opacity:1;filter:blur(0)}
.js .reveal[data-d="1"]{transition-delay:.1s}.js .reveal[data-d="2"]{transition-delay:.2s}.js .reveal[data-d="3"]{transition-delay:.3s}

@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;filter:none;transition:none}
  .hero-line,.hero-sub,.hero-rule i{animation:none;transform:none}
  .work .ph img{height:100%}
}

/* ============ RESPONSIVE ============ */
@media(max-width:980px){
  .origins .og-grid{grid-template-columns:1fr;gap:2.5rem}.origins .og-lead{position:static}
  .ap{grid-template-columns:1fr;gap:1rem}
  .contact .cgrid{grid-template-columns:1fr;gap:2.5rem}
}
@media(max-width:680px){
  .hero{height:90vh;min-height:520px}
  .brand img{height:50px}
  .work-row{grid-template-columns:1fr;gap:0}.work-row .work{margin-bottom:clamp(3rem,9vw,4rem)}.work-row .ph{aspect-ratio:4/3}
  .work-cap{flex-direction:column;gap:.3rem}.work-cap .mt{text-align:left}
  .aw{grid-template-columns:3.6rem 1fr;gap:1rem}.aw .pl{display:none}
  .aw-major{grid-template-columns:1fr;gap:1rem}
  .foot-top{flex-direction:column;align-items:flex-start;gap:1.4rem}
}

/* buharlı reveal */
.js .vapor{opacity:0;filter:blur(18px);transition:opacity 1.2s var(--e),filter 1.2s var(--e)}
.js .vapor.in{opacity:1;filter:blur(0)}
.js .vapor[data-d="1"]{transition-delay:.14s}.js .vapor[data-d="2"]{transition-delay:.28s}.js .vapor[data-d="3"]{transition-delay:.42s}.js .vapor[data-d="4"]{transition-delay:.56s}
@media(prefers-reduced-motion:reduce){.js .vapor{opacity:1;filter:none}}

/* erişilebilirlik + scroll ipucu */
a:focus-visible,button:focus-visible{outline:2px solid var(--violet);outline-offset:3px}
.scroll-cue{position:absolute;left:50%;bottom:4.6rem;transform:translateX(-50%);z-index:3;width:1px;height:46px;background:rgba(255,255,255,.18);overflow:hidden}
.scroll-cue i{position:absolute;left:0;top:0;width:100%;height:45%;background:#fff;animation:scrolly 1.9s cubic-bezier(.5,0,.5,1) infinite}
@keyframes scrolly{0%{transform:translateY(-110%)}100%{transform:translateY(240%)}}
@media(prefers-reduced-motion:reduce){.scroll-cue i{animation:none;height:100%;opacity:.35}}
@media(max-width:680px){.scroll-cue{display:none}}
@media(max-width:680px){.brand img{height:52px}}

/* ============ EKİP ============ */
.team{padding:clamp(5rem,11vw,11rem) 0}
.team-head{max-width:62ch}
.team-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2.5rem,5vw,5.5rem);align-items:start;margin-top:clamp(2.4rem,5vw,4rem);border-top:1px solid var(--line);padding-top:clamp(2.4rem,5vw,4rem)}
.tm-role{font-size:.78rem;letter-spacing:.04em;color:var(--violet);font-weight:600;margin-bottom:.6rem}
.tm-name{font-size:clamp(2rem,3.6vw,3rem);font-weight:700;letter-spacing:-.03em;color:var(--ink);line-height:1}
.tm-bio{color:var(--ink-2);font-size:1.06rem;line-height:1.7;margin-top:1.3rem;max-width:50ch}
.tm-langs{margin-top:1.3rem;font-size:.84rem;color:var(--gray);letter-spacing:.02em}
.tm-consultant{padding-bottom:1.7rem;border-bottom:1px solid var(--line);margin-bottom:1.5rem}
.tm-name2{font-size:1.45rem;font-weight:700;letter-spacing:-.02em;color:var(--ink);margin-top:.25rem}
.tm-bio2{color:var(--gray);font-size:.95rem;line-height:1.6;margin-top:.7rem}
.tm-list{list-style:none}
.tm-list li{display:flex;justify-content:space-between;gap:1rem;padding:.95rem 0;border-bottom:1px solid var(--line)}
.tm-list li:first-child{border-top:1px solid var(--line)}
.tm-list .nm{font-weight:600;color:var(--ink);font-size:1.02rem}
.tm-list .rl{color:var(--gray);font-size:.9rem;text-align:right;align-self:center}
@media(max-width:860px){.team-grid{grid-template-columns:1fr;gap:2.5rem}}

/* ============ İLETİŞİM FORMU ============ */
.cform{display:grid;gap:.8rem}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.cform input,.cform textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--line-d);color:#fff;font-family:var(--disp);font-size:.98rem;padding:.95rem 1.1rem;outline:none;transition:border .3s var(--e),background .3s var(--e)}
.cform input::placeholder,.cform textarea::placeholder{color:rgba(237,235,228,.45)}
.cform input:focus,.cform textarea:focus{border-color:var(--violet);background:rgba(118,104,155,.12)}
.cform textarea{resize:none;min-height:128px}
.cform button{margin-top:.3rem;background:#fff;color:var(--carbon);border:0;cursor:pointer;padding:1.15rem;font-family:var(--disp);font-size:.95rem;font-weight:600;transition:.4s var(--e);display:inline-flex;align-items:center;justify-content:center;gap:.6rem}
.cform button:hover{background:var(--violet);color:#fff}
.cform button .ar{transition:transform .4s var(--e)}.cform button:hover .ar{transform:translateX(5px)}
.cf-note{font-size:.76rem;color:rgba(237,235,228,.45);text-align:center;margin-top:.3rem}
.cf-done{padding:2.5rem 1rem;text-align:center;color:#fff;font-size:1.25rem;font-weight:600;line-height:1.4}
.cf-done span{display:block;font-weight:400;color:rgba(237,235,228,.6);font-size:.95rem;margin-top:.5rem}
@media(max-width:860px){.cf-row{grid-template-columns:1fr}}
/* ============ LENIS (akıcı scroll — önerilen reset) ============ */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}
.lenis.lenis-stopped{overflow:hidden}
.lenis.lenis-smooth iframe{pointer-events:none}