:root {
  --ink: #102a43;
  --ink-deep: #071c2d;
  --ink-soft: #243b53;
  --paper: #fbf8f2;
  --paper-warm: #f5eee2;
  --white: #fffdf8;
  --orange: #f26b38;
  --orange-deep: #cc4825;
  --sun: #ffc65b;
  --sun-pale: #ffe2a4;
  --teal: #007c83;
  --green: #159a78;
  --line: rgba(16, 42, 67, 0.14);
  --display: "Bricolage Grotesque", "Avenir Next", "Segoe UI", Arial, sans-serif;
  --body: "Manrope", Inter, "Avenir Next", "Segoe UI", Arial, sans-serif;
  --istanbul-image: url('https://images.unsplash.com/photo-1524231757912-21f4fe3a7200?auto=format&fm=webp&fit=crop&w=900&q=70');
  --shadow: 0 28px 80px rgba(7, 28, 45, 0.17);
  --section: min(1180px, calc(100vw - 64px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--body); -webkit-font-smoothing: antialiased; }
button, input { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; }

.skip-link { position: fixed; top: 12px; left: 12px; z-index: 100; padding: 11px 14px; background: var(--sun); color: var(--ink); border-radius: 5px; font-weight: 800; transform: translateY(-160%); transition: transform .2s ease; }
.skip-link:focus { transform: translateY(0); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.section-wrap { width: var(--section); margin: 0 auto; }

.site-header { position: absolute; z-index: 10; top: 0; left: 0; display: flex; width: 100%; height: 92px; align-items: center; justify-content: space-between; gap: 32px; padding: 0 max(32px, calc((100vw - 1180px) / 2)); color: var(--ink); background: rgba(255,253,248,.97); box-shadow: 0 1px 0 rgba(16,42,67,.1); transition: background .3s ease, box-shadow .3s ease, height .3s ease; }
.site-header.is-scrolled { position: fixed; top: 0; width: 100%; height: 72px; padding: 0 max(24px, calc((100vw - 1180px) / 2)); border: 0; border-radius: 0; color: var(--ink); background: rgba(255,253,248,.94); box-shadow: 0 9px 28px rgba(16,42,67,.11); backdrop-filter: blur(18px); }
.brand-logo { display: block; width: 237px; height: 72px; overflow: hidden; flex: 0 0 auto; }
.brand-logo__crop { position: relative; display: block; width: 237px; height: 72px; overflow: hidden; background: url('./brand/logo_slogan_tr_transparent.png') -31px -37px / 295px auto no-repeat; }
.brand-logo__crop img { position: absolute; top: -37px; left: -31px; display: block; width: 295px; max-width: none; height: auto; opacity: 0; }
.menu-toggle { display: none; }
.brand { display: inline-flex; align-items: center; gap: 8px; flex-shrink: 0; }
.brand__mark { width: 34px; height: 34px; color: var(--sun); overflow: visible; }
.brand__wordmark { color: inherit; font: 900 21px/1 var(--display); letter-spacing: .065em; }
.site-nav { display: flex; align-items: center; gap: 30px; margin-left: auto; margin-right: 12px; }
.site-nav a { position: relative; display: inline-flex; min-height: 48px; align-items: center; color: #426075; font-size: 12px; font-weight: 800; letter-spacing: .015em; transition: color .2s ease; }
.site-nav a::after { position: absolute; right: 0; bottom: -7px; left: 0; height: 1px; content: ""; background: var(--sun); transform: scaleX(0); transform-origin: right; transition: transform .23s ease; }
.site-nav a:hover, .site-nav a:focus-visible { color: var(--orange-deep); }
.site-nav a:hover::after, .site-nav a:focus-visible::after { transform: scaleX(1); transform-origin: left; }
.header-cta { display: inline-flex; min-height: 48px; align-items: center; gap: 6px; border: 1px solid var(--ink); padding: 11px 14px; color: var(--white); background: var(--ink); font-size: 11px; font-weight: 850; letter-spacing: .02em; transition: background .22s ease, color .22s ease, transform .22s ease; }
.site-nav .site-nav__mobile-cta, .mobile-cta { display: none; }
.header-cta span { font-size: 15px; line-height: 0; }
.header-cta:hover, .header-cta:focus-visible { background: var(--orange); border-color: var(--orange); color: white; transform: translateY(-2px); }

.hero { position: relative; isolation: isolate; min-height: 830px; overflow: hidden; color: var(--white); background: linear-gradient(114deg, #071c2d 0%, #102a43 48%, #173d57 100%); }
.hero::before { position: absolute; z-index: -2; inset: 0; content: ""; opacity: .28; background-image: radial-gradient(circle at 1px 1px, rgba(255,255,255,.22) 1px, transparent 0); background-size: 30px 30px; mask-image: linear-gradient(to bottom, black, transparent 73%); }
.hero::after { position: absolute; z-index: -1; right: -22vw; bottom: -27vw; width: 75vw; aspect-ratio: 1; content: ""; border: 1px solid rgba(255,255,255,.12); border-radius: 50%; box-shadow: 0 0 0 55px rgba(255,255,255,.025), 0 0 0 110px rgba(255,255,255,.018); }
.hero__atmosphere { position: absolute; z-index: -1; inset: 0; pointer-events: none; overflow: hidden; }
.hero__sun { position: absolute; top: 121px; left: 53%; width: 365px; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle at 39% 34%, #fff5c7, #ffc65a 44%, #f28b36 72%, transparent 73%); opacity: .93; filter: blur(.2px); }
.hero__sun-ring { position: absolute; top: 82px; left: calc(53% - 39px); width: 445px; aspect-ratio: 1; border: 1px solid rgba(255,220,143,.33); border-radius: 50%; }
.hero__grid { position: absolute; right: -95px; bottom: 54px; width: 640px; height: 390px; transform: perspective(400px) rotateX(57deg) rotateZ(-10deg); transform-origin: bottom; opacity: .16; background: linear-gradient(rgba(255,231,177,.65) 1px, transparent 1px), linear-gradient(90deg, rgba(255,231,177,.65) 1px, transparent 1px); background-size: 40px 40px; mask-image: linear-gradient(to top, black, transparent); }
.hero__orb { position: absolute; border-radius: 50%; opacity: .78; filter: blur(1px); animation: float 8s ease-in-out infinite; }
.hero__orb--one { top: 24%; left: 8%; width: 12px; height: 12px; background: var(--sun); box-shadow: 0 0 0 8px rgba(255,190,84,.12); }
.hero__orb--two { top: 65%; left: 46%; width: 10px; height: 10px; background: #69d4cf; box-shadow: 0 0 0 9px rgba(105,212,207,.1); animation-delay: -2.4s; }
.hero__orb--three { top: 20%; right: 10%; width: 7px; height: 7px; background: #fff4cf; animation-delay: -5s; }
.hero__content { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 32px; min-height: 766px; padding-top: 102px; }
.hero__copy { position: relative; z-index: 2; padding: 64px 0 88px; }
.eyebrow { display: flex; align-items: center; gap: 9px; margin: 0 0 19px; color: var(--sun); font-size: 10px; font-weight: 900; letter-spacing: .17em; }
.eyebrow__spark { font-size: 17px; line-height: 1; }
.eyebrow--dark { color: var(--orange-deep); }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: var(--display); }
h1 { max-width: 710px; margin-bottom: 23px; color: var(--white); font-size: clamp(50px, 6.15vw, 86px); font-weight: 750; letter-spacing: -.082em; line-height: .91; }
h1 em, h2 em { color: var(--sun); font-style: normal; }
.hero__lede { max-width: 468px; margin-bottom: 30px; color: rgba(255,253,248,.77); font-size: 16px; font-weight: 500; line-height: 1.7; }
.hero__actions { display: flex; align-items: center; gap: 23px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 14px; min-height: 53px; padding: 0 19px; font-size: 13px; font-weight: 900; transition: transform .22s ease, box-shadow .22s ease, background .22s ease; }
.button span { font-size: 19px; transition: transform .22s ease; }
.button--sun { color: var(--ink); background: var(--sun); box-shadow: 0 13px 25px rgba(0,0,0,.18); }
.button--sun:hover, .button--sun:focus-visible { background: #ffcc6a; box-shadow: 0 18px 35px rgba(0,0,0,.25); transform: translateY(-3px); }
.button:hover span, .button:focus-visible span { transform: translateX(4px); }
.text-link { display: inline-flex; align-items: center; gap: 9px; color: var(--white); font-size: 13px; font-weight: 800; }
.text-link span { color: var(--sun); font-size: 18px; transition: transform .2s ease; }
.text-link:hover span, .text-link:focus-visible span { transform: translateY(4px); }
.hero__note { display: flex; align-items: center; gap: 8px; margin-top: 48px; color: rgba(255,253,248,.53); font-size: 11px; font-weight: 650; letter-spacing: .02em; }
.hero__note-pulse { position: relative; width: 7px; height: 7px; border-radius: 50%; background: #62d1b3; }
.hero__note-pulse::after { position: absolute; inset: -4px; content: ""; border: 1px solid #62d1b3; border-radius: inherit; animation: pulse 1.8s ease-out infinite; }

.hero__visual { position: relative; min-height: 624px; align-self: end; transform: translate3d(var(--parallax-x, 0), var(--parallax-y, 0), 0); transition: transform .25s ease-out; }
.hero__route-line { position: absolute; z-index: 0; top: 33px; left: 15px; width: min(100%, 545px); }
.hero__route-line svg { display: block; width: 100%; }
.phone { position: absolute; z-index: 2; right: 10%; bottom: 15px; width: min(307px, 48vw); aspect-ratio: .49; padding: 9px; border: 7px solid #102031; border-radius: 42px; background: #102031; box-shadow: 0 40px 70px rgba(0,0,0,.36), inset 0 0 0 1px rgba(255,255,255,.18); transform: rotate(4deg); }
.phone__chrome { position: absolute; z-index: 2; top: 0; left: 50%; display: flex; align-items: center; justify-content: center; gap: 6px; width: 92px; height: 23px; border-radius: 0 0 14px 14px; background: #102031; transform: translateX(-50%); }
.phone__chrome b { width: 37px; height: 4px; border-radius: 9px; background: #26394d; }
.phone__chrome span { width: 5px; height: 5px; border-radius: 50%; background: #26394d; }
.phone__screen { position: relative; height: 100%; overflow: hidden; padding: 31px 13px 13px; border-radius: 29px; background: #f5f7f6; }
.phone__top { display: flex; align-items: center; justify-content: space-between; }
.phone__city { display: inline-flex; align-items: center; gap: 5px; color: var(--ink); font-size: 10px; font-weight: 850; }
.phone__city i { width: 7px; height: 7px; border-radius: 50%; background: var(--orange); box-shadow: 0 0 0 3px rgba(239,108,51,.18); }
.phone__avatar { display: grid; width: 24px; height: 24px; place-items: center; border-radius: 8px; color: white; background: linear-gradient(135deg, var(--orange), var(--sun)); font-size: 10px; font-weight: 900; }
.phone__microcopy { margin: 16px 0 11px; color: var(--ink); font-size: 14px; font-weight: 900; letter-spacing: -.03em; }
.phone__card-stack { position: relative; height: calc(100% - 133px); min-height: 264px; }
.phone__back-card { position: absolute; top: 8px; right: 4px; bottom: -2px; left: 4px; border-radius: 13px; background: #d6e4e6; transform: rotate(3deg); }
.discover-card { position: relative; z-index: 1; display: flex; flex-direction: column; height: 100%; overflow: hidden; border-radius: 14px; background: white; box-shadow: 0 9px 22px rgba(16,42,67,.12); }
.discover-card__image { position: relative; flex: 1.05; overflow: hidden; padding: 11px; background: linear-gradient(160deg, transparent 12%, rgba(4,25,41,.47)), var(--istanbul-image) 50% 70% / cover; }
.discover-card__image::after { position: absolute; z-index: 0; right: -19px; bottom: -29px; width: 160px; height: 90px; content: ""; border: 4px solid rgba(255,201,83,.86); border-radius: 50%; transform: rotate(-20deg); }
.discover-card__rating, .discover-card__badge { position: relative; z-index: 1; display: inline-block; padding: 4px 6px; border-radius: 5px; font-size: 8px; font-weight: 900; }
.discover-card__rating { color: var(--ink); background: var(--sun); }
.discover-card__badge { float: right; color: white; background: rgba(7,28,45,.6); }
.discover-card__image-wave { position: absolute; z-index: 1; bottom: -13px; left: -10px; width: 120%; height: 32px; border-radius: 50% 50% 0 0; background: white; transform: rotate(-3deg); }
.discover-card__content { padding: 10px 11px 11px; }
.discover-card__place { color: var(--orange); font-size: 7px; font-weight: 900; letter-spacing: .12em; }
.discover-card h2 { margin: 3px 0 4px; color: var(--ink); font-size: 18px; letter-spacing: -.06em; line-height: 1; }
.discover-card p { margin: 0; color: #617b90; font-size: 8px; font-weight: 600; line-height: 1.35; }
.discover-card__meta { display: flex; gap: 10px; margin-top: 8px; color: var(--ink); font-size: 7px; font-weight: 800; }
.phone__actions { position: relative; z-index: 3; display: flex; align-items: center; justify-content: center; gap: 13px; height: 55px; }
.phone__action { display: grid; width: 29px; height: 29px; place-items: center; border-radius: 50%; background: white; box-shadow: 0 4px 10px rgba(16,42,67,.13); font-size: 17px; font-weight: 850; }
.phone__action--no { color: #d45c63; }
.phone__action--save { width: 36px; height: 36px; color: white; background: var(--orange); }
.phone__action--go { color: var(--teal); }
.phone__tabs { display: flex; justify-content: space-around; color: #a7bac7; font-size: 13px; }
.phone__tabs .is-active { color: var(--orange); }
.location-card { position: absolute; z-index: 1; overflow: hidden; width: 171px; color: white; background: var(--ink); box-shadow: var(--shadow); }
.location-card--galata { top: 43px; left: 2%; transform: rotate(-5deg); }
.location-card__photo { height: 100px; background: linear-gradient(to top, rgba(7,28,45,.48), transparent 60%), var(--istanbul-image) 65% 54% / cover; }
.location-card__details { padding: 11px 12px 12px; }
.location-card__tag { display: block; margin-bottom: 4px; color: var(--sun); font-size: 7px; font-weight: 900; letter-spacing: .12em; }
.location-card strong { display: block; margin-bottom: 4px; font-size: 14px; font-weight: 900; letter-spacing: -.04em; }
.location-card__details > span:last-child { color: #c9d8e1; font-size: 8px; font-weight: 700; }
.location-card__details i { color: var(--sun); font-style: normal; }
.location-card__save { position: absolute; top: 88px; right: 9px; display: grid; width: 25px; height: 25px; place-items: center; border-radius: 50%; color: var(--orange); background: white; font-size: 12px; box-shadow: 0 3px 8px rgba(0,0,0,.19); }
.floating-pill { position: absolute; z-index: 3; display: flex; align-items: center; gap: 6px; padding: 9px 11px; border: 1px solid rgba(255,255,255,.25); color: var(--ink); background: rgba(255,253,248,.91); box-shadow: 0 12px 25px rgba(0,0,0,.14); font-size: 10px; font-weight: 850; backdrop-filter: blur(8px); }
.floating-pill span { color: var(--orange); font-size: 15px; }
.floating-pill--one { top: 192px; right: 5%; animation: float 6s ease-in-out infinite -2s; }
.floating-pill--two { right: 47%; bottom: 48px; animation: float 6.6s ease-in-out infinite -4.2s; }
.floating-pill--two span { color: #d45c63; }
.route-stamp { position: absolute; z-index: 3; right: 1%; bottom: 191px; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 74px; height: 74px; border: 1px solid rgba(255,220,143,.85); border-radius: 50%; color: var(--sun); transform: rotate(10deg); animation: spin-slight 12s linear infinite; }
.route-stamp span { font-size: 22px; font-weight: 900; letter-spacing: -.07em; line-height: 1; }
.route-stamp small { margin-top: 3px; font-size: 7px; font-weight: 900; letter-spacing: .1em; line-height: 1.1; text-align: center; }
.hero__ticker { position: absolute; right: 0; bottom: 0; left: 0; z-index: 4; overflow: hidden; height: 57px; border-top: 1px solid rgba(255,255,255,.17); background: rgba(7,28,45,.23); }
.hero__ticker-track { display: flex; align-items: center; width: max-content; height: 100%; animation: ticker 24s linear infinite; }
.hero__ticker span { padding: 0 23px; color: rgba(255,253,248,.84); font-size: 11px; font-weight: 900; letter-spacing: .14em; }
.hero__ticker i { color: var(--sun); font-style: normal; }

.experience { position: relative; display: grid; grid-template-columns: .75fr 1fr; column-gap: 70px; padding-top: 142px; padding-bottom: 145px; }
.experience::before { position: absolute; top: 107px; right: 0; width: 46%; height: 1px; content: ""; background: var(--line); }
.section-heading h2, .story h2, .swipe-story h2, .join h2, .rhythms h2 { margin-bottom: 0; color: var(--ink); font-size: clamp(43px, 5.3vw, 70px); font-weight: 750; letter-spacing: -.075em; line-height: .93; }
.section-heading h2 em, .story h2 em { color: var(--orange); }
.experience__intro { max-width: 500px; align-self: end; margin: 0 0 5px; color: #4e677c; font-size: 17px; font-weight: 550; line-height: 1.67; }
.feature-grid { grid-column: 1 / -1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 70px; }
.feature { position: relative; min-height: 358px; overflow: hidden; padding: 28px 29px 31px; color: var(--white); transition: transform .25s ease, box-shadow .25s ease; }
.feature:hover { z-index: 1; box-shadow: 0 25px 42px rgba(7,28,45,.2); transform: translateY(-8px); }
.feature::before { position: absolute; right: -58px; bottom: -72px; width: 190px; height: 190px; content: ""; border: 1px solid rgba(255,255,255,.24); border-radius: 50%; box-shadow: 0 0 0 30px rgba(255,255,255,.04), 0 0 0 60px rgba(255,255,255,.025); }
.feature--warm { background: linear-gradient(145deg, #ef6c33, #c94821); }
.feature--blue { background: linear-gradient(145deg, #102a43, #164864); }
.feature--teal { background: linear-gradient(145deg, #007c83, #136b69); }
.feature__number { position: relative; z-index: 1; display: block; color: rgba(255,255,255,.58); font-size: 10px; font-weight: 900; letter-spacing: .15em; }
.feature__icon { position: relative; z-index: 1; display: grid; width: 58px; height: 58px; place-items: center; margin: 34px 0 23px; border: 1px solid rgba(255,255,255,.35); border-radius: 50%; }
.feature h3 { position: relative; z-index: 1; margin-bottom: 13px; font-size: 26px; font-weight: 900; letter-spacing: -.06em; line-height: 1; }
.feature p { position: relative; z-index: 1; max-width: 290px; margin: 0; color: rgba(255,255,255,.75); font-size: 13px; font-weight: 550; line-height: 1.6; }
.feature__line { position: absolute; z-index: 1; bottom: 28px; left: 29px; width: 37px; height: 2px; background: var(--sun); }
.feature__icon--swipe span { width: 20px; height: 13px; border: 2px solid white; border-radius: 5px; transform: rotate(-15deg); }
.feature__icon--swipe b { position: absolute; right: 10px; bottom: 11px; color: var(--sun); font-size: 19px; transform: rotate(-18deg); }
.feature__icon--route { display: flex; align-items: center; justify-content: center; gap: 4px; }
.feature__icon--route i { width: 7px; height: 7px; border: 2px solid white; border-radius: 50%; }
.feature__icon--route i:nth-child(2) { width: 14px; height: 1px; border: 0; border-top: 2px dashed var(--sun); border-radius: 0; }
.feature__icon--spark { color: var(--sun); font-size: 32px; }

.rhythms { padding: 121px 0 127px; background: #f3ede2; }
.rhythms__intro { display: flex; align-items: end; justify-content: space-between; gap: 60px; }
.rhythms__intro > p { max-width: 410px; margin: 0 0 6px; color: #526a7a; font-size: 15px; font-weight: 600; line-height: 1.7; }
.rhythms h2 em { color: var(--teal); }
.rhythm-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-top: 55px; }
.rhythm-card { position: relative; min-height: 285px; overflow: hidden; padding: 21px; color: var(--ink); background: #fffdf8; transition: transform .25s ease, box-shadow .25s ease; }
.rhythm-card:hover { z-index: 1; box-shadow: 0 23px 40px rgba(16,42,67,.15); transform: translateY(-8px) rotate(-.5deg); }
.rhythm-card::after { position: absolute; right: -58px; bottom: -73px; width: 176px; height: 176px; content: ""; border-radius: 50%; opacity: .22; }
.rhythm-card__number { display: block; color: #5f7586; font-size: 9px; font-weight: 900; letter-spacing: .14em; }
.rhythm-card svg { width: 52px; height: 52px; margin: 46px 0 25px; fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; stroke-width: 2.4; }
.rhythm-card h3 { position: relative; z-index: 1; margin-bottom: 9px; font-size: 22px; font-weight: 750; letter-spacing: -.06em; line-height: 1; }
.rhythm-card p { position: relative; z-index: 1; margin: 0; color: #5f7586; font-size: 12px; font-weight: 600; line-height: 1.55; }
.rhythm-card--sun { color: #d67b15; }
.rhythm-card--sun::after { background: var(--sun); }
.rhythm-card--sea { color: var(--teal); }
.rhythm-card--sea::after { background: #6ccfc6; }
.rhythm-card--night { color: #3d5688; }
.rhythm-card--night::after { background: #8ea7de; }
.rhythm-card--coral { color: var(--orange-deep); }
.rhythm-card--coral::after { background: #ff9a72; }

.swipe-story { position: relative; isolation: isolate; overflow: hidden; padding: 118px 0; color: white; background: var(--ink-deep); }
.swipe-story__backdrop { position: absolute; z-index: -1; inset: 0; overflow: hidden; opacity: .9; background: radial-gradient(circle at 75% 43%, rgba(232,110,48,.38), transparent 28%), radial-gradient(circle at 25% 15%, rgba(19,118,130,.34), transparent 31%); }
.swipe-story__backdrop::before, .swipe-story__backdrop::after { position: absolute; content: ""; border-radius: 50%; border: 1px solid rgba(255,255,255,.1); }
.swipe-story__backdrop::before { top: -260px; left: -120px; width: 630px; height: 630px; }
.swipe-story__backdrop::after { right: -220px; bottom: -300px; width: 740px; height: 740px; box-shadow: 0 0 0 42px rgba(255,255,255,.025), 0 0 0 84px rgba(255,255,255,.017); }
.swipe-story__inner { display: grid; grid-template-columns: .85fr 1.15fr; align-items: center; gap: 100px; }
.swipe-story h2 { color: var(--white); }
.swipe-story h2 em { color: var(--sun); }
.swipe-story__copy > p:not(.eyebrow) { max-width: 350px; margin: 28px 0; color: rgba(255,253,248,.72); font-size: 16px; font-weight: 520; line-height: 1.7; }
.swipe-story__legend { display: flex; flex-wrap: wrap; gap: 14px; color: rgba(255,253,248,.64); font-size: 11px; font-weight: 750; }
.swipe-story__legend span { display: inline-flex; align-items: center; gap: 5px; }
.swipe-story__legend i { display: grid; width: 19px; height: 19px; place-items: center; border-radius: 50%; font-style: normal; }
.legend-no { color: #fc9896; background: rgba(240,116,114,.16); }
.legend-yes { color: #ffbf4d; background: rgba(255,190,84,.16); }
.swipe-demo { display: flex; justify-content: center; }
.swipe-demo__frame { position: relative; width: min(365px, 80vw); height: 473px; padding: 23px 27px 23px; border: 1px solid rgba(255,255,255,.17); background: rgba(255,255,255,.075); box-shadow: 0 36px 70px rgba(0,0,0,.23); backdrop-filter: blur(13px); }
.swipe-demo__hint { position: absolute; top: -27px; left: 50%; margin: 0; color: var(--sun); font-size: 10px; font-weight: 850; letter-spacing: .04em; transform: translateX(-50%); white-space: nowrap; animation: hint-bob 2.7s ease-in-out infinite; }
.swipe-demo__card-under { position: absolute; top: 34px; right: 20px; bottom: 61px; left: 34px; display: flex; flex-direction: column; justify-content: flex-end; padding: 20px; color: white; background: linear-gradient(155deg, #067e83, #0d485c); transform: rotate(4deg); }
.swipe-demo__card-under::before { position: absolute; top: 27px; left: 20px; width: 42px; height: 42px; content: ""; border: 1px solid rgba(255,255,255,.34); border-radius: 50%; }
.swipe-demo__card-under span { margin-bottom: 7px; color: var(--sun); font-size: 8px; font-weight: 900; letter-spacing: .14em; }
.swipe-demo__card-under b { font-size: 18px; letter-spacing: -.045em; line-height: 1.05; }
.swipe-demo__card { position: relative; z-index: 1; display: flex; flex-direction: column; height: 100%; overflow: hidden; outline: none; background: white; box-shadow: 0 16px 25px rgba(0,0,0,.25); touch-action: none; transform: rotate(-2deg); will-change: transform; }
.swipe-demo__card:focus-visible { box-shadow: 0 0 0 3px var(--sun), 0 16px 25px rgba(0,0,0,.25); }
.swipe-demo__photo { position: relative; flex: 1; overflow: hidden; background: linear-gradient(to top, rgba(7,28,45,.62), transparent 68%), var(--istanbul-image) 50% 67% / cover; }
.swipe-demo__photo::after { position: absolute; right: -53px; bottom: -73px; width: 230px; height: 159px; content: ""; border: 2px solid rgba(255,205,83,.9); border-radius: 50%; transform: rotate(-20deg); }
.swipe-demo__city { position: absolute; z-index: 1; bottom: 15px; left: 15px; color: white; font-size: 8px; font-weight: 900; letter-spacing: .14em; }
.swipe-demo__accept, .swipe-demo__reject { position: absolute; z-index: 3; top: 20px; padding: 8px 9px; border: 3px solid; border-radius: 3px; font-size: 11px; font-weight: 900; letter-spacing: .04em; opacity: 0; transition: opacity .1s; }
.swipe-demo__accept { right: 17px; border-color: #8be0c3; color: #8be0c3; transform: rotate(10deg); }
.swipe-demo__reject { left: 17px; border-color: #ffb0ac; color: #ffb0ac; transform: rotate(-10deg); }
.swipe-demo__content { flex: .78; padding: 16px; color: var(--ink); }
.swipe-demo__content > div:first-child { display: flex; align-items: flex-end; justify-content: space-between; gap: 8px; }
.swipe-demo__content span { color: var(--orange); font-size: 8px; font-weight: 900; letter-spacing: .12em; }
.swipe-demo__content h3 { margin: 4px 0 0; font-size: 27px; font-weight: 900; letter-spacing: -.07em; line-height: 1; }
.swipe-demo__content p { margin: 11px 0; color: #617b90; font-size: 10px; font-weight: 600; line-height: 1.45; }
.swipe-demo__card-foot { display: flex; align-items: center; gap: 11px; }
.swipe-demo__card-foot span { color: var(--ink); font-size: 9px; letter-spacing: 0; }
.swipe-demo__card-foot span:first-child { color: #c27c10; }
.swipe-demo__card-foot b { display: grid; width: 20px; height: 20px; place-items: center; margin-left: auto; border-radius: 50%; color: white; background: var(--orange); font-size: 12px; }
.swipe-demo__buttons { position: absolute; z-index: 3; right: 0; bottom: -22px; left: 0; display: flex; justify-content: center; gap: 14px; }
.swipe-demo__buttons button { display: grid; width: 46px; height: 46px; place-items: center; border: 0; border-radius: 50%; background: var(--white); box-shadow: 0 9px 18px rgba(0,0,0,.22); font-size: 25px; font-weight: 800; transition: transform .2s ease; }
.swipe-demo__buttons button:hover, .swipe-demo__buttons button:focus-visible { transform: translateY(-4px) scale(1.05); }
.swipe-demo__buttons button:first-child { color: #d85a5e; }
.swipe-demo__buttons button:last-child { color: var(--orange); }
.swipe-demo__card.is-dragging { transition: none; }
.swipe-demo__card.is-resetting { transition: transform .38s cubic-bezier(.2,.85,.25,1); }

.story { display: grid; grid-template-columns: 1.02fr .98fr; align-items: center; gap: clamp(52px, 8vw, 123px); padding-top: 150px; padding-bottom: 150px; }
.story__visual { position: relative; min-height: 543px; }
.story__image { position: absolute; top: 0; right: 0; bottom: 0; left: 48px; overflow: hidden; background: linear-gradient(to top, rgba(7,28,45,.54), rgba(7,28,45,.04) 65%), var(--istanbul-image) 53% 64% / cover; box-shadow: var(--shadow); }
.story__image::after { position: absolute; top: 0; right: 0; bottom: 0; left: 0; content: ""; opacity: .4; background-image: linear-gradient(rgba(255,255,255,.35) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.35) 1px, transparent 1px); background-size: 50px 50px; mix-blend-mode: soft-light; }
.story__sun { position: absolute; z-index: 2; top: -34px; left: 0; width: 118px; height: 118px; border-radius: 50%; background: var(--sun); box-shadow: 0 0 0 17px rgba(255,190,84,.16); }
.story__caption { position: absolute; z-index: 2; right: 20px; bottom: 20px; display: flex; gap: 12px; color: rgba(255,255,255,.82); font-size: 8px; font-weight: 800; letter-spacing: .08em; }
.story__card { position: absolute; z-index: 3; bottom: -31px; left: 0; width: 206px; padding: 20px; color: var(--ink); background: var(--white); box-shadow: 0 18px 35px rgba(7,28,45,.17); }
.story__card span { display: block; margin-bottom: 3px; color: var(--orange); font-size: 9px; font-weight: 850; letter-spacing: .07em; }
.story__card strong { font-family: var(--display); font-size: 22px; font-weight: 900; letter-spacing: -.07em; line-height: .95; }
.story__card i { position: absolute; top: 23px; right: 18px; color: var(--orange); font-size: 22px; font-style: normal; }
.story__copy > p:not(.eyebrow) { max-width: 455px; margin-bottom: 18px; color: #4e677c; font-size: 15px; font-weight: 520; line-height: 1.67; }
.story__copy .text-link { margin-top: 8px; }
.text-link--dark { color: var(--ink); }
.text-link--dark span { color: var(--orange); }
.text-link--dark:hover span, .text-link--dark:focus-visible span { transform: translateX(4px); }

.join { position: relative; isolation: isolate; overflow: hidden; padding: 132px 0 129px; color: white; text-align: center; background: linear-gradient(135deg, #cf4b1b, #ef6c33 59%, #f58c34); }
.join__texture { position: absolute; z-index: -1; inset: 0; opacity: .75; }
.join__texture::before, .join__texture::after { position: absolute; content: ""; border: 1px solid rgba(255,255,255,.2); border-radius: 50%; }
.join__texture::before { top: -390px; left: 50%; width: 780px; height: 780px; transform: translateX(-50%); box-shadow: 0 0 0 50px rgba(255,255,255,.04), 0 0 0 100px rgba(255,255,255,.025); }
.join__texture::after { right: -180px; bottom: -180px; width: 450px; height: 450px; background: radial-gradient(circle at 40% 40%, rgba(255,236,172,.38), transparent 62%); }
.join__inner { position: relative; max-width: 680px; }
.join .eyebrow { justify-content: center; color: #fff0bf; }
.join h2 { color: white; }
.join h2 em { color: #ffdfa0; }
.join__inner > p:not(.eyebrow):not(.join__privacy) { max-width: 470px; margin: 24px auto 29px; color: rgba(255,255,255,.8); font-size: 16px; font-weight: 550; line-height: 1.6; }
.join__form { display: flex; max-width: 475px; margin: 0 auto; padding: 5px; background: white; box-shadow: 0 15px 35px rgba(117,35,15,.25); }
.join__form input { flex: 1; min-width: 0; padding: 0 16px; border: 0; outline: none; color: var(--ink); background: transparent; font-size: 13px; font-weight: 650; }
.join__form input::placeholder { color: #8ea0ad; }
.join__form input:focus { box-shadow: inset 0 -2px 0 var(--sun); }
.join__form button { display: inline-flex; align-items: center; gap: 9px; min-height: 48px; padding: 0 15px; border: 0; color: var(--ink); background: var(--sun); font-size: 12px; font-weight: 900; transition: background .2s ease, transform .2s ease; }
.join__form button span { font-size: 17px; }
.join__form button:hover, .join__form button:focus-visible { background: #ffcf69; transform: translateX(2px); }
.join__privacy { margin: 15px auto 0; color: rgba(255,255,255,.65); font-size: 10px; font-weight: 500; }
.join__privacy a { text-decoration: underline; text-underline-offset: 2px; }

.site-footer { display: flex; align-items: center; justify-content: space-between; gap: 25px; min-height: 115px; color: var(--ink); }
.brand-logo--footer { width: 181px; height: 55px; }
.brand-logo--footer .brand-logo__crop { width: 181px; height: 55px; }
.brand-logo--footer .brand-logo__crop img { top: -28px; left: -24px; width: 226px; }
.brand--footer .brand__mark { color: var(--orange); }
.site-footer p { margin: 0; color: #6e8496; font-size: 11px; font-weight: 750; }
.site-footer__links { display: flex; gap: 18px; color: #6e8496; font-size: 10px; font-weight: 700; }
.site-footer__links a { color: var(--orange-deep); }
.site-footer__links a:hover, .site-footer__links a:focus-visible { text-decoration: underline; text-underline-offset: 3px; }

.contact-section { display: grid; grid-template-columns: .85fr 1.15fr; gap: 80px; padding-top: 125px; padding-bottom: 125px; }
.contact-section h2 { margin-bottom: 21px; color: var(--ink); font: 750 clamp(42px, 4.4vw, 62px)/.93 var(--display); letter-spacing: -.075em; }
.contact-section h2 em { color: var(--orange); font-style: normal; }
.contact-section__copy > p:not(.eyebrow) { max-width: 390px; margin: 0; color: #526a7a; font-size: 15px; font-weight: 600; line-height: 1.7; }
.contact-form { display: grid; gap: 15px; padding: 28px; background: #edf3f3; border-top: 3px solid var(--teal); }
.contact-form label { display: grid; gap: 7px; color: var(--ink); font-size: 12px; font-weight: 800; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid #c6d6dc; border-radius: 0; padding: 13px 14px; color: var(--ink); background: white; font-size: 16px; line-height: 1.4; outline: none; }
.contact-form textarea { resize: vertical; min-height: 115px; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--teal); box-shadow: 0 0 0 3px rgba(0,124,131,.13); }
.contact-form button { display: inline-flex; width: fit-content; min-height: 48px; align-items: center; gap: 10px; margin-top: 3px; border: 0; padding: 0 18px; color: white; background: var(--teal); font-size: 13px; font-weight: 900; }
.contact-form button:hover, .contact-form button:focus-visible { background: #00666c; }

.cookie-consent { position: fixed; z-index: 30; right: 20px; bottom: 20px; display: flex; width: min(490px, calc(100% - 40px)); align-items: center; gap: 18px; padding: 17px; border: 1px solid rgba(16,42,67,.14); color: var(--ink); background: rgba(255,253,248,.98); box-shadow: 0 18px 50px rgba(7,28,45,.2); backdrop-filter: blur(14px); }
.cookie-consent[hidden] { display: none; }
.cookie-consent p { flex: 1; margin: 0; font-size: 12px; font-weight: 600; line-height: 1.55; }
.cookie-consent p a { color: var(--orange-deep); text-decoration: underline; text-underline-offset: 2px; }
.cookie-consent > div { display: flex; gap: 8px; }
.cookie-consent button { min-height: 42px; border: 1px solid var(--ink); padding: 0 12px; color: var(--ink); background: transparent; font-size: 11px; font-weight: 850; }
.cookie-consent button:last-child { color: white; background: var(--ink); }

.legal-page { min-height: 100vh; background: #f8f5ef; }
.legal-page__inner { width: min(760px, calc(100% - 40px)); margin: 0 auto; padding: 76px 0 100px; color: var(--ink); }
.legal-page__back { display: inline-flex; min-height: 48px; align-items: center; margin-bottom: 50px; color: var(--orange-deep); font-size: 13px; font-weight: 850; }
.legal-page h1 { max-width: 700px; margin-bottom: 22px; color: var(--ink); font-size: clamp(45px, 7vw, 75px); }
.legal-page h2 { margin: 38px 0 11px; font: 750 26px/1 var(--display); letter-spacing: -.045em; }
.legal-page p { color: #496174; font-size: 16px; font-weight: 550; line-height: 1.72; }
.legal-page p a { color: var(--orange-deep); text-decoration: underline; text-underline-offset: 3px; }
.legal-page__lead { max-width: 680px; color: var(--ink) !important; font-size: 19px !important; font-weight: 650 !important; }

[data-reveal] { opacity: 1; transform: none; }
[data-parallax][data-reveal] { transform: translate3d(var(--parallax-x, 0), var(--parallax-y, 0), 0); }

@keyframes float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-11px); } }
@keyframes pulse { from { transform: scale(.4); opacity: .9; } to { transform: scale(1.6); opacity: 0; } }
@keyframes ticker { to { transform: translateX(-50%); } }
@keyframes phone-enter { from { opacity: 0; transform: translateY(58px) rotate(11deg); } to { opacity: 1; transform: translateY(0) rotate(4deg); } }
@keyframes card-in { from { opacity: 0; transform: translate(-25px, 20px) rotate(-9deg); } to { opacity: 1; transform: translate(0, 0) rotate(-5deg); } }
@keyframes spin-slight { 50% { transform: rotate(18deg); } 100% { transform: rotate(10deg); } }
@keyframes hint-bob { 0%,100% { transform: translate(-50%, 0); opacity: .65; } 50% { transform: translate(-50%, -6px); opacity: 1; } }

@media (max-width: 960px) {
  :root { --section: min(100% - 48px, 700px); }
  .site-nav { display: none; }
  .hero { min-height: 1025px; }
  .hero__sun { top: 366px; left: auto; right: -80px; width: 320px; }
  .hero__sun-ring { top: 332px; left: auto; right: -112px; width: 390px; }
  .hero__content { display: block; min-height: 968px; padding-top: 91px; }
  .hero__copy { padding: 55px 0 0; }
  h1 { max-width: 620px; font-size: clamp(53px, 11.5vw, 76px); }
  .hero__visual { width: 560px; max-width: 100%; min-height: 518px; margin: 0 auto; }
  .phone { right: 9%; bottom: 14px; }
  .location-card--galata { top: 27px; left: 4%; }
  .floating-pill--one { top: 157px; right: 0; }
  .route-stamp { right: 0; bottom: 162px; }
  .experience { display: block; padding-top: 113px; padding-bottom: 117px; }
  .experience::before { top: 77px; width: 34%; }
  .experience__intro { margin: 25px 0 0; }
  .feature-grid { margin-top: 48px; }
  .feature { min-height: 355px; padding: 24px 22px; }
  .feature h3 { font-size: 22px; }
  .rhythms { padding: 95px 0 100px; }
  .rhythm-grid { grid-template-columns: repeat(2, 1fr); }
  .swipe-story { padding: 108px 0; }
  .swipe-story__inner { grid-template-columns: 1fr; gap: 72px; }
  .swipe-story__copy { max-width: 500px; }
  .story { grid-template-columns: 1fr; gap: 85px; padding-top: 112px; padding-bottom: 118px; }
  .story__visual { min-height: 510px; max-width: 595px; }
  .story__copy { max-width: 600px; }
  .contact-section { grid-template-columns: 1fr; gap: 38px; padding-top: 96px; padding-bottom: 98px; }
  .contact-section__copy > p:not(.eyebrow) { max-width: 520px; }
}

@media (max-width: 640px) {
  :root { --section: calc(100% - 36px); }
  .site-header { width: 100%; height: 76px; padding: 0 18px; }
  .site-header.is-scrolled { top: 0; width: 100%; height: 62px; padding: 0 18px; }
  .brand-logo { width: 186px; height: 58px; }
  .brand-logo__crop { width: 186px; height: 58px; background-position: -24px -29px; background-size: 232px auto; }
  .brand-logo__crop img { top: -29px; left: -24px; width: 232px; }
  .brand__mark { width: 29px; height: 29px; }
  .brand__wordmark { font-size: 18px; }
  .header-cta { display: none; }
  .menu-toggle { position: absolute; z-index: 2; top: 14px; right: 18px; display: grid; width: 48px; height: 48px; place-items: center; border: 0; padding: 0; color: var(--ink); background: transparent; font-size: 29px; line-height: 1; }
  .menu-toggle span { display: block; line-height: 1; }
  .menu-open .menu-toggle span { font-size: 0; }
  .menu-open .menu-toggle span::after { content: "×"; font-size: 34px; }
  .site-header .site-nav { position: absolute; top: 76px; right: 0; left: 0; display: none; padding: 13px 18px 19px; border-top: 1px solid rgba(16,42,67,.09); background: #fffdf8; box-shadow: 0 15px 25px rgba(16,42,67,.1); }
  .menu-open .site-header .site-nav { display: grid; }
  .site-header.is-scrolled .site-nav { top: 62px; }
  .site-nav a { min-height: 48px; padding: 0 4px; font-size: 14px; }
  .site-nav a::after { bottom: 2px; }
  .site-nav__mobile-cta { display: flex !important; justify-content: center; margin-top: 8px; padding: 0 14px !important; color: white !important; background: var(--orange); }
  .site-nav__mobile-cta::after { display: none; }
  .mobile-cta { position: fixed; z-index: 21; right: 18px; bottom: 18px; left: 18px; display: inline-flex; min-height: 52px; align-items: center; justify-content: center; gap: 10px; color: white; background: var(--ink); box-shadow: 0 13px 28px rgba(7,28,45,.28); font-size: 14px; font-weight: 900; }
  .hero { min-height: 946px; }
  .hero__content { min-height: 891px; padding-top: 77px; }
  .hero__copy { padding-top: 38px; }
  h1 { margin-bottom: 18px; font-size: clamp(43px, 13vw, 60px); letter-spacing: -.08em; }
  .hero-title-tail { display: block; }
  .hero__lede { max-width: 360px; margin-bottom: 23px; font-size: 14px; line-height: 1.62; }
  .hero__actions { align-items: flex-start; flex-direction: column; gap: 17px; }
  .button { min-height: 49px; }
  .hero__note { margin-top: 26px; font-size: 10px; }
  .hero__visual { min-height: 480px; margin-top: 6px; }
  .hero__sun { top: 420px; right: -111px; width: 290px; }
  .hero__sun-ring { top: 394px; right: -142px; width: 350px; }
  .hero__route-line { top: 11px; left: -15px; width: 430px; }
  .phone { right: 2%; bottom: 14px; width: 238px; border-width: 5px; border-radius: 32px; }
  .phone__screen { padding: 27px 10px 10px; border-radius: 23px; }
  .phone__chrome { width: 77px; height: 19px; }
  .phone__microcopy { margin: 12px 0 7px; font-size: 11px; }
  .phone__card-stack { min-height: 215px; }
  .discover-card h2 { font-size: 15px; }
  .phone__actions { height: 45px; gap: 9px; }
  .phone__action { width: 24px; height: 24px; font-size: 13px; }
  .phone__action--save { width: 30px; height: 30px; }
  .location-card { width: 139px; }
  .location-card--galata { top: 30px; left: -2px; }
  .location-card__photo { height: 79px; }
  .location-card__details { padding: 8px 9px 10px; }
  .location-card strong { font-size: 11px; }
  .location-card__save { top: 68px; right: 7px; width: 20px; height: 20px; font-size: 9px; }
  .floating-pill { padding: 7px 8px; font-size: 8px; }
  .floating-pill--one { top: 134px; right: -4px; }
  .floating-pill--two { right: 48%; bottom: 16px; }
  .route-stamp { right: -3px; bottom: 137px; width: 58px; height: 58px; }
  .route-stamp span { font-size: 17px; }
  .route-stamp small { font-size: 5px; }
  .hero__ticker { height: 46px; }
  .hero__ticker span { padding: 0 15px; font-size: 9px; }
  .experience { padding-top: 83px; padding-bottom: 86px; }
  .experience::before { top: 54px; }
  .section-heading h2, .story h2, .swipe-story h2, .join h2 { font-size: clamp(39px, 12vw, 53px); }
  .experience__intro { margin-top: 20px; font-size: 15px; }
  .feature-grid { grid-template-columns: 1fr; gap: 10px; margin-top: 37px; }
  .feature { min-height: 274px; padding: 20px; }
  .feature__icon { width: 47px; height: 47px; margin: 20px 0 16px; }
  .feature h3 { margin-bottom: 10px; font-size: 23px; }
  .feature p { max-width: 310px; font-size: 12px; }
  .feature__line { bottom: 20px; left: 20px; }
  .rhythms { padding: 77px 0 83px; }
  .rhythms__intro { display: block; }
  .rhythms__intro > p { margin-top: 20px; font-size: 14px; }
  .rhythm-grid { grid-template-columns: 1fr; gap: 9px; margin-top: 36px; }
  .rhythm-card { min-height: 218px; padding: 18px; }
  .rhythm-card svg { width: 42px; height: 42px; margin: 25px 0 15px; }
  .rhythm-card h3 { font-size: 21px; }
  .swipe-story { padding: 84px 0 94px; }
  .swipe-story__inner { gap: 68px; }
  .swipe-story__copy > p:not(.eyebrow) { margin: 20px 0; font-size: 14px; }
  .swipe-demo__frame { width: min(324px, 90vw); height: 434px; padding: 20px 23px; }
  .swipe-demo__card-under { top: 31px; right: 17px; bottom: 54px; left: 29px; }
  .swipe-demo__content h3 { font-size: 23px; }
  .swipe-demo__buttons { bottom: -21px; }
  .story { gap: 75px; padding-top: 84px; padding-bottom: 91px; }
  .story__visual { min-height: 404px; }
  .story__image { left: 20px; }
  .story__sun { top: -22px; width: 86px; height: 86px; box-shadow: 0 0 0 12px rgba(255,190,84,.16); }
  .story__card { bottom: -25px; width: 178px; padding: 16px; }
  .story__card strong { font-size: 19px; }
  .story__copy > p:not(.eyebrow) { font-size: 14px; }
  .join { padding: 89px 0 85px; }
  .join__inner > p:not(.eyebrow):not(.join__privacy) { margin: 19px auto 23px; font-size: 14px; }
  .join__form { display: grid; gap: 8px; padding: 6px; }
  .join__form input { min-height: 45px; }
  .join__form button { justify-content: center; }
  .site-footer { display: grid; grid-template-columns: 1fr; gap: 12px; padding-top: 31px; padding-bottom: 30px; }
  .site-footer__links { flex-wrap: wrap; gap: 9px 15px; }
  .brand-logo--footer { width: 181px; height: 55px; }
  .brand-logo--footer .brand-logo__crop { width: 181px; height: 55px; }
  .brand-logo--footer .brand-logo__crop img { top: -28px; left: -24px; width: 226px; }
  .contact-section { gap: 29px; padding-top: 77px; padding-bottom: 92px; }
  .contact-section h2 { font-size: 43px; }
  .contact-section__copy > p:not(.eyebrow) { font-size: 14px; }
  .contact-form { padding: 19px; }
  .cookie-consent { right: 12px; bottom: 80px; left: 12px; width: auto; display: block; padding: 15px; }
  .cookie-consent > div { margin-top: 13px; }
  .cookie-consent button { flex: 1; min-height: 46px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  [data-reveal] { opacity: 1; transform: none; }
}
