/* =====================================================================
   EEC Design — Dijital Ajans
   Design system + components. Dark-first, macOS-inspired, with PİKO.
   ===================================================================== */

/* ---------- Tokens ---------- */
:root {
  /* Editöryel stüdyo paleti — sıcak siyah zemin, kâğıt beyazı, asit yeşili */
  --bg:        #0C0C0A;
  --bg-2:      #100F0B;
  --surface:   #15140F;
  --surface-2: #1C1A14;
  --border:    rgba(236, 234, 224, 0.10);
  --border-2:  rgba(236, 234, 224, 0.18);

  --text:   #ECEAE0;
  --muted:  #9D998C;
  --faint:  #6A655A;

  --acid:      #CDFF4F;
  --acid-deep: #A6E22E;
  --clay:      #E0794B;
  --cream:     #EFE7D4;

  --primary:   #CDFF4F;
  --primary-2: #DBFF7A;
  --accent:    #CDFF4F;
  --accent-2:  #E0794B;
  --pink:      #E0794B;

  --grad:      linear-gradient(135deg, #DBFF7A 0%, #A6E22E 100%);
  --grad-warm: linear-gradient(135deg, #E0794B 0%, #EFD9A8 100%);
  --grad-text: linear-gradient(120deg, #CDFF4F 0%, #CDFF4F 100%);

  --ring: 0 0 0 1px var(--border);
  --shadow-sm: 0 4px 16px rgba(0, 0, 0, 0.4);
  --shadow:    0 18px 50px rgba(0, 0, 0, 0.5);
  --shadow-glow: 0 20px 60px rgba(124, 92, 255, 0.28);

  --r-sm: 12px;
  --r:    18px;
  --r-lg: 26px;
  --r-xl: 34px;

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 56px);

  --font-display: "Fraunces", "Times New Roman", Georgia, serif;
  --font-sans: "Space Grotesk", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-body: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Text", system-ui, sans-serif;
  --font-mono: "Space Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
}

[data-theme="light"] {
  --bg:        #F4F4F8;
  --bg-2:      #ECECF3;
  --surface:   #FFFFFF;
  --surface-2: #F6F6FB;
  --border:    rgba(10, 10, 25, 0.10);
  --border-2:  rgba(10, 10, 25, 0.18);
  --text:   #15151F;
  --muted:  #565670;
  --faint:  #8E8EA6;
  --shadow:    0 18px 50px rgba(60, 50, 120, 0.14);
  --shadow-sm: 0 4px 16px rgba(60, 50, 120, 0.10);
}

/* ---------- Reset / base ---------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
}

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Ambient background glow */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(70% 45% at 50% -8%, rgba(205, 255, 79, 0.06), transparent 62%),
    radial-gradient(120% 90% at 50% 108%, rgba(0, 0, 0, 0.5), transparent 60%);
  pointer-events: none;
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
::selection { background: rgba(124, 92, 255, 0.4); color: #fff; }

/* ---------- Layout ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
section { position: relative; padding-block: clamp(60px, 8vw, 100px); }
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 0.72rem; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent);
  padding: 7px 14px 6px; border-radius: 100px;
  background: rgba(24, 230, 200, 0.07);
  border: 1px solid rgba(24, 230, 200, 0.20);
}
.eyebrow::before { content: "—"; opacity: 0.6; }
.eyebrow.violet { color: var(--primary-2); background: rgba(124, 92, 255, 0.10); border-color: rgba(124, 92, 255, 0.28); }
.eyebrow.warm { color: var(--accent-2); background: rgba(255, 178, 62, 0.10); border-color: rgba(255, 178, 62, 0.28); }

h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; line-height: 1.08; letter-spacing: -0.02em; }
.h-section { font-size: clamp(2rem, 5vw, 3.4rem); margin-top: 18px; }
.lead { color: var(--muted); font-size: clamp(1.02rem, 2vw, 1.2rem); max-width: 56ch; margin-top: 18px; }
.grad-text { background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.center { text-align: center; }
.center .lead { margin-inline: auto; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-display); font-weight: 600; font-size: 1rem;
  padding: 15px 26px; border-radius: 100px;
  transition: transform 0.3s var(--ease-bounce), box-shadow 0.3s var(--ease), background 0.3s var(--ease);
  position: relative; white-space: nowrap;
}
.btn:active { transform: scale(0.97); }
.btn-primary {
  background: var(--grad); color: #0a0a12;
  box-shadow: 0 12px 30px rgba(124, 92, 255, 0.35);
}
.btn-primary:hover { transform: translateY(-3px) scale(1.02); box-shadow: 0 18px 44px rgba(124, 92, 255, 0.5); }
.btn-ghost {
  background: rgba(255, 255, 255, 0.04); color: var(--text);
  border: 1px solid var(--border-2);
  backdrop-filter: blur(10px);
}
.btn-ghost:hover { transform: translateY(-3px); border-color: var(--primary); background: rgba(124, 92, 255, 0.10); }
.btn .arrow { transition: transform 0.3s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }
.btn-lg { padding: 18px 32px; font-size: 1.08rem; }

/* ---------- Header / Nav ---------- */
.site-header {
  position: fixed; top: 0; inset-inline: 0; z-index: 100;
  transition: background 0.4s var(--ease), border-color 0.4s, backdrop-filter 0.4s;
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter: blur(18px) saturate(150%);
  border-bottom-color: var(--border);
}
.nav { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--font-display); font-weight: 700; font-size: 1.18rem; letter-spacing: -0.01em; }
.brand img { height: 22px; width: auto; opacity: 0.96; }
.brand .dot { color: var(--accent); }
.nav-links { display: flex; align-items: center; gap: 6px; }
.nav-links a {
  font-size: 0.95rem; color: var(--muted); padding: 9px 15px; border-radius: 100px;
  transition: color 0.25s, background 0.25s;
}
.nav-links a:hover { color: var(--text); background: rgba(255, 255, 255, 0.05); }
.nav-actions { display: flex; align-items: center; gap: 10px; }
.icon-btn {
  width: 40px; height: 40px; display: grid; place-items: center; border-radius: 50%;
  border: 1px solid var(--border); color: var(--muted); transition: all 0.25s;
}
.icon-btn:hover { color: var(--text); border-color: var(--border-2); background: rgba(255, 255, 255, 0.05); }
.nav-toggle { display: none; }

@media (max-width: 860px) {
  .nav-links {
    position: fixed; inset: 72px 0 auto 0;
    flex-direction: column; align-items: stretch; gap: 2px;
    background: color-mix(in srgb, var(--bg) 96%, transparent);
    backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
    padding: 14px var(--gut) 24px;
    transform: translateY(-130%); transition: transform 0.4s var(--ease);
  }
  .nav-links.open { transform: translateY(0); }
  .nav-links a { padding: 14px 16px; font-size: 1.05rem; }
  .nav-toggle { display: grid; }
  .nav-cta-desktop { display: none; }
}

/* ---------- Hero ---------- */
.hero { padding-top: 130px; padding-bottom: 60px; min-height: 100svh; display: flex; align-items: center; }
.hero-grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 40px; align-items: center; width: 100%;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 9px;
  font-size: 0.86rem; color: var(--muted);
  padding: 8px 15px; border-radius: 100px;
  background: rgba(255, 255, 255, 0.04); border: 1px solid var(--border);
}
.hero-badge .pulse { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 0 var(--accent); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(24, 230, 200, 0.5); } 70% { box-shadow: 0 0 0 10px rgba(24, 230, 200, 0); } 100% { box-shadow: 0 0 0 0 rgba(24, 230, 200, 0); } }

.hero h1 { font-size: clamp(2.6rem, 6.4vw, 5rem); margin: 24px 0 0; line-height: 1.02; }
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .line > span { display: inline-block; }
.hero .typed { color: var(--text); }
.hero .caret { display: inline-block; width: 3px; height: 0.95em; background: var(--accent); margin-left: 4px; vertical-align: -0.08em; animation: blinkCaret 1s steps(2) infinite; border-radius: 2px; }
@keyframes blinkCaret { 50% { opacity: 0; } }
.hero-sub { margin-top: 26px; font-size: clamp(1.05rem, 2vw, 1.28rem); color: var(--muted); max-width: 50ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 36px; }
.hero-meta { display: flex; gap: 30px; margin-top: 44px; flex-wrap: wrap; }
.hero-meta .stat .n { font-family: var(--font-display); font-size: 1.9rem; font-weight: 700; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero-meta .stat .l { font-size: 0.82rem; color: var(--faint); letter-spacing: 0.02em; }

.hero-stage { position: relative; display: grid; place-items: center; min-height: 440px; }
.stage-glow {
  position: absolute; width: 78%; aspect-ratio: 1; border-radius: 50%;
  background: var(--grad); filter: blur(70px); opacity: 0.35; animation: floaty 9s ease-in-out infinite;
}
.stage-ring { position: absolute; width: 90%; aspect-ratio: 1; border-radius: 50%; border: 1px dashed var(--border-2); animation: spin 38s linear infinite; }
.stage-ring.r2 { width: 66%; animation-direction: reverse; animation-duration: 28s; }
@keyframes spin { to { transform: rotate(360deg); } }
.orbit-chip {
  position: absolute; padding: 8px 14px; border-radius: 100px; font-size: 0.8rem; font-weight: 600;
  font-family: var(--font-display); background: var(--surface); border: 1px solid var(--border-2);
  box-shadow: var(--shadow-sm); white-space: nowrap; animation: floaty 6s ease-in-out infinite;
}
.orbit-chip.c1 { top: 6%; left: 4%; color: var(--accent); }
.orbit-chip.c2 { top: 22%; right: 0%; color: var(--primary-2); animation-delay: -2s; }
.orbit-chip.c3 { bottom: 12%; left: -2%; color: var(--accent-2); animation-delay: -4s; }
.orbit-chip.c4 { bottom: 2%; right: 8%; color: var(--pink); animation-delay: -1s; }

@media (max-width: 940px) {
  .hero-grid { grid-template-columns: 1fr; gap: 10px; }
  .hero-stage { order: -1; min-height: 320px; margin-bottom: 10px; }
  .hero { min-height: auto; padding-top: 118px; }
  .hero-meta { gap: 22px; }
}

/* ---------- PİKO mascot ---------- */
.piko {
  --eye-x: 0px; --eye-y: 0px;
  width: 100%; max-width: 320px; position: relative; z-index: 2;
  transform-origin: center bottom;
  animation: floaty 5.5s ease-in-out infinite;
}
@keyframes floaty { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }
.piko svg { width: 100%; height: auto; overflow: visible; filter: drop-shadow(0 24px 40px rgba(124, 92, 255, 0.35)); }
.piko .pupil { transition: transform 0.18s var(--ease); transform: translate(var(--eye-x), var(--eye-y)); }
.piko .eye-lid, .piko .spark, .piko .cheek, .piko .eye-ball { transform-box: fill-box; transform-origin: center; }
.piko .eye-lid { transform: scaleY(0); transition: transform 0.09s ease; }
/* göz maskotu: kırpma = gözü bir çizgiye sıkıştır */
.piko .eye-ball { transition: transform 0.1s ease; }
.piko.blink .eye-ball, .piko.mood-sleeping .eye-ball { transform: scaleY(0.07); }
.piko.blink .eye-lid { transform: scaleY(1); }
.piko .mouth { transition: d 0.3s var(--ease), transform 0.3s var(--ease); }
.piko .cheek { opacity: 0; transition: opacity 0.4s; }
.piko .spark { opacity: 0; transform-origin: center; }
.piko .zzz { opacity: 0; }

/* moods */
.piko.mood-happy { animation: bounceY 1.4s var(--ease-bounce) infinite; }
.piko.mood-happy .cheek { opacity: 0.9; }
.piko.mood-excited { animation: bounceY 0.6s var(--ease-bounce) infinite; }
.piko.mood-excited .cheek { opacity: 1; }
.piko.mood-excited .spark { opacity: 1; animation: sparkle 0.9s ease-in-out infinite; }
.piko.mood-thinking { animation: floaty 5.5s ease-in-out infinite, tilt 3s ease-in-out infinite; }
.piko.mood-sleeping { animation: floaty 7s ease-in-out infinite; }
.piko.mood-sleeping .zzz { opacity: 1; animation: rise 3s ease-in-out infinite; }
@keyframes bounceY { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-18px); } }
@keyframes tilt { 0%, 100% { rotate: -3deg; } 50% { rotate: 3deg; } }
@keyframes sparkle { 0%, 100% { opacity: 0.2; transform: scale(0.7); } 50% { opacity: 1; transform: scale(1.1); } }
@keyframes rise { 0% { opacity: 0; transform: translateY(6px) scale(0.8); } 30% { opacity: 1; } 100% { opacity: 0; transform: translateY(-18px) scale(1.1); } }

/* ---------- Floating PİKO guide ---------- */
.piko-guide {
  position: fixed; right: clamp(14px, 3vw, 30px); bottom: clamp(14px, 3vw, 30px);
  z-index: 90; display: flex; align-items: flex-end; gap: 12px; flex-direction: column;
  pointer-events: none;
}
.piko-guide.hidden { display: none; }
.piko-bubble {
  pointer-events: auto;
  max-width: 270px; background: var(--surface); border: 1px solid var(--border-2);
  border-radius: 18px 18px 4px 18px; padding: 13px 16px; font-size: 0.92rem; line-height: 1.45;
  box-shadow: var(--shadow); position: relative;
  opacity: 0; transform: translateY(8px) scale(0.96); transform-origin: bottom right;
  transition: opacity 0.35s var(--ease), transform 0.35s var(--ease-bounce);
}
.piko-bubble.show { opacity: 1; transform: translateY(0) scale(1); }
.piko-bubble strong { color: var(--accent); }
.piko-stage { display: flex; align-items: center; gap: 6px; pointer-events: auto; }
.piko-guide .piko { width: 92px; animation: floaty 4s ease-in-out infinite; cursor: pointer; }
.piko-guide .piko svg { filter: drop-shadow(0 12px 22px rgba(124, 92, 255, 0.45)); }
.piko-mute {
  pointer-events: auto;
  width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center;
  background: var(--surface); border: 1px solid var(--border); color: var(--muted);
  font-size: 0.85rem; transition: all 0.25s; align-self: flex-end; margin-bottom: 6px;
}
.piko-mute:hover { color: var(--text); border-color: var(--border-2); }

/* ---------- Marquee ---------- */
.marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); padding-block: 10px; }
.marquee-track { display: flex; gap: 16px; width: max-content; animation: scrollX 32s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes scrollX { to { transform: translateX(-50%); } }
.chip-stat {
  display: inline-flex; align-items: center; gap: 10px; white-space: nowrap;
  padding: 12px 20px; border-radius: 100px; background: var(--surface); border: 1px solid var(--border);
  font-family: var(--font-display); font-weight: 600;
}
.chip-stat .n { font-size: 1.15rem; }
.chip-stat .l { color: var(--muted); font-weight: 400; font-family: var(--font-body); font-size: 0.9rem; }
.chip-stat.v .n { color: var(--primary-2); }
.chip-stat.a .n { color: var(--accent); }
.chip-stat.w .n { color: var(--accent-2); }
.chip-stat.p .n { color: var(--pink); }

/* ---------- Services ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 54px; }
.svc-card {
  position: relative; padding: 30px; border-radius: var(--r-lg);
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg-2) 100%);
  border: 1px solid var(--border); overflow: hidden;
  transition: transform 0.4s var(--ease), border-color 0.4s, box-shadow 0.4s;
}
.svc-card::before {
  content: ""; position: absolute; inset: 0; opacity: 0; transition: opacity 0.4s;
  background: radial-gradient(120% 90% at var(--mx, 50%) 0%, color-mix(in srgb, var(--c) 26%, transparent), transparent 60%);
}
.svc-card:hover { transform: translateY(-6px); border-color: color-mix(in srgb, var(--c) 50%, var(--border)); box-shadow: var(--shadow); }
.svc-card:hover::before { opacity: 1; }
.svc-num { position: absolute; top: 22px; right: 26px; font-family: var(--font-display); font-size: 0.9rem; color: var(--faint); font-weight: 600; }
.svc-icon {
  width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center; font-size: 1.6rem;
  background: color-mix(in srgb, var(--c) 16%, transparent); border: 1px solid color-mix(in srgb, var(--c) 30%, transparent);
  margin-bottom: 22px;
}
.svc-card h3 { font-size: 1.5rem; }
.svc-tag { display: inline-block; margin-top: 6px; font-size: 0.82rem; font-weight: 600; color: var(--c); font-family: var(--font-display); letter-spacing: 0.02em; }
.svc-card p { color: var(--muted); margin-top: 14px; font-size: 0.98rem; }
.svc-list { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 8px; }
.svc-list span { font-size: 0.8rem; color: var(--muted); padding: 6px 12px; border-radius: 100px; background: rgba(255, 255, 255, 0.04); border: 1px solid var(--border); }
.svc-foot { margin-top: 22px; display: flex; align-items: center; gap: 8px; font-family: var(--font-display); font-weight: 600; font-size: 0.9rem; color: var(--c); }

@media (max-width: 720px) { .svc-grid { grid-template-columns: 1fr; } }

/* ---------- Process ---------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 54px; }
.step {
  position: relative; padding: 30px 26px; border-radius: var(--r-lg);
  background: var(--surface); border: 1px solid var(--border);
}
.step .k { font-family: var(--font-display); font-size: 3rem; font-weight: 700; line-height: 1; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; opacity: 0.9; }
.step h3 { font-size: 1.3rem; margin-top: 14px; }
.step p { color: var(--muted); margin-top: 10px; font-size: 0.96rem; }
.step .piko-say { margin-top: 16px; font-size: 0.86rem; color: var(--accent); font-style: italic; padding-left: 14px; border-left: 2px solid var(--accent); }
@media (max-width: 760px) { .steps { grid-template-columns: 1fr; } }

/* ---------- References / Projects ---------- */
.proj-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 50px; }
.proj-card {
  position: relative; display: flex; flex-direction: column; min-height: 230px;
  padding: 24px; border-radius: var(--r-lg); overflow: hidden;
  background: var(--surface); border: 1px solid var(--border);
  transition: transform 0.4s var(--ease), border-color 0.4s, box-shadow 0.4s;
}
.proj-card::after {
  content: ""; position: absolute; inset: 0; z-index: 0; opacity: 0.5; transition: opacity 0.4s;
  background: radial-gradient(120% 80% at 100% 0%, color-mix(in srgb, var(--c) 24%, transparent), transparent 55%);
}
.proj-card:hover { transform: translateY(-6px); border-color: color-mix(in srgb, var(--c) 45%, var(--border)); box-shadow: var(--shadow); }
.proj-card:hover::after { opacity: 1; }
.proj-card > * { position: relative; z-index: 1; }
.proj-logo { width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: 1.2rem; color: #0a0a12; background: var(--c); box-shadow: 0 8px 20px color-mix(in srgb, var(--c) 40%, transparent); }
.proj-sector { margin-top: auto; font-size: 0.78rem; color: var(--faint); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.proj-card h3 { font-size: 1.3rem; margin-top: 6px; }
.proj-card .blurb { color: var(--muted); font-size: 0.9rem; margin-top: 8px; }
.proj-visit { margin-top: 16px; display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-display); font-weight: 600; font-size: 0.86rem; color: var(--c); }
.proj-card .arrow { transition: transform 0.3s var(--ease); }
.proj-card:hover .arrow { transform: translate(3px, -3px); }
@media (max-width: 860px) { .proj-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .proj-grid { grid-template-columns: 1fr; } }

/* trust note + testimonials */
.trust-row { display: grid; grid-template-columns: 1.1fr 1fr; gap: 18px; margin-top: 50px; align-items: stretch; }
.trust-note {
  padding: 32px; border-radius: var(--r-lg); border: 1px solid var(--border-2);
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.10), rgba(24, 230, 200, 0.06));
}
.trust-note h3 { font-size: 1.5rem; }
.trust-note p { color: var(--muted); margin-top: 12px; }
.trust-note .sign { margin-top: 18px; display: flex; align-items: center; gap: 12px; font-size: 0.9rem; color: var(--text); }
.trust-note .sign .av { width: 36px; height: 36px; border-radius: 50%; background: var(--grad); }
.chat-card {
  padding: 26px; border-radius: var(--r-lg); border: 1px solid var(--border); background: var(--surface);
  display: flex; flex-direction: column; gap: 12px; justify-content: center;
}
.wa-bubble { max-width: 86%; padding: 11px 15px; border-radius: 16px; font-size: 0.94rem; line-height: 1.45; }
.wa-bubble.them { align-self: flex-start; background: var(--surface-2); border: 1px solid var(--border); border-bottom-left-radius: 4px; }
.wa-bubble.us { align-self: flex-end; background: rgba(24, 230, 200, 0.14); border: 1px solid rgba(24, 230, 200, 0.25); border-bottom-right-radius: 4px; }
.wa-time { font-size: 0.7rem; color: var(--faint); margin-left: 6px; }
@media (max-width: 760px) { .trust-row { grid-template-columns: 1fr; } }

/* ---------- CTA band ---------- */
.cta-band { text-align: center; }
.cta-inner {
  position: relative; padding: clamp(40px, 7vw, 80px) var(--gut); border-radius: var(--r-xl); overflow: hidden;
  background: linear-gradient(135deg, rgba(124, 92, 255, 0.16), rgba(24, 230, 200, 0.10));
  border: 1px solid var(--border-2);
}
.cta-inner::before { content: ""; position: absolute; width: 60%; aspect-ratio: 1; left: 50%; top: -40%; translate: -50% 0; background: var(--grad); filter: blur(90px); opacity: 0.3; }
.cta-inner h2 { font-size: clamp(2rem, 5vw, 3.2rem); position: relative; }
.cta-inner p { color: var(--muted); margin: 16px auto 0; max-width: 48ch; position: relative; }
.cta-inner .hero-cta { justify-content: center; position: relative; }

/* ---------- Footer ---------- */
.site-footer { border-top: 1px solid var(--border); padding-block: 56px 32px; margin-top: 30px; }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 34px; }
.foot-brand .brand { margin-bottom: 14px; }
.foot-brand p { color: var(--muted); font-size: 0.94rem; max-width: 34ch; }
.foot-col h4 { font-size: 0.82rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--faint); font-family: var(--font-display); margin-bottom: 14px; }
.foot-col a { display: block; color: var(--muted); padding: 6px 0; font-size: 0.95rem; transition: color 0.2s; }
.foot-col a:hover { color: var(--accent); }
.foot-bottom { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 44px; padding-top: 24px; border-top: 1px solid var(--border); color: var(--faint); font-size: 0.86rem; }
.socials { display: flex; gap: 8px; }
@media (max-width: 760px) { .foot-grid { grid-template-columns: 1fr 1fr; } .foot-brand { grid-column: 1 / -1; } }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 0.08s; }
.reveal.d2 { transition-delay: 0.16s; }
.reveal.d3 { transition-delay: 0.24s; }
.reveal.d4 { transition-delay: 0.32s; }

/* ---------- Brief / chat page ---------- */
.brief-main { padding-top: 110px; min-height: 100svh; }
.brief-shell { max-width: 720px; margin-inline: auto; }
.brief-window {
  background: var(--surface); border: 1px solid var(--border-2); border-radius: var(--r-lg);
  box-shadow: var(--shadow); overflow: hidden; height: clamp(500px, 68vh, 680px); display: flex; flex-direction: column;
}
.brief-titlebar { display: flex; align-items: center; gap: 10px; padding: 14px 18px; border-bottom: 1px solid var(--border); background: var(--bg-2); }
.tl-dots { display: flex; gap: 7px; }
.tl-dots i { width: 12px; height: 12px; border-radius: 50%; display: block; }
.tl-dots i:nth-child(1) { background: #ff5f57; }
.tl-dots i:nth-child(2) { background: #febc2e; }
.tl-dots i:nth-child(3) { background: #28c840; }
.brief-title { font-family: var(--font-display); font-weight: 600; font-size: 0.92rem; display: flex; align-items: center; gap: 8px; }
.brief-title .live { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); animation: pulse 2s infinite; }
.brief-log { flex: 1; padding: 26px 22px; display: flex; flex-direction: column; gap: 14px; overflow-y: auto; }
.msg { display: flex; gap: 12px; align-items: flex-end; max-width: 88%; animation: msgIn 0.4s var(--ease) both; }
@keyframes msgIn { from { opacity: 0; transform: translateY(10px); } }
.msg .avatar { width: 38px; height: 38px; flex: 0 0 38px; border-radius: 50%; overflow: hidden; background: var(--bg-2); border: 1px solid var(--border); }
.msg .avatar svg { width: 120%; height: 120%; margin: -6% 0 0 -10%; }
.msg .text { padding: 12px 16px; border-radius: 16px; font-size: 0.97rem; line-height: 1.5; }
.msg.bot .text { background: var(--surface-2); border: 1px solid var(--border); border-bottom-left-radius: 4px; }
.msg.me { align-self: flex-end; flex-direction: row-reverse; }
.msg.me .text { background: var(--grad); color: #0a0a12; font-weight: 500; border-bottom-right-radius: 4px; }
.typing .text { display: inline-flex; gap: 4px; }
.typing .text i { width: 7px; height: 7px; border-radius: 50%; background: var(--muted); animation: typeDot 1.2s infinite; }
.typing .text i:nth-child(2) { animation-delay: 0.2s; }
.typing .text i:nth-child(3) { animation-delay: 0.4s; }
@keyframes typeDot { 0%, 60%, 100% { opacity: 0.3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-4px); } }

.brief-input { border-top: 1px solid var(--border); padding: 16px; background: var(--bg-2); }
.quick-opts { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 12px; }
.quick-opts button {
  padding: 11px 17px; border-radius: 100px; font-family: var(--font-display); font-weight: 500; font-size: 0.92rem;
  background: var(--surface); border: 1px solid var(--border-2); color: var(--text); transition: all 0.25s var(--ease);
  animation: msgIn 0.35s var(--ease) both;
}
.quick-opts button:hover { transform: translateY(-2px); border-color: var(--primary); background: rgba(124, 92, 255, 0.12); color: #fff; }
.field-row { display: flex; gap: 10px; }
.field-row input {
  flex: 1; padding: 14px 18px; border-radius: 100px; font-size: 1rem; font-family: inherit;
  background: var(--surface); border: 1px solid var(--border-2); color: var(--text); outline: none; transition: border-color 0.25s;
}
.field-row input:focus { border-color: var(--primary); }
.field-row input::placeholder { color: var(--faint); }
.send-btn { width: 52px; height: 52px; border-radius: 50%; background: var(--grad); color: #0a0a12; display: grid; place-items: center; flex: 0 0 52px; transition: transform 0.25s var(--ease-bounce); }
.send-btn:hover { transform: scale(1.08); }
.send-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.brief-progress { height: 4px; background: var(--bg); }
.brief-progress > i { display: block; height: 100%; width: 0; background: var(--grad); transition: width 0.5s var(--ease); }
.brief-aside { text-align: center; margin-top: 22px; color: var(--faint); font-size: 0.9rem; }
.brief-aside a { color: var(--accent); }

/* summary card after completion */
.summary-card { border: 1px solid rgba(24, 230, 200, 0.3); background: rgba(24, 230, 200, 0.06); border-radius: 16px; padding: 18px; font-size: 0.95rem; }
.summary-card h4 { font-family: var(--font-display); margin-bottom: 10px; color: var(--accent); }
.summary-card .row { display: flex; justify-content: space-between; gap: 12px; padding: 5px 0; border-bottom: 1px dashed var(--border); }
.summary-card .row:last-child { border-bottom: none; }
.summary-card .row span:first-child { color: var(--muted); }

/* ---------- Page hero (sub pages) ---------- */
.page-hero { padding-top: 140px; padding-bottom: 30px; }
.page-hero h1 { font-size: clamp(2.4rem, 6vw, 4.2rem); }
.page-hero .lead { font-size: 1.2rem; }

/* ---------- Blog ---------- */
.blog-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; margin-top: 44px; }
.post {
  display: flex; flex-direction: column; padding: 26px; border-radius: var(--r-lg);
  background: var(--surface); border: 1px solid var(--border); transition: transform 0.4s var(--ease), border-color 0.4s, box-shadow 0.4s;
}
.post:hover { transform: translateY(-5px); border-color: var(--border-2); box-shadow: var(--shadow); }
.post .cat { font-size: 0.76rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); font-family: var(--font-display); }
.post h3 { font-size: 1.35rem; margin-top: 12px; }
.post p { color: var(--muted); margin-top: 10px; font-size: 0.95rem; flex: 1; }
.post .meta { margin-top: 18px; display: flex; align-items: center; gap: 10px; font-size: 0.84rem; color: var(--faint); }
.post.feature { grid-column: 1 / -1; background: linear-gradient(135deg, rgba(124, 92, 255, 0.12), rgba(24, 230, 200, 0.06)); border-color: var(--border-2); }
.post.feature h3 { font-size: 1.9rem; }
@media (max-width: 720px) { .blog-grid { grid-template-columns: 1fr; } }

/* ---------- About / story ---------- */
.story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 44px; align-items: center; }
.story-card { padding: 30px; border-radius: var(--r-lg); background: var(--surface); border: 1px solid var(--border); }
.story-card h3 { font-size: 1.4rem; margin-bottom: 10px; }
.story-card p { color: var(--muted); }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 44px; }
.team-card { padding: 26px; border-radius: var(--r-lg); background: var(--surface); border: 1px solid var(--border); text-align: center; transition: transform 0.4s var(--ease), border-color 0.4s; }
.team-card:hover { transform: translateY(-5px); border-color: var(--border-2); }
.team-card .face { width: 80px; height: 80px; border-radius: 50%; margin: 0 auto 16px; background: var(--grad); display: grid; place-items: center; font-size: 2rem; }
.team-card h4 { font-size: 1.15rem; }
.team-card .role { color: var(--accent); font-size: 0.86rem; font-family: var(--font-display); margin-top: 4px; }
.team-card p { color: var(--muted); font-size: 0.88rem; margin-top: 10px; }
@media (max-width: 820px) { .story-grid { grid-template-columns: 1fr; } .team-grid { grid-template-columns: 1fr; } }

/* ---------- FAQ ---------- */
.faq { max-width: 760px; margin: 44px auto 0; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 22px 4px; font-family: var(--font-display); font-weight: 600; font-size: 1.1rem; }
.faq-q .pm { color: var(--accent); transition: transform 0.3s; flex: 0 0 auto; font-size: 1.4rem; }
.faq-item.open .pm { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.4s var(--ease); color: var(--muted); }
.faq-a p { padding: 0 4px 22px; }

/* ============================================================
   PREMIUM LAYER — grain, icons, live-preview showcase
   ============================================================ */

/* film grain overlay */
.grain {
  position: fixed; inset: 0; z-index: 9998; pointer-events: none; opacity: 0.05;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
[data-theme="light"] .grain { mix-blend-mode: multiply; opacity: 0.04; }

/* SVG line-icons */
.ico { width: 1.35em; height: 1.35em; stroke: currentColor; stroke-width: 1.6; fill: none; stroke-linecap: round; stroke-linejoin: round; display: inline-block; vertical-align: -0.18em; flex: none; }
.svc-icon { font-size: 0; }
.svc-icon svg { width: 26px; height: 26px; stroke: var(--c); stroke-width: 1.7; fill: none; stroke-linecap: round; stroke-linejoin: round; }
.icon-btn .ico, .work-visit .ico, .svc-foot .ico, .btn .ico { width: 1.05rem; height: 1.05rem; stroke-width: 1.8; }
.socials a { font-size: 0; }
.socials .ico { width: 1.05rem; height: 1.05rem; }

/* refined marquee chips (less candy) */
.chip-stat { background: var(--surface); border-color: var(--border); }
.chip-stat .n { font-family: var(--font-mono); }

/* ---- Live-preview project showcase ---- */
.work-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; margin-top: 54px; }
.work-card {
  position: relative; display: flex; flex-direction: column; border-radius: var(--r-lg); overflow: hidden;
  background: var(--surface); border: 1px solid var(--border);
  transition: transform 0.5s var(--ease), border-color 0.4s, box-shadow 0.5s;
}
.work-card::after {
  content: ""; position: absolute; inset: 0; z-index: 3; pointer-events: none; opacity: 0; transition: opacity 0.45s;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--c) 55%, transparent), inset 0 -90px 80px -60px color-mix(in srgb, var(--c) 40%, transparent);
  border-radius: inherit;
}
.work-card:hover { transform: translateY(-7px); box-shadow: var(--shadow); }
.work-card:hover::after { opacity: 1; }

.browser-bar { display: flex; align-items: center; gap: 12px; padding: 11px 15px; background: var(--bg-2); border-bottom: 1px solid var(--border); }
.browser-bar .dots { display: flex; gap: 6px; flex: none; }
.browser-bar .dots i { width: 10px; height: 10px; border-radius: 50%; background: var(--border-2); }
.browser-url { flex: 1; font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted); background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 6px 12px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: flex; align-items: center; gap: 7px; }
.browser-url .lock { width: 11px; height: 11px; opacity: 0.6; flex: none; }

.frame { position: relative; aspect-ratio: 16 / 10; overflow: hidden; background: var(--surface-2); }
.frame::before { content: ""; position: absolute; inset: 0; z-index: 0; background: linear-gradient(110deg, var(--surface-2) 30%, rgba(255, 255, 255, 0.06) 50%, var(--surface-2) 70%); background-size: 220% 100%; animation: shimmer 1.7s linear infinite; }
@keyframes shimmer { to { background-position: -220% 0; } }
.frame .poster { position: absolute; inset: 0; z-index: 1; width: 100%; height: 100%; object-fit: cover; object-position: top center; transition: transform 0.7s var(--ease), opacity 0.5s; }
/* CSS-only ölçek: iframe konteynerin 3 katı genişlikte render olur (geniş masaüstü viewport), sonra 1/3 küçültülür → içerik küçük görünür, daha çok sayfa sığar; her zaman tam oturur */
.frame iframe { position: absolute; top: 0; left: 0; z-index: 2; width: 300%; height: 300%; border: 0; transform: scale(0.3334); transform-origin: 0 0; opacity: 0; transition: opacity 0.7s var(--ease); pointer-events: none; background: #fff; }
.frame iframe.ready { opacity: 1; }
.work-card:hover .frame .poster { transform: scale(1.04); }
.frame .live-badge {
  position: absolute; z-index: 4; top: 12px; left: 12px; display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text);
  padding: 5px 10px; border-radius: 100px; background: color-mix(in srgb, var(--bg) 70%, transparent); backdrop-filter: blur(8px); border: 1px solid var(--border-2);
}
.frame .live-badge .d { width: 6px; height: 6px; border-radius: 50%; background: #ff5f57; box-shadow: 0 0 0 0 rgba(255, 95, 87, 0.5); animation: pulse 2s infinite; }

.work-meta { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 20px 22px; }
.work-meta .t h3 { font-size: 1.3rem; }
.work-tag { font-family: var(--font-mono); font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--c); margin-top: 7px; display: block; }
.work-visit { flex: none; width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; border: 1px solid var(--border-2); color: var(--text); transition: all 0.35s var(--ease); }
.work-card:hover .work-visit { background: var(--c); color: #08080d; border-color: var(--c); }
.work-card:hover .work-visit .ico { transform: translate(2px, -2px); }
.work-visit .ico { transition: transform 0.35s var(--ease); }
@media (max-width: 820px) { .work-grid { grid-template-columns: 1fr; } }

/* ============================================================
   EDİTÖRYEL STÜDYO OVERRIDE — serif display, asit yeşili, ham/gazete hissi
   ============================================================ */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 480; letter-spacing: -0.012em; font-optical-sizing: auto; }
.h-section { font-size: clamp(2.4rem, 6vw, 4.7rem); line-height: 1.0; font-weight: 400; letter-spacing: -0.02em; margin-top: 22px; }
.grad-text { background: none; -webkit-text-fill-color: currentColor; color: var(--acid); font-style: italic; font-weight: 380; }
.lead { font-family: var(--font-body); color: var(--muted); }
em { font-style: italic; }
::selection { background: var(--acid); color: #0C0C0A; }

/* eyebrow → düz editöryel etiket */
.eyebrow, .eyebrow.violet, .eyebrow.warm { background: none; border: none; padding: 0; color: var(--acid); font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.18em; font-weight: 400; }
.eyebrow::before { content: ""; display: inline-block; width: 28px; height: 1px; background: var(--acid); margin-right: 6px; vertical-align: middle; opacity: 0.85; }

/* butonlar → editöryel bloklar, glow yok */
.btn { border-radius: 5px; font-family: var(--font-mono); font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; font-size: 0.82rem; }
.btn-primary { background: var(--acid); color: #0C0C0A; box-shadow: none; }
.btn-primary:hover { background: var(--acid-deep); transform: translateY(-2px); box-shadow: none; }
.btn-ghost { background: transparent; border: 1px solid var(--border-2); color: var(--text); backdrop-filter: none; }
.btn-ghost:hover { border-color: var(--acid); color: var(--acid); background: transparent; transform: translateY(-2px); }

/* hero → tekno süsleri kaldır */
.stage-glow, .stage-ring, .orbit-chip { display: none !important; }
.hero h1 { font-family: var(--font-display); font-weight: 360; letter-spacing: -0.025em; }
.hero .caret { background: var(--acid); }
.hero-badge { font-family: var(--font-mono); border-radius: 4px; font-size: 0.74rem; letter-spacing: 0.08em; }
.hero-badge .pulse { background: var(--acid); }
.hero-meta .stat .n { background: none; -webkit-text-fill-color: currentColor; color: var(--acid); font-family: var(--font-display); font-style: italic; font-weight: 420; }
.hero-meta .stat .l { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.04em; }
.nav-links a, .brand { font-family: var(--font-sans); }
.nav-links a {
  font-size: 0.96rem;
  font-weight: 600;
  color: #ECEAE0;
  letter-spacing: 0.01em;
  text-shadow: 0 1px 8px rgba(0,0,0,0.9);
}
.nav-links a:hover { color: var(--acid); background: rgba(205, 255, 79, 0.09); }
.nav-links a.nav-cta-desktop { color: var(--acid); font-weight: 700; }
.brand { color: #ECEAE0; }
.brand span { font-weight: 700; font-size: 1.1rem; }

/* Header: her zaman okunabilir arka plan — scroll olmasa da */
.site-header {
  background: linear-gradient(180deg, rgba(12,12,10,0.82) 0%, rgba(12,12,10,0.0) 100%);
  backdrop-filter: none;
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(12, 12, 10, 0.90) !important;
  backdrop-filter: blur(18px) saturate(140%);
  border-bottom-color: rgba(236, 234, 224, 0.10);
}

/* marquee → editöryel ticker */
.marquee { border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding-block: 20px; }
.marquee-track { gap: 0; align-items: baseline; }
.chip-stat { background: none; border: none; border-radius: 0; padding: 0 32px; }
.chip-stat::before { content: "✳"; color: var(--acid); margin-right: 30px; font-size: 0.9rem; }
.chip-stat .n { color: var(--text); font-family: var(--font-display); font-style: italic; font-weight: 420; font-size: 1.5rem; }
.chip-stat .l { font-family: var(--font-mono); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--muted); }

/* hizmetler → editöryel liste */
.svc-grid { gap: 0 40px; }
.svc-card { background: transparent; border: none; border-top: 1px solid var(--border-2); border-radius: 0; padding: 36px 0 30px; }
.svc-card::before { display: none; }
.svc-card:hover { transform: none; box-shadow: none; border-top-color: var(--acid); }
.svc-num { font-family: var(--font-mono); color: var(--faint); top: 38px; }
.svc-icon { background: none !important; border: none !important; width: auto; height: auto; margin-bottom: 16px; }
.svc-icon svg { width: 30px; height: 30px; stroke: var(--acid) !important; }
.svc-card h3 { font-size: 2rem; font-weight: 420; }
.svc-tag { color: var(--muted); font-family: var(--font-mono); text-transform: none; letter-spacing: 0; font-size: 0.8rem; }
.svc-list span { border-radius: 3px; font-family: var(--font-mono); font-size: 0.74rem; }
.svc-foot { color: var(--acid); font-family: var(--font-mono); text-transform: uppercase; font-size: 0.76rem; letter-spacing: 0.06em; }

/* süreç */
.step { background: transparent; border: none; border-left: 1px solid var(--border-2); border-radius: 0; padding: 4px 0 4px 26px; }
.step .k { background: none; -webkit-text-fill-color: currentColor; color: var(--acid); font-style: italic; font-weight: 380; opacity: 1; }
.step .piko-say { color: var(--muted); border-left: none; font-family: var(--font-display); font-size: 1rem; font-style: italic; padding-left: 0; }

/* referanslar — marka logosu çipi */
.work-meta .t { display: flex; align-items: center; gap: 14px; }
.brand-logo { width: 46px; height: 46px; flex: none; border-radius: 9px; display: grid; place-items: center; background: var(--bg-2); border: 1px solid var(--border); overflow: hidden; }
.brand-logo img { max-width: 76%; max-height: 76%; object-fit: contain; }
.brand-logo.mono { font-family: var(--font-display); font-style: italic; color: var(--acid); font-size: 1.25rem; }
.work-tag { color: var(--muted); }
.work-card:hover .work-visit { background: var(--acid); color: #0C0C0A; border-color: var(--acid); }
.live-badge { font-family: var(--font-mono); }

/* logo şeridi → kayan, tıklanabilir marka logoları (sitelerine gider) */
.logo-strip { margin-top: 54px; padding-top: 30px; border-top: 1px solid var(--border); }
.logo-strip .cap { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--faint); margin-bottom: 22px; display: flex; align-items: center; gap: 8px; }
.logo-strip .cap::before { content: ""; width: 22px; height: 1px; background: var(--faint); }
.logo-marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); mask-image: linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent); }
.logo-track { display: flex; align-items: center; gap: 56px; width: max-content; animation: scrollX 36s linear infinite; }
.logo-marquee:hover .logo-track { animation-play-state: paused; }
.lm { display: inline-flex; align-items: center; gap: 13px; flex: none; opacity: 0.5; filter: grayscale(0.55); transition: opacity 0.35s var(--ease), filter 0.35s var(--ease), transform 0.35s var(--ease); }
.lm:hover { opacity: 1; filter: none; transform: translateY(-3px); }
.lm img { height: 32px; width: auto; max-width: 132px; object-fit: contain; }
.lm > span:not(.nm) { font-family: var(--font-display); font-style: italic; font-size: 1.35rem; color: var(--text); }
.lm .nm { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.03em; color: var(--muted); white-space: nowrap; transition: color 0.3s; }
.lm:hover .nm { color: var(--acid); }

/* hardcoded mor/teal arkaplanları asit'e çevir */
.cta-inner { background: linear-gradient(135deg, rgba(205, 255, 79, 0.08), rgba(205, 255, 79, 0.02)); }
.cta-inner::before { background: var(--acid); opacity: 0.12; }
.trust-note { background: linear-gradient(135deg, rgba(205, 255, 79, 0.07), rgba(224, 121, 75, 0.04)); }
.trust-note .sign .av { background: var(--acid); }
.post.feature { background: linear-gradient(135deg, rgba(205, 255, 79, 0.08), rgba(205, 255, 79, 0.02)); }
.wa-bubble.us { background: rgba(205, 255, 79, 0.12); border-color: rgba(205, 255, 79, 0.25); }
.team-card .face { background: var(--acid); }
.post .cat, .team-card .role { color: var(--acid); }

/* brief sohbet → asit */
.msg.me .text { background: var(--acid); color: #0C0C0A; }
.brief-progress > i, .send-btn { background: var(--acid); }
.send-btn { color: #0C0C0A; }
.summary-card { border-color: rgba(205, 255, 79, 0.3); background: rgba(205, 255, 79, 0.06); }
.summary-card h4, .brief-title .live, .brief-aside a { color: var(--acid); }
.brief-title .live { background: var(--acid); }
.quick-opts button:hover { border-color: var(--acid); background: rgba(205, 255, 79, 0.1); color: var(--text); }
.field-row input:focus { border-color: var(--acid); }

/* ses aç/kapa düğmesi */
.sound-widget { position: fixed; left: clamp(14px, 3vw, 28px); bottom: clamp(14px, 3vw, 28px); z-index: 90; display: inline-flex; align-items: center; gap: 12px; padding: 9px 14px 8px; border-radius: 100px; background: color-mix(in srgb, var(--bg) 80%, transparent); backdrop-filter: blur(10px); border: 1px solid var(--border-2); transition: all 0.3s var(--ease); overflow: hidden; }
.sound-toggle { display: inline-flex; align-items: center; background: transparent; border: none; padding: 0; color: var(--muted); cursor: pointer; transition: color 0.3s var(--ease); outline: none; }
.sound-widget:hover .sound-toggle, .sound-toggle.on { color: var(--acid); }
.vol-slider { width: 0; opacity: 0; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.15); appearance: none; outline: none; cursor: pointer; transition: all 0.4s var(--ease); pointer-events: none; margin: 0; }
.vol-slider::-webkit-slider-thumb { appearance: none; width: 10px; height: 10px; border-radius: 50%; background: var(--acid); box-shadow: 0 0 10px rgba(205,255,79,0.5); }
.sound-toggle.on ~ .vol-slider { width: 60px; opacity: 1; pointer-events: auto; }
.sound-toggle .eq { display: inline-flex; align-items: flex-end; gap: 2px; height: 13px; }
.sound-toggle .eq i { width: 2.5px; background: currentColor; height: 4px; border-radius: 2px; }
.sound-toggle.on .eq i { animation: eq 0.9s ease-in-out infinite; }
.sound-toggle .eq i:nth-child(2) { animation-delay: 0.2s; }
.sound-toggle .eq i:nth-child(3) { animation-delay: 0.4s; }
.sound-toggle .eq i:nth-child(4) { animation-delay: 0.15s; }
@keyframes eq { 0%, 100% { height: 4px; } 50% { height: 13px; } }
@media (max-width: 600px) { .sound-widget { padding: 8px 12px; gap: 8px; } }

/* hand-drawn maskot — mürekkep gölgesi */
.piko svg { filter: drop-shadow(0 14px 22px rgba(0, 0, 0, 0.5)); }
.piko-guide .piko svg { filter: drop-shadow(0 10px 16px rgba(0, 0, 0, 0.55)); }
.piko-bubble { font-family: var(--font-body); border-radius: 16px 16px 16px 3px; }
.piko-bubble strong { color: var(--acid); }

/* "Mac Sistemine Gir" girişi — eesatcakiroglu portfolyosuna */
.mac-link { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--acid); border: 1px solid rgba(205, 255, 79, 0.42); border-radius: 100px; padding: 9px 15px 8px; transition: all 0.3s var(--ease); white-space: nowrap; }
.mac-link:hover { background: var(--acid); color: #0C0C0A; border-color: var(--acid); transform: translateY(-1px); }
.mac-link .k { font-size: 1rem; line-height: 1; }
/* icon-only varyant */
.mac-link.mac-icon { padding: 9px 13px; border-radius: 50%; }
.mac-link.mac-icon .k { font-size: 1.1rem; }

/* aktif nav linki */
.nav-links a.active { color: var(--acid) !important; }
.nav-links a.active::after { content: ""; display: block; height: 2px; background: var(--acid); border-radius: 2px; margin-top: 2px; }

/* hamburger → X animasyonu */
.nav-toggle .ico { transition: transform 0.3s var(--ease); }
.nav-links.open ~ .nav-actions .nav-toggle .ico,
.nav-toggle[aria-expanded="true"] .ico { transform: rotate(90deg); }

/* 404 sayfası */
.page-404 { min-height: 100svh; display: flex; align-items: center; justify-content: center; text-align: center; padding-top: 80px; }
.page-404 .code { font-family: var(--font-display); font-style: italic; font-size: clamp(6rem, 18vw, 12rem); font-weight: 300; line-height: 1; background: none; color: var(--acid); opacity: 0.18; position: absolute; user-select: none; }
.page-404 .inner { position: relative; z-index: 1; }
.page-404 h1 { font-size: clamp(2rem, 5vw, 3.4rem); margin-bottom: 16px; }
.page-404 p { color: var(--muted); max-width: 42ch; margin-inline: auto; }
.page-404 .btns { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 32px; }

/* footer tam hali — tüm sayfalarda ortak */
.foot-full { padding-block: 56px 32px; border-top: 1px solid var(--border); margin-top: 60px; }
.foot-full .foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 34px; }
.foot-full .foot-brand .brand { margin-bottom: 14px; }
.foot-full .foot-brand p { color: var(--muted); font-size: 0.94rem; max-width: 34ch; }
.foot-full .foot-col h4 { font-size: 0.76rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--faint); font-family: var(--font-mono); margin-bottom: 14px; }
.foot-full .foot-col a { display: block; color: var(--muted); padding: 5px 0; font-size: 0.94rem; transition: color 0.2s; }
.foot-full .foot-col a:hover { color: var(--acid); }
.foot-full .foot-bottom { display: flex; justify-content: space-between; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--border); color: var(--faint); font-size: 0.84rem; font-family: var(--font-mono); }
@media (max-width: 760px) { .foot-full .foot-grid { grid-template-columns: 1fr 1fr; } .foot-full .foot-brand { grid-column: 1 / -1; } }

/* ============================================================
   AYDINLIK MOD — editöryel "kâğıt" teması (okunur)
   ============================================================ */
[data-theme="light"] {
  --bg: #F4F1E9; --bg-2: #EEEADF; --surface: #FBF9F3; --surface-2: #F1EDE2;
  --border: rgba(26, 24, 15, 0.13); --border-2: rgba(26, 24, 15, 0.24);
  --text: #1A1813; --muted: #5C5849; --faint: #8F8A78;
  --acid: #3F7D1E; --acid-deep: #2F5E16;
  --primary: #3F7D1E; --primary-2: #4E9626; --accent: #3F7D1E;
  --grad: linear-gradient(135deg, #4E9626, #3F7D1E);
  --grad-text: linear-gradient(120deg, #3F7D1E, #3F7D1E);
  --shadow: 0 18px 50px rgba(60, 50, 20, 0.12); --shadow-sm: 0 4px 16px rgba(60, 50, 20, 0.10);
}
[data-theme="light"] body::before {
  background: radial-gradient(70% 45% at 50% -8%, rgba(63, 125, 30, 0.06), transparent 62%),
              radial-gradient(120% 90% at 50% 108%, rgba(0, 0, 0, 0.04), transparent 60%);
}
[data-theme="light"] .grain { mix-blend-mode: multiply; opacity: 0.05; }
/* logo (beyaz) → koyuya çevir */
[data-theme="light"] .brand img { filter: invert(1) brightness(0.18); }
[data-theme="light"] .brand, [data-theme="light"] .brand span { color: var(--text); }
/* header */
[data-theme="light"] .site-header { background: linear-gradient(180deg, rgba(244, 241, 233, 0.88), rgba(244, 241, 233, 0)); }
[data-theme="light"] .site-header.scrolled { background: rgba(244, 241, 233, 0.93) !important; border-bottom-color: var(--border); }
/* nav linkleri */
[data-theme="light"] .nav-links a { color: #2A271E; text-shadow: none; }
[data-theme="light"] .nav-links a:hover, [data-theme="light"] .nav-links a.active { color: var(--acid); background: rgba(63, 125, 30, 0.10); }
[data-theme="light"] .nav-links a.nav-cta-desktop { color: var(--acid); }
[data-theme="light"] .nav-links { background: rgba(251, 249, 243, 0.97); }
/* butonlar */
[data-theme="light"] .btn-primary { color: #FBF9F3; }
[data-theme="light"] .btn-primary:hover { background: var(--acid-deep); }
[data-theme="light"] .icon-btn { color: var(--muted); border-color: var(--border-2); }
[data-theme="light"] .mac-link { color: var(--acid); border-color: rgba(63, 125, 30, 0.45); }
[data-theme="light"] .mac-link:hover { color: #FBF9F3; }
/* çeşitli bileşenler */
[data-theme="light"] .hero-badge, [data-theme="light"] .chip-stat .n { color: var(--text); }
[data-theme="light"] .sound-toggle { background: rgba(244, 241, 233, 0.85); }
[data-theme="light"] .live-badge { background: rgba(244, 241, 233, 0.75); color: var(--text); }
[data-theme="light"] .browser-bar { background: var(--bg-2); }
[data-theme="light"] .browser-url { color: var(--muted); }
[data-theme="light"] .msg.me .text, [data-theme="light"] .send-btn { color: #FBF9F3; }
[data-theme="light"] .piko-bubble { background: var(--surface); }
[data-theme="light"] .lm { filter: grayscale(0.3) brightness(0.4); opacity: 0.6; }
[data-theme="light"] .lm:hover { filter: none; opacity: 1; }
[data-theme="light"] .footer-cta, [data-theme="light"] .cta-inner { background: linear-gradient(135deg, rgba(63,125,30,0.08), rgba(63,125,30,0.02)); }

/* ---- Dil switcher ---- */
.lang-switch { display: inline-flex; align-items: center; border: 1px solid var(--border-2); border-radius: 100px; overflow: hidden; font-family: var(--font-mono); }
.lang-switch button { padding: 7px 11px 6px; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.04em; color: var(--muted); background: transparent; transition: all 0.2s; line-height: 1; }
.lang-switch button:hover { color: var(--text); }
.lang-switch button.on { background: var(--acid); color: #0C0C0A; }
[data-theme="light"] .lang-switch button.on { color: #FBF9F3; }
@media (max-width: 600px) { .lang-switch button { padding: 7px 8px 6px; } }

/* ============================================================
   "Mac Sistemine Gir" — tam ekran açılış + kilit ekranı
   ============================================================ */
.mac-boot {
  position: fixed; inset: 0; z-index: 1000; display: none;
  align-items: center; justify-content: center; flex-direction: column;
  color: #f4f3ef; overflow: hidden; font-family: var(--font-sans);
}
.mac-boot.open { display: flex; animation: macIn 0.5s var(--ease); }
@keyframes macIn { from { opacity: 0; } }
.mac-boot.closing { animation: macOut 0.4s var(--ease) forwards; }
@keyframes macOut { to { opacity: 0; transform: scale(1.04); } }
.mac-wall {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(80% 70% at 25% 15%, #2a2f1a, transparent 60%),
    radial-gradient(70% 80% at 85% 80%, #1a2630, transparent 60%),
    linear-gradient(160deg, #0d0f0a 0%, #14130d 50%, #0a0c10 100%);
}
.mac-wall::after {
  content: ""; position: absolute; inset: 0; opacity: 0.06; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.mac-top { position: absolute; top: 8vh; left: 0; right: 0; z-index: 2; text-align: center; }
.mac-time { display: block; font-family: var(--font-display); font-weight: 300; font-size: clamp(3.5rem, 11vw, 7rem); line-height: 1; letter-spacing: -0.02em; }
.mac-date { display: block; font-family: var(--font-mono); font-size: 0.92rem; letter-spacing: 0.05em; opacity: 0.8; margin-top: 6px; }
.mac-stage { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; text-align: center; }

/* boot */
.mac-booting .mac-mark { font-family: var(--font-display); font-style: italic; font-size: 3.4rem; letter-spacing: -0.02em; margin-bottom: 30px; }
.mac-booting .mac-mark b { color: var(--acid); font-style: normal; }
.mac-bar { width: 210px; height: 5px; border-radius: 100px; background: rgba(255,255,255,0.16); overflow: hidden; }
.mac-bar > i { display: block; height: 100%; width: 0; background: var(--acid); border-radius: 100px; animation: macLoad 1.5s var(--ease) forwards; }
@keyframes macLoad { to { width: 100%; } }

/* lock */
.mac-lock { margin-top: 16vh; }
.mac-avatar { width: 108px; height: 108px; border-radius: 50%; overflow: hidden; display: grid; place-items: center; background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.18); backdrop-filter: blur(8px); margin-bottom: 18px; box-shadow: 0 20px 50px rgba(0,0,0,0.4); }
.mac-avatar img { width: 58%; height: auto; }
.mac-user { font-family: var(--font-display); font-size: 1.7rem; font-weight: 500; }
.mac-sub { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.06em; opacity: 0.7; margin-top: 6px; }
.mac-field { display: flex; align-items: center; gap: 8px; margin-top: 26px; background: rgba(255,255,255,0.13); border: 1px solid rgba(255,255,255,0.22); backdrop-filter: blur(14px); border-radius: 100px; padding: 6px 6px 6px 18px; transition: border-color 0.25s; }
.mac-field:focus-within { border-color: var(--acid); }
.mac-field input { background: transparent; border: none; outline: none; color: #fff; font-size: 0.95rem; width: 190px; font-family: var(--font-sans); }
.mac-field input::placeholder { color: rgba(255,255,255,0.55); }
.mac-field button { width: 38px; height: 38px; flex: none; border-radius: 50%; background: var(--acid); color: #0c0c0a; display: grid; place-items: center; font-size: 1.2rem; font-weight: 700; transition: transform 0.2s var(--ease-bounce); }
.mac-field button:hover { transform: scale(1.1); }
.mac-hint { margin-top: 20px; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.05em; color: rgba(255,255,255,0.55); transition: color 0.25s; }
.mac-hint:hover { color: #fff; }
.mac-close { position: absolute; top: 24px; right: 26px; z-index: 3; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.25); border-radius: 100px; padding: 7px 13px 6px; transition: all 0.25s; }
.mac-close:hover { color: #0c0c0a; background: #fff; }
body.mac-open { overflow: hidden; }

/* ---- Fiyat listesi ---- */
.price-list { margin-top: 52px; border-top: 1px solid var(--border-2); }
.price-row { display: flex; align-items: baseline; justify-content: space-between; gap: 28px; padding: 26px 6px 24px; border-bottom: 1px solid var(--border); transition: background 0.3s var(--ease), padding-inline 0.3s var(--ease); position: relative; }
.price-row::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: var(--acid); opacity: 0; transition: 0.3s; }
.price-row:hover { background: rgba(205, 255, 79, 0.04); padding-inline: 18px 6px; }
.price-row:hover::before { width: 3px; opacity: 1; }
.pr-info { max-width: 60ch; }
.pr-info h3 { font-size: clamp(1.3rem, 2.6vw, 1.7rem); font-weight: 480; }
.pr-info p { color: var(--muted); margin-top: 5px; font-size: 0.95rem; }
.pr-price { text-align: right; flex: none; display: flex; flex-direction: column; align-items: flex-end; gap: 3px; }
.pr-tl { font-family: var(--font-display); font-style: italic; font-weight: 460; font-size: clamp(1.4rem, 3vw, 1.9rem); color: var(--acid); line-height: 1; white-space: nowrap; }
.pr-eur { font-family: var(--font-mono); font-size: 0.8rem; color: var(--muted); }
.pr-note { font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.09em; text-transform: uppercase; color: var(--faint); margin-top: 2px; }
@media (max-width: 620px) { .price-row { flex-direction: column; gap: 10px; } .pr-price { text-align: left; align-items: flex-start; } }

/* ---- Hero tek kolon (maskot kaldırıldı) ---- */
.hero { min-height: auto; padding-top: 150px; padding-bottom: 40px; }
.hero-solo { max-width: 980px; }
.hero-solo h1 { font-size: clamp(2.8rem, 9vw, 6.4rem); }
.hl1 { display: inline; }

/* ---- Hero altı marka şeridi ---- */
.brand-band { padding-block: 4px 8px; }
.brand-band .logo-strip { margin-top: 8px; padding-top: 26px; }

/* ---- PİKO Chatbot (sağ alt) ---- */
.piko-chat { position: fixed; right: clamp(14px, 3vw, 28px); bottom: clamp(14px, 3vw, 28px); z-index: 95; display: flex; flex-direction: column; align-items: flex-end; gap: 14px; }
.pc-launch { position: relative; width: 74px; height: 74px; border-radius: 50%; background: var(--surface); border: 1px solid var(--border-2); box-shadow: var(--shadow); display: grid; place-items: center; transition: transform 0.3s var(--ease-bounce); cursor: pointer; }
.pc-launch:hover { transform: scale(1.06); }
.pc-launch .piko { width: 56px; animation: floaty 4s ease-in-out infinite; }
.pc-launch .piko svg { filter: drop-shadow(0 8px 14px rgba(0, 0, 0, 0.4)); }
.pc-ping { position: absolute; top: 5px; right: 5px; width: 13px; height: 13px; border-radius: 50%; background: var(--acid); border: 2px solid var(--surface); }
.pc-panel { width: min(370px, calc(100vw - 28px)); height: min(540px, calc(100vh - 130px)); background: var(--surface); border: 1px solid var(--border-2); border-radius: 22px; box-shadow: var(--shadow); display: flex; flex-direction: column; overflow: hidden; }
.pc-panel[hidden] { display: none; }
.pc-panel.opening { animation: pcIn 0.36s var(--ease-bounce); }
@keyframes pcIn { from { opacity: 0; transform: translateY(24px) scale(0.92); } }
.pc-head { display: flex; align-items: center; gap: 11px; padding: 14px 16px; border-bottom: 1px solid var(--border); background: var(--bg-2); }
.pc-ava { width: 40px; height: 40px; border-radius: 50%; overflow: hidden; background: var(--surface-2); border: 1px solid var(--border); display: grid; place-items: center; flex: none; }
.pc-ava svg { width: 116%; height: 116%; }
.pc-id { display: flex; flex-direction: column; line-height: 1.25; }
.pc-id strong { font-family: var(--font-display); font-size: 1.02rem; font-weight: 500; }
.pc-id span { font-family: var(--font-mono); font-size: 0.62rem; color: var(--acid); letter-spacing: 0.04em; }
.pc-close { margin-left: auto; width: 30px; height: 30px; border-radius: 50%; color: var(--muted); display: grid; place-items: center; font-size: 1rem; }
.pc-close:hover { color: var(--text); background: var(--surface-2); }
.pc-log { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.pc-msg { max-width: 86%; padding: 10px 13px; border-radius: 15px; font-size: 0.92rem; line-height: 1.45; animation: pcMsg 0.3s var(--ease) both; }
@keyframes pcMsg { from { opacity: 0; transform: translateY(6px); } }
.pc-msg.bot { align-self: flex-start; background: var(--surface-2); border: 1px solid var(--border); border-bottom-left-radius: 4px; }
.pc-msg.me { align-self: flex-end; background: var(--acid); color: #0c0c0a; font-weight: 500; border-bottom-right-radius: 4px; }
.pc-msg.bot a { color: var(--acid); text-decoration: underline; font-weight: 600; }
.pc-msg.typing { display: inline-flex; gap: 4px; align-items: center; }
.pc-msg.typing i { width: 6px; height: 6px; border-radius: 50%; background: var(--muted); animation: typeDot 1.2s infinite; }
.pc-msg.typing i:nth-child(2) { animation-delay: 0.2s; }
.pc-msg.typing i:nth-child(3) { animation-delay: 0.4s; }
.pc-quick { display: flex; flex-wrap: wrap; gap: 7px; padding: 0 14px 12px; }
.pc-quick button { font-family: var(--font-mono); font-size: 0.72rem; padding: 8px 12px; border-radius: 100px; border: 1px solid var(--border-2); color: var(--text); background: transparent; transition: all 0.2s; }
.pc-quick button:hover { border-color: var(--acid); color: var(--acid); background: rgba(205, 255, 79, 0.08); }
.pc-form { display: flex; gap: 8px; padding: 12px 14px; border-top: 1px solid var(--border); background: var(--bg-2); }
.pc-form input { flex: 1; background: var(--surface); border: 1px solid var(--border-2); border-radius: 100px; padding: 11px 16px; color: var(--text); font-size: 0.92rem; outline: none; font-family: var(--font-body); }
.pc-form input:focus { border-color: var(--acid); }
.pc-form button { width: 42px; height: 42px; flex: none; border-radius: 50%; background: var(--acid); color: #0c0c0a; display: grid; place-items: center; font-size: 1.2rem; font-weight: 700; transition: transform 0.2s var(--ease-bounce); }
.pc-form button:hover { transform: scale(1.08); }
[data-theme="light"] .pc-msg.me, [data-theme="light"] .pc-form button { color: #FBF9F3; }
@media (max-width: 480px) { .piko-chat { right: 12px; bottom: 12px; } .pc-launch { width: 62px; height: 62px; } .pc-launch .piko { width: 46px; } }

/* ---- Menü: responsive iyileştirmeler ---- */
@media (max-width: 860px) {
  .lang-switch button { padding: 7px 9px 6px; }
  .nav-actions { gap: 7px; }
}
@media (max-width: 600px) {
  .nav .brand span { display: none; }
  .nav-actions { gap: 5px; }
}
@media (max-width: 420px) {
  .mac-link.mac-icon { display: none; }
}


/* ============================================================
   EEC DESIGN REVOLUTION v20 — THE ULTIMATE EDITORIAL MODERN DESIGN
   ============================================================ */

/* ---------- 1. EDITORIAL GRID & ARCHITECTURE ---------- */
@media (min-width: 1200px) {
  body::after {
    content: "";
    position: fixed;
    inset: 0;
    left: 50%;
    transform: translateX(-50%);
    width: var(--maxw);
    border-left: 1px solid rgba(236, 234, 224, 0.04);
    border-right: 1px solid rgba(236, 234, 224, 0.04);
    pointer-events: none;
    z-index: -1;
    background-image: linear-gradient(to right, rgba(236, 234, 224, 0.04) 1px, transparent 1px);
    background-size: 33.333% 100%;
  }
  [data-theme="light"] body::after {
    border-color: rgba(10, 10, 25, 0.04);
    background-image: linear-gradient(to right, rgba(10, 10, 25, 0.04) 1px, transparent 1px);
  }
}

section {
  padding-block: clamp(70px, 9vw, 120px) !important;
  border-bottom: 1px solid var(--border);
  background: transparent !important;
}

/* ---------- 2. HEADER & NAVIGATION ---------- */
.site-header {
  position: fixed;
  top: 0;
  inset-inline: 0;
  z-index: 100;
  height: 76px;
  background: linear-gradient(180deg, rgba(12,12,10,0.85) 0%, rgba(12,12,10,0) 100%);
  backdrop-filter: none;
  border-bottom: 1px solid transparent;
  transition: background 0.4s var(--ease), border-color 0.4s, backdrop-filter 0.4s;
  max-width: none;
  margin: 0;
  border-radius: 0;
  box-shadow: none;
}
.site-header.scrolled {
  background: rgba(12, 12, 10, 0.88) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border-bottom-color: rgba(236, 234, 224, 0.08);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .site-header {
  background: linear-gradient(180deg, rgba(244,244,248,0.9) 0%, rgba(244,244,248,0) 100%);
}
[data-theme="light"] .site-header.scrolled {
  background: rgba(244, 244, 248, 0.9) !important;
  border-bottom-color: rgba(10, 10, 25, 0.08);
}

.nav {
  height: 100%;
  padding-inline: var(--gut);
}
.nav-links a {
  position: relative;
  font-family: var(--font-sans);
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--muted);
  padding: 8px 12px;
  transition: color 0.35s var(--ease);
  background: none !important;
  border: none !important;
  box-shadow: none !important;
}
.nav-links a::after {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: calc(100% - 24px);
  height: 1px;
  background: var(--acid);
  transition: transform 0.4s var(--ease);
  transform-origin: center;
}
.nav-links a:hover {
  color: var(--text);
}
.nav-links a:hover::after {
  transform: translateX(-50%) scaleX(1);
}
.nav-links a.active {
  color: var(--text) !important;
}
.nav-links a.active::after {
  transform: translateX(-50%) scaleX(1);
}

.brand {
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.02em;
}

/* Minimalist Nav CTA */
.nav-cta-desktop {
  border-radius: 4px !important;
  padding: 10px 20px !important;
  font-size: 0.85rem !important;
  background: var(--text) !important;
  color: var(--bg) !important;
  border: 1px solid transparent !important;
  box-shadow: none !important;
}
.nav-cta-desktop:hover {
  background: transparent !important;
  color: var(--text) !important;
  border-color: var(--text) !important;
}

/* Mobile Nav Overlay */
@media (max-width: 860px) {
  .nav-links {
    position: fixed;
    inset: 76px 0 auto 0;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    background: rgba(12, 12, 10, 0.96);
    backdrop-filter: blur(28px) saturate(180%);
    -webkit-backdrop-filter: blur(28px) saturate(180%);
    border-bottom: 1px solid var(--border);
    padding: 32px var(--gut) 48px;
    transform: translateY(-130%);
    transition: transform 0.5s var(--ease-bounce);
    border-radius: 0;
    box-shadow: 0 20px 40px rgba(0,0,0,0.4);
  }
  .nav-links.open { transform: translateY(0); }
  .nav-links a { font-size: 1.4rem; padding: 12px; }
}

/* ---------- 3. EDITORIAL TYPOGRAPHY & HERO ---------- */
.hero-copy h1 {
  font-family: var(--font-sans) !important;
  font-size: clamp(3.2rem, 8vw, 6.5rem) !important;
  line-height: 1.0 !important;
  letter-spacing: -0.035em !important;
  font-weight: 500 !important;
  margin-bottom: 32px;
}
.hero-copy h1 em, .hero-copy h1 .grad-text {
  font-family: var(--font-display) !important;
  font-style: italic;
  font-weight: 400 !important;
  background: none;
  -webkit-text-fill-color: currentColor;
  color: var(--text);
}
.hero-sub {
  font-family: var(--font-body);
  font-size: clamp(1.15rem, 2.4vw, 1.45rem);
  line-height: 1.6;
  color: var(--muted);
  max-width: 640px;
  margin-bottom: 48px;
}
.hero-meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding-block: 24px;
  margin-top: 60px;
  width: 100%;
  max-width: 800px;
  gap: 0 !important;
}
.hero-meta .stat {
  text-align: center;
  border-right: 1px solid var(--border);
}
.hero-meta .stat:last-child {
  border-right: none;
}
.hero-meta .stat .n {
  font-family: var(--font-mono);
  font-size: 1.6rem !important;
  font-weight: 400 !important;
  color: var(--acid) !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
  font-style: normal !important;
}
.hero-meta .stat .l {
  font-family: var(--font-sans);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--faint);
  margin-top: 6px;
}

/* Remove cheesy glowing blobs */
.hero::before, .stage-glow, .stage-ring, .orbit-chip { display: none !important; }

/* Eyebrow & Sections */
.eyebrow {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  color: var(--acid) !important;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  font-weight: 500;
}
.eyebrow::before {
  content: "";
  display: inline-block;
  width: 32px;
  height: 1px;
  background: var(--acid);
  margin-right: 12px;
  vertical-align: middle;
}
.h-section {
  font-family: var(--font-sans);
  font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: 1.05;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin-top: 24px;
}
.h-section .grad-text {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  color: var(--acid);
}

/* ---------- 4. ARCHITECTURAL SERVICES GRID ---------- */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
  margin-top: 60px;
}
.svc-card {
  border: none !important;
  border-right: 1px solid var(--border) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 60px 48px;
  background: transparent !important;
  transition: background-color 0.5s var(--ease), border-color 0.5s var(--ease) !important;
  box-shadow: none !important;
  transform: none !important;
}
.svc-card::before, .svc-card::after { display: none !important; }
.svc-card:hover {
  background-color: rgba(255, 255, 255, 0.02) !important;
  border-right-color: var(--acid) !important;
  border-bottom-color: var(--acid) !important;
}
.svc-num {
  position: static !important;
  display: block;
  font-family: var(--font-mono);
  color: var(--acid) !important;
  font-size: 0.85rem;
  margin-bottom: 24px;
}
.svc-icon { display: none !important; }
.svc-card h3 {
  font-family: var(--font-sans);
  font-size: 2.2rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
}
.svc-tag {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted) !important;
}
.svc-card p {
  font-size: 1.05rem;
  color: var(--muted);
  line-height: 1.6;
  margin-top: 16px;
}
.svc-list { margin-top: 24px; }
.svc-list span {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid var(--border);
}

@media (max-width: 860px) {
  .svc-grid { grid-template-columns: 1fr; border-left: none; }
  .svc-card { border-right: none !important; padding: 48px 24px; }
}

/* ---------- 5. PORTFOLIO SHOWCASE (NO IFRAMES) ---------- */
.work-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 48px;
  margin-top: 60px;
}
.work-card {
  border: none !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  transition: transform 0.6s var(--ease) !important;
  padding: 0 !important;
}
.work-card::after { display: none !important; }
.work-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: none !important;
}
.work-card .frame {
  border-radius: 4px;
  border: 1px solid var(--border);
  aspect-ratio: 16 / 10.5;
  background: var(--surface-2);
  overflow: hidden;
  margin-bottom: 24px;
  position: relative;
}
.work-card .frame img.poster {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.8s var(--ease);
  position: relative;
  z-index: 2;
}
.work-card:hover .frame img.poster {
  transform: scale(1.04);
}
.frame .live-badge { display: none; }
.browser-bar { display: none; } /* Remove the fake browser bar for a cleaner gallery look */

.work-meta {
  padding: 0 !important;
  display: block !important;
}
.work-meta .t { display: block !important; }
.brand-logo { display: none !important; }
.work-meta h3 {
  font-family: var(--font-sans);
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.work-tag {
  font-family: var(--font-mono);
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted) !important;
  margin-top: 8px;
}
.work-visit { display: none !important; }

@media (max-width: 860px) {
  .work-grid { grid-template-columns: 1fr; gap: 40px; }
}

/* ---------- 6. PROCESS GRID ---------- */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--border);
  border-left: 1px solid var(--border);
  margin-top: 60px;
}
.step {
  border: none !important;
  border-right: 1px solid var(--border) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: 0 !important;
  padding: 48px 32px;
  background: transparent !important;
}
.step .k {
  font-family: var(--font-mono);
  font-size: 1.1rem !important;
  font-weight: 500 !important;
  color: var(--acid) !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
  margin-bottom: 24px;
}
.step h3 {
  font-family: var(--font-sans);
  font-size: 1.6rem;
  font-weight: 500;
  margin-bottom: 12px;
}
.step p {
  font-size: 1.05rem;
  color: var(--muted);
  line-height: 1.6;
}
.step .piko-say {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 0.95rem;
  color: var(--faint);
  border-left: none;
  padding-left: 0;
  margin-top: 20px;
}
@media (max-width: 860px) {
  .steps { grid-template-columns: 1fr; border-left: none; }
  .step { border-right: none !important; padding: 40px 24px; }
}

/* ---------- 7. PRICING & CTA ---------- */
.price-list {
  border-top: 1px solid var(--border);
  margin-top: 40px;
}
.price-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 32px 0;
  border-bottom: 1px solid var(--border);
  transition: padding-left 0.4s var(--ease);
}
.price-row:hover {
  padding-left: 20px;
}
.pr-info h3 {
  font-family: var(--font-sans);
  font-size: 1.3rem;
  font-weight: 500;
}
.pr-info p {
  font-size: 0.95rem;
  color: var(--muted);
  margin-top: 6px;
}
.pr-price {
  text-align: right;
}
.pr-price .pr-tl {
  display: block;
  font-family: var(--font-mono);
  font-size: 1.25rem;
  color: var(--text);
}
.pr-price .pr-note {
  display: block;
  font-size: 0.8rem;
  color: var(--faint);
  margin-top: 4px;
}
.pr-express {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px !important;
}

.cta-inner {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  border-radius: 4px;
  padding: clamp(60px, 10vw, 120px) var(--gut);
}
.cta-inner h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  letter-spacing: -0.02em;
}

/* Custom Buttons */
.btn {
  border-radius: 4px !important;
  font-family: var(--font-mono);
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 500;
  box-shadow: none !important;
}
.btn-primary { background: var(--text) !important; color: var(--bg) !important; }
.btn-primary:hover { background: transparent !important; color: var(--text) !important; border: 1px solid var(--text); transform: none !important; }
.btn-ghost { border-radius: 4px !important; }

/* ---------- 8. PREMIUM CUSTOM CURSOR ---------- */
.custom-cursor { display: none; }
@media (pointer: fine) {
  .custom-cursor { display: block; position: fixed; top: 0; left: 0; width: 100vw; height: 100vh; z-index: 99999; pointer-events: none; mix-blend-mode: difference; }
  .cursor-dot { position: fixed; width: 6px; height: 6px; background: #ffffff; border-radius: 50%; transform: translate(-50%, -50%); transition: width 0.2s var(--ease), height 0.2s var(--ease); z-index: 100000; pointer-events: none; }
  .cursor-follower { position: fixed; width: 36px; height: 36px; border: 1px solid rgba(255,255,255,0.4); border-radius: 50%; transform: translate(-50%, -50%); transition: width 0.3s var(--ease), height 0.3s var(--ease), border-color 0.3s var(--ease), background 0.3s var(--ease), transform 0.1s linear; z-index: 99999; pointer-events: none; display: flex; align-items: center; justify-content: center; }
  .cursor-follower::after { content: ""; opacity: 0; font-family: var(--font-mono); font-size: 0.7rem; color: #000; letter-spacing: 0.05em; transition: opacity 0.2s var(--ease); }
  
  .custom-cursor.hovering .cursor-dot { width: 4px; height: 4px; }
  .custom-cursor.hovering .cursor-follower { width: 56px; height: 56px; background: #ffffff; border-color: #ffffff; }
  
  .custom-cursor.hover-card .cursor-dot { opacity: 0; }
  .custom-cursor.hover-card .cursor-follower { width: 80px; height: 80px; background: #ffffff; border-color: #ffffff; }
  .custom-cursor.hover-card .cursor-follower::after { content: attr(data-label); opacity: 1; }
}

/* Utilities */
.hidden { display: none !important; }
.mt-0 { margin-top: 0; }


/* ============================================================
   NIGHT LAMP THEME TOGGLE & FULLSCREEN MENU LOGIC
   ============================================================ */
/* Default Light Theme */
:root {
  --bg: #FAFAFA !important;
  --bg-2: #FFFFFF !important;
  --surface: #FFFFFF !important;
  --surface-2: #F4F4F8 !important;
  --border: rgba(0, 0, 0, 0.08) !important;
  --border-2: rgba(0, 0, 0, 0.15) !important;
  --text: #111111 !important;
  --muted: #555555 !important;
  --faint: #999999 !important;
  --acid: #111111 !important;
  --acid-deep: #000000 !important;
}

[data-theme="dark"] {
  --bg: #0C0C0A !important;
  --bg-2: #100F0B !important;
  --surface: #15140F !important;
  --surface-2: #1C1A14 !important;
  --border: rgba(236, 234, 224, 0.10) !important;
  --border-2: rgba(236, 234, 224, 0.18) !important;
  --text: #ECEAE0 !important;
  --muted: #9D998C !important;
  --faint: #6A655A !important;
  --acid: #CDFF4F !important;
  --acid-deep: #A6E22E !important;
}

body { background: var(--bg) !important; color: var(--text) !important; }

.grad-text {
  background: none !important;
  -webkit-text-fill-color: var(--text) !important;
  color: var(--text) !important;
  font-family: var(--font-display) !important;
  font-style: italic !important;
  font-weight: 400 !important;
}

.svc-card, .step, .price-row { background: transparent !important; }
.svc-card:hover {
  background: var(--surface) !important;
  border-right-color: var(--text) !important;
  border-bottom-color: var(--text) !important;
}
.svc-num, .step .k { color: var(--text) !important; }
.eyebrow { color: var(--text) !important; }
.eyebrow::before { background: var(--text) !important; }
.btn-primary { background: var(--text) !important; color: var(--bg) !important; border: 1px solid var(--text) !important; }
.btn-primary:hover { background: transparent !important; color: var(--text) !important; }
.btn-ghost { border: 1px solid var(--border) !important; color: var(--text) !important; }
.btn-ghost:hover { border-color: var(--text) !important; }

.site-header {
  background: transparent !important; backdrop-filter: none !important; -webkit-backdrop-filter: none !important; border-bottom: none !important; box-shadow: none !important; transition: padding 0.4s var(--ease), background 0.4s var(--ease);
}
.site-header.scrolled {
  background: var(--bg) !important; backdrop-filter: blur(20px) !important; -webkit-backdrop-filter: blur(20px) !important; border-bottom: 1px solid var(--border) !important; opacity: 0.95;
}
.brand span { color: var(--text) !important; }
.brand .dot { color: var(--text) !important; }

/* Menu Toggle Button */
.menu-toggle-btn {
  width: 48px; height: 48px; border-radius: 50%; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 6px; background: transparent; border: 1px solid transparent; transition: all 0.3s cubic-bezier(0.22, 1, 0.36, 1); z-index: 10000; position: relative; cursor: pointer;
}
.menu-toggle-btn:hover { background: rgba(128, 128, 128, 0.1); }
.mt-line { display: block; width: 24px; height: 2px; background: var(--text); transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); transform-origin: center; }
.menu-toggle-btn.is-open .mt-line:nth-child(1) { transform: translateY(4px) rotate(45deg); }
.menu-toggle-btn.is-open .mt-line:nth-child(2) { transform: translateY(-4px) rotate(-45deg); }

/* FULLSCREEN OVERLAY MENU */
.fs-menu-overlay { position: fixed; inset: 0; width: 100vw; height: 100vh; z-index: 9999; visibility: hidden; pointer-events: none; display: flex; align-items: center; justify-content: center; }
.fs-menu-overlay.is-open { visibility: visible; pointer-events: auto; }
.fs-menu-bg { position: absolute; inset: 0; background: var(--bg); transform: translateY(-100%); transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1); }
.fs-menu-overlay.is-open .fs-menu-bg { transform: translateY(0); }
.fs-menu-inner { position: relative; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: center; padding-top: 80px; padding-bottom: 40px; }
.fs-nav-links { display: flex; flex-direction: column; gap: 1vh; margin-top: 40px; }
.fs-link { font-family: var(--font-display); font-size: clamp(3rem, 7vw, 6.5rem); line-height: 1.0; font-weight: 400; color: var(--text); text-decoration: none; letter-spacing: -0.02em; position: relative; display: inline-block; align-self: flex-start; overflow: hidden; opacity: 0; transform: translateY(40px); transition: opacity 0.4s cubic-bezier(0.22, 1, 0.36, 1), transform 0.6s cubic-bezier(0.22, 1, 0.36, 1); }
.fs-menu-overlay.is-open .fs-link { opacity: 1; transform: translateY(0); }
.fs-menu-overlay.is-open .fs-link:nth-child(1) { transition-delay: 0.2s; }
.fs-menu-overlay.is-open .fs-link:nth-child(2) { transition-delay: 0.25s; }
.fs-menu-overlay.is-open .fs-link:nth-child(3) { transition-delay: 0.3s; }
.fs-menu-overlay.is-open .fs-link:nth-child(4) { transition-delay: 0.35s; }
.fs-menu-overlay.is-open .fs-link:nth-child(5) { transition-delay: 0.4s; }
.fs-menu-overlay.is-open .fs-link:nth-child(6) { transition-delay: 0.45s; }
.fs-link::before { content: attr(data-text); position: absolute; top: 0; left: 0; color: var(--acid); font-style: italic; transform: translateY(100%); transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1); }
.fs-link:hover::before { transform: translateY(0); }
.fs-link:hover { color: transparent; }
.fs-menu-footer { margin-top: auto; display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; opacity: 0; transform: translateY(20px); transition: opacity 0.4s 0.6s cubic-bezier(0.22, 1, 0.36, 1), transform 0.4s 0.6s cubic-bezier(0.22, 1, 0.36, 1); border-top: 1px solid var(--border); padding-top: 32px; }
.fs-menu-overlay.is-open .fs-menu-footer { opacity: 1; transform: translateY(0); }
.fs-contact, .fs-social { display: flex; flex-direction: column; gap: 8px; }
.fs-menu-footer span { font-family: var(--font-mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--faint); margin-bottom: 8px; }
.fs-menu-footer a { font-family: var(--font-sans); font-size: 1.1rem; font-weight: 500; color: var(--text); transition: opacity 0.3s; }
.fs-menu-footer a:hover { opacity: 0.6; }
@media (max-width: 860px) { .fs-link { font-size: clamp(2.5rem, 10vw, 4rem); } .fs-menu-footer { grid-template-columns: 1fr; gap: 32px; } }

/* ============================================================
   NIGHT LAMP THEME TOGGLE
   ============================================================ */

.lamp-toggle-btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  transition: all 0.3s var(--ease);
  cursor: pointer;
  position: relative;
  color: #111;
  z-index: 10000;
}
.lamp-toggle-btn:hover {
  background: rgba(0, 0, 0, 0.04);
}
[data-theme="dark"] .lamp-toggle-btn {
  color: #ECEAE0;
}
[data-theme="dark"] .lamp-toggle-btn:hover {
  background: rgba(255, 255, 255, 0.08);
}

.lamp-icon {
  width: 24px;
  height: 24px;
  overflow: visible;
}
.lamp-shade {
  transition: fill 0.3s var(--ease), filter 0.3s var(--ease);
  fill: transparent;
}
.lamp-string {
  transition: transform 0.1s ease-in-out;
}
.lamp-string-pull {
  transition: transform 0.1s ease-in-out;
}
.lamp-glow {
  opacity: 0;
  transition: opacity 0.4s var(--ease);
  fill: #FFD700;
  filter: blur(8px);
}

/* Clicking animation */
.lamp-toggle-btn:active .lamp-string,
.lamp-toggle-btn:active .lamp-string-pull {
  transform: translateY(4px);
}

/* Dark Mode (Lamp ON) */
[data-theme="dark"] .lamp-shade {
  fill: rgba(255, 215, 0, 0.9); /* Warm yellow glow */
  filter: drop-shadow(0 0 12px rgba(255, 215, 0, 0.8)) drop-shadow(0 0 24px rgba(255, 140, 0, 0.5));
  stroke: #FFD700;
}
[data-theme="dark"] .lamp-glow {
  opacity: 0.4;
}

/* Light Mode (Lamp OFF) */
[data-theme="light"] .lamp-shade {
  fill: transparent;
  stroke: #111;
}


/* ============================================================
   AESTHETIC ADJUSTMENTS: LOGO, SPACING, TYPOGRAPHY & NEW LAMP
   ============================================================ */

/* 1. Fix Logo Visibility in Light Mode (Invert white logo to black) */
.brand img {
  filter: invert(1) brightness(0.2); /* Make it black for light mode */
  transition: filter 0.3s ease;
}
[data-theme="dark"] .brand img {
  filter: invert(0) brightness(1); /* Keep it white for dark mode */
}

/* 2. Refined Typography (Smaller, more elegant) */
.hero-copy h1 {
  font-size: clamp(2.4rem, 4.5vw, 4.8rem) !important; /* Reduced from 6.5rem */
  line-height: 1.15 !important;
  letter-spacing: -0.03em !important;
}
.fs-link {
  font-size: clamp(2.5rem, 5vw, 4.5rem) !important; /* Reduced from 6.5rem */
}
.h-section {
  font-size: clamp(2rem, 3.5vw, 3.2rem) !important; /* Reduced from 4rem */
  line-height: 1.1 !important;
}

/* 3. Massive Whitespace (Breathing Room) */
section {
  padding-block: clamp(80px, 10vw, 140px) !important; /* Reduced from 260px max */
}

/* 4. Detailed Hanging Lamp CSS */
.lamp-toggle-btn {
  width: 56px;
  height: 64px; /* Taller for the hanging wire */
  display: flex; align-items: flex-start; justify-content: center;
  background: transparent; border: none; cursor: pointer;
  position: relative; color: #111; z-index: 10000;
}
.lamp-icon { width: 36px; height: 36px; overflow: visible; }
.lamp-shade { fill: #FAFAFA; transition: fill 0.3s ease, filter 0.3s ease; stroke: currentColor; }
.lamp-glow-bulb { fill: transparent; transition: fill 0.3s ease; stroke: currentColor; }
.lamp-string, .lamp-string-pull { transition: transform 0.15s cubic-bezier(0.34, 1.56, 0.64, 1); }

/* Lamp Animation */
.lamp-toggle-btn:active .lamp-string,
.lamp-toggle-btn:active .lamp-string-pull {
  transform: translateY(6px);
}

/* Dark Mode Lamp ON */
[data-theme="dark"] .lamp-toggle-btn { color: #EFE7D4; }
[data-theme="dark"] .lamp-shade {
  fill: rgba(255, 200, 50, 0.85); /* Retro warm yellow */
  filter: drop-shadow(0 0 16px rgba(255, 180, 0, 0.6)) drop-shadow(0 0 32px rgba(255, 140, 0, 0.4));
  stroke: #FFB400;
}
[data-theme="dark"] .lamp-glow-bulb {
  fill: #FFF;
  stroke: #FFF;
  filter: drop-shadow(0 0 8px #FFF);
}
[data-theme="dark"] .lamp-rays {
  opacity: 0.6;
  stroke: #FFB400;
}


/* ============================================================
   APPLE TYPOGRAPHY & LAYOUT REFINEMENTS
   ============================================================ */

/* 1. Apple Native Typography */
:root {
  --font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "San Francisco", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
  --font-display: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "San Francisco", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}
body {
  font-family: var(--font-sans) !important;
}
.grad-text, .fs-link, h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display) !important;
  letter-spacing: -0.04em !important; /* Authentic Apple tight tracking for large headers */
}

/* 2. Menu and Hero Spacing Reduction */
section.hero {
  padding-top: clamp(100px, 12vw, 140px) !important; /* Reduced to bring it closer to menu */
}
.hero-copy {
  margin-top: 0 !important;
}

/* 3. Reference Logos: Side-by-side & Grayscale Hover */
.logo-strip {
  margin-top: 40px !important;
  margin-bottom: 80px !important;
}
.logo-marquee {
  overflow: visible !important;
  white-space: normal !important;
}
.logo-track {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 40px 60px !important;
  animation: none !important; /* Stop the scrolling marquee */
  width: 100% !important;
}
.lm[aria-hidden="true"] {
  display: none !important; /* Hide duplicate marquee logos */
}
.lm {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.lm img {
  filter: grayscale(100%) opacity(0.5) !important;
  transition: filter 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
  max-width: 130px !important;
  height: auto !important;
}
.lm:hover img {
  filter: grayscale(0%) opacity(1) !important;
}


/* ============================================================
   SMART LOGO STRIP (Auto-White Detection)
   ============================================================ */

/* Base State: All logos are uniform dark gray (sleek and modern) */
.lm img {
  filter: grayscale(100%) contrast(0) brightness(0) opacity(0.35) !important;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
  max-width: 140px !important;
}

/* Hover State for Normal (Colored) Logos: Reveal full original color */
.lm:hover img {
  filter: grayscale(0%) contrast(1) brightness(1) opacity(1) !important;
  transform: scale(1.05);
}

/* Hover State for White Logos in Light Mode: Turn solid black instead of white */
body:not([data-theme="dark"]) .lm:hover img.is-white-logo {
  filter: grayscale(100%) contrast(0) brightness(0) opacity(1) !important;
}

/* Dark Mode Overrides */
[data-theme="dark"] .lm img {
  filter: grayscale(100%) contrast(0) brightness(2) opacity(0.4) !important; /* Uniform light gray */
}
[data-theme="dark"] .lm:hover img {
  filter: grayscale(0%) contrast(1) brightness(1) opacity(1) !important;
}
/* White logos in Dark Mode stay pure white on hover */
[data-theme="dark"] .lm:hover img.is-white-logo {
  filter: grayscale(100%) contrast(0) brightness(2) opacity(1) !important;
}


/* Mercedes Typography for Reference Logo */
.mercedes-logo-text {
  font-family: Baskerville, "Playfair Display", "Times New Roman", Times, serif !important;
  font-size: 19px !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  color: #111 !important;
  white-space: nowrap !important;
  opacity: 0.35 !important;
  transition: opacity 0.4s cubic-bezier(0.22, 1, 0.36, 1), transform 0.4s cubic-bezier(0.22, 1, 0.36, 1) !important;
  text-transform: uppercase !important;
}
.lm:hover .mercedes-logo-text {
  opacity: 1 !important;
  transform: scale(1.05) !important;
}
[data-theme="dark"] .mercedes-logo-text {
  color: #ECEAE0 !important;
}


/* ============================================================
   MAKE LOGOS FULLY OPAQUE
   ============================================================ */

/* Base State: Fully opaque, solid black (in light mode) */
.lm img {
  filter: grayscale(100%) contrast(0) brightness(0) opacity(1) !important;
}
.mercedes-logo-text {
  opacity: 1 !important;
}

/* Dark Mode Overrides: Fully opaque, solid white/light gray */
[data-theme="dark"] .lm img {
  filter: grayscale(100%) contrast(0) brightness(2) opacity(1) !important; 
}


/* ============================================================
   FIT LOGOS ON A SINGLE LINE
   ============================================================ */

.logo-track {
  flex-wrap: nowrap !important;
  justify-content: space-between !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 10px !important;
  gap: clamp(20px, 4vw, 60px) !important; /* Responsive gap */
}

/* Hide scrollbar for cleaner look */
.logo-track::-webkit-scrollbar {
  display: none !important;
}
.logo-track {
  -ms-overflow-style: none !important;  /* IE and Edge */
  scrollbar-width: none !important;  /* Firefox */
}

/* Make logos dynamically shrink to fit better */
.lm img {
  max-width: clamp(70px, 12vw, 120px) !important;
  flex-shrink: 0 !important; /* Keep their shape */
}

.mercedes-logo-text {
  font-size: clamp(12px, 2vw, 19px) !important;
  flex-shrink: 0 !important;
}


/* ============================================================
   PORTFOLIO (CASE STUDY) REDESIGN - AWWWARDS LEVEL
   ============================================================ */

/* 1. Simplify & Elevate the Card */
.work-card {
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.5s cubic-bezier(0.22, 1, 0.36, 1) !important;
  border: 1px solid rgba(0,0,0,0.04) !important;
  background: var(--glass-bg) !important;
}

/* 2. Premium Hover (TranslateY + Deep Soft Shadow) */
.work-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 24px 60px rgba(0,0,0,0.06) !important;
}
[data-theme="dark"] .work-card:hover {
  box-shadow: 0 24px 60px rgba(0,0,0,0.4) !important;
}

/* Diminish the colorful background/border glow to make it more professional */
.work-card::before {
  opacity: 0.05 !important; 
}
.work-card:hover::before {
  opacity: 0.1 !important;
}

/* 3. The Result Badge (Metrics - What Agencies Actually Sell) */
.result-badge {
  display: inline-block !important;
  margin-top: 14px !important;
  padding: 6px 12px !important;
  background: rgba(0, 0, 0, 0.04) !important;
  border-radius: 6px !important;
  font-family: var(--font-sans) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  letter-spacing: -0.01em !important;
  border: 1px solid rgba(0,0,0,0.03) !important;
}
[data-theme="dark"] .result-badge {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255,255,255,0.04) !important;
}

/* Fix spacing for the simplified meta section */
.work-meta .t {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 4px !important;
}

.work-meta .t h3 {
  margin: 0 !important;
}

/* 4. Mini Live Badge (Less distracting) */
.live-badge.mini {
  transform: scale(0.7) !important;
  transform-origin: top right !important;
  opacity: 0.7 !important;
}


/* ============================================================
   PIKO ROBOT ANIMATIONS
   ============================================================ */
.piko-hero-bot {
  width: 100%;
  max-width: 320px;
  height: auto;
  color: var(--text);
  animation: floatBot 4s ease-in-out infinite;
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.05));
}
[data-theme="dark"] .piko-hero-bot {
  filter: drop-shadow(0 20px 40px rgba(0,0,0,0.3));
}

@keyframes floatBot {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}

