:root {
  --bg: #0b0b0c;
  --case-bg: #121416;
  --text: #ffffff;
  --muted: rgba(255,255,255,.68);
  --soft: rgba(255,255,255,.45);
  --line: rgba(255,255,255,.10);
  --glass: rgba(255,255,255,.035);
  --glass-strong: rgba(255,255,255,.06);
  --gold: #F4C430;
  --gold-hover: #FFD95A;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: var(--bg);
  color: var(--text);
}
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
.page {
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  position: relative;
  overflow: hidden;
}
.ambient { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.ambient::before,
.ambient::after {
  content: "";
  position: absolute;
  width: 560px;
  height: 560px;
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  filter: blur(70px);
  animation: pulse 6s ease-in-out infinite alternate;
}
.ambient::before { top: -150px; left: -120px; }
.ambient::after { bottom: -220px; right: -160px; animation-delay: 1.2s; }
.ambient svg { position: absolute; inset: 0; width: 100%; height: 100%; opacity: .09; }
.container { max-width: 1280px; margin: 0 auto; }
.section { position: relative; z-index: 1; padding: 128px 80px; border-top: 1px solid rgba(255,255,255,.05); }
.hero { min-height: 100vh; display: flex; align-items: center; padding: 96px 80px; position: relative; z-index: 1; }
.hero-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; width: 100%; }
.badge-row { display: flex; flex-wrap: wrap; gap: 16px; align-items: center; margin-bottom: 32px; }
.badge { display: inline-flex; align-items: center; gap: 10px; padding: 8px 16px; border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.05); color: rgba(255,255,255,.72); font-size: 14px; }
.dot { width: 8px; height: 8px; border-radius: 999px; background: rgba(255,255,255,.65); }
h1, h2, h3, p { margin: 0; }
.hero-title { font-size: clamp(48px, 6vw, 86px); line-height: 1.05; letter-spacing: -0.055em; font-weight: 650; max-width: 900px; }
.hero-copy { margin-top: 40px; max-width: 680px; display: grid; gap: 22px; color: var(--muted); font-size: 18px; line-height: 1.8; }
.cta-row { margin-top: 40px; display: flex; flex-wrap: wrap; gap: 16px; align-items: center; }
.primary-btn, .secondary-btn, .link-btn { border: none; text-decoration: none; white-space: nowrap; }
.primary-btn { padding: 13px 28px; border-radius: 999px; background: var(--gold); color: #000; font-weight: 650; box-shadow: 0 12px 42px rgba(244,196,48,.28); transition: .25s ease; }
.primary-btn:hover { background: var(--gold-hover); transform: translateY(-1px) scale(1.02); }
.secondary-btn { padding: 13px 24px; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.03); color: var(--gold); transition: .25s ease; }
.secondary-btn:hover { color: var(--gold-hover); background: rgba(255,255,255,.06); }
.hero-visual { position: relative; max-width: 500px; aspect-ratio: 1; border-radius: 40px; border: 1px solid var(--line); background: var(--glass); backdrop-filter: blur(24px); overflow: hidden; box-shadow: 0 24px 80px rgba(0,0,0,.35); display: flex; align-items: center; justify-content: center; }
.grid-overlay { position: absolute; inset: 0; opacity: .18; display: grid; grid-template-columns: repeat(6,1fr); grid-template-rows: repeat(6,1fr); }
.grid-overlay div { border: 1px solid rgba(255,255,255,.06); }
.float-card { position: absolute; padding: 18px 20px; border-radius: 20px; border: 1px solid var(--line); background: rgba(255,255,255,.09); backdrop-filter: blur(18px); box-shadow: 0 18px 44px rgba(0,0,0,.25); animation: float 6s ease-in-out infinite; }
.float-card.top { top: 40px; left: 40px; }
.float-card.bottom { right: 40px; bottom: 56px; animation-duration: 7s; }
.float-card span { display: block; color: var(--soft); font-size: 14px; margin-bottom: 8px; }
.float-card strong { font-size: 20px; font-weight: 600; }
.core-circle { width: 160px; height: 160px; border-radius: 999px; border: 1px solid var(--line); background: rgba(255,255,255,.09); backdrop-filter: blur(20px); display: flex; align-items: center; justify-content: center; text-align: center; box-shadow: 0 0 80px rgba(255,255,255,.08); animation: pulse 3s ease-in-out infinite alternate; }
.core-circle span { display:block; color: var(--soft); font-size: 14px; }
.core-circle strong { display:block; font-size: 26px; margin: 4px 0; }
.kicker { color: var(--soft); text-transform: uppercase; letter-spacing: .2em; font-size: 13px; margin-bottom: 24px; }
.section-title { font-size: clamp(38px, 5vw, 68px); line-height: 1.08; letter-spacing: -.04em; font-weight: 650; max-width: 900px; }
.work-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 40px; margin-top: 80px; }
.card { border: 1px solid var(--line); background: var(--glass); border-radius: 32px; padding: 40px; transition: .35s ease; }
.card:hover { background: rgba(255,255,255,.055); transform: translateY(-4px); }
.category { display:inline-flex; padding: 9px 15px; border: 1px solid var(--line); border-radius: 999px; color: rgba(255,255,255,.52); background: rgba(255,255,255,.04); text-transform: uppercase; letter-spacing: .14em; font-size: 11px; }
.card h3 { margin-top: 28px; font-size: 30px; line-height: 1.15; letter-spacing: -.025em; }
.card p { margin-top: 22px; color: var(--muted); line-height: 1.75; font-size: 17px; }
.card-footer { margin-top: 36px; padding-top: 26px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; gap: 32px; align-items: flex-start; }
.label { color: var(--soft); font-size: 13px; margin-bottom: 8px; }
.impact-text { color: rgba(255,255,255,.82); line-height: 1.55; }
.text-link { color: var(--gold); background: none; border: none; text-decoration: underline; text-underline-offset: 5px; white-space: nowrap; flex-shrink: 0; }
.text-link:hover { color: var(--gold-hover); }
.leadership-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; max-width: 1120px; margin: 0 auto; }
.leadership-copy { color: var(--muted); font-size: 18px; line-height: 1.8; display: grid; gap: 26px; }
.kpi-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 24px; margin-top: 24px; }
.kpi { border: 1px solid var(--line); background: var(--glass); border-radius: 24px; padding: 24px; }
.kpi strong { display:block; font-size: 34px; margin-bottom: 8px; }
.kpi span { color: var(--soft); }
.build-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 80px; align-items: start; }
.form-card { border: 1px solid var(--line); background: rgba(255,255,255,.045); border-radius: 40px; padding: 40px; }
.audience-grid { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 12px; margin-top: 12px; margin-bottom: 28px; }
.audience-chip { padding: 16px 20px; border-radius: 18px; border: 1px solid var(--line); background: rgba(255,255,255,.03); color: rgba(255,255,255,.75); text-align: left; white-space: nowrap; transition:.2s; }
.audience-chip.active { background: #fff; color: #000; border-color: #fff; }
.field-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 20px; }
label { display:block; color: rgba(255,255,255,.45); font-size: 14px; margin-top: 20px; }
.req { color: var(--gold); }
input, select, textarea { width: 100%; margin-top: 12px; border: 1px solid var(--line); border-radius: 18px; background: rgba(0,0,0,.23); color: #fff; padding: 16px 18px; outline: none; }
textarea { resize: none; min-height: 120px; }
input:focus, select:focus, textarea:focus { border-color: rgba(244,196,48,.45); }
.error { color: #fca5a5; border: 1px solid rgba(248,113,113,.25); background: rgba(248,113,113,.10); padding: 10px 14px; border-radius: 12px; font-size: 14px; }
.case-page { min-height: 100vh; color: #fff; padding: 80px; }
.case-container { max-width: 1280px; margin: 0 auto; }
.case-hero { display:grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.case-title { font-size: clamp(46px, 5.6vw, 82px); line-height: 1.05; letter-spacing: -.05em; font-weight: 650; }
.case-desc { margin-top: 36px; color: var(--muted); font-size:18px; line-height: 1.8; }
.metric-row { margin-top: 44px; display: flex; flex-wrap: wrap; gap: 20px; }
.metric { flex: 1; min-width: 180px; border: 1px solid var(--line); background: var(--glass); border-radius: 24px; padding: 20px; }
.metric span { color: var(--soft); font-size: 14px; }
.metric strong { display:block; margin-top:10px; white-space: nowrap; }
.strategy-panel { border: 1px solid var(--line); background: var(--glass); border-radius: 40px; padding: 40px; overflow:hidden; }
.strategy-panel h3 { font-size: 40px; line-height: 1.12; letter-spacing: -.035em; }
.strategy-list { display:grid; gap: 14px; margin-top: 36px; }
.strategy-list div { border: 1px solid var(--line); background: var(--glass); border-radius: 18px; padding: 16px 18px; color: rgba(255,255,255,.76); }
.case-section { margin-top: 120px; padding-top: 72px; border-top: 1px solid var(--line); }
.two-col { display:grid; grid-template-columns: 1fr 1fr; gap:80px; }
.case-section h2 { font-size: clamp(36px, 4vw, 56px); line-height: 1.12; letter-spacing: -.035em; }
.case-section p { color: var(--muted); font-size:18px; line-height: 1.8; margin-bottom: 24px; }
.insight-grid, .impact-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 28px; }
.insight-card, .impact-card { border: 1px solid var(--line); background: var(--glass); border-radius: 28px; padding: 32px; }
.insight-card h3, .impact-card h3 { font-size: 25px; line-height: 1.15; }
.insight-card p, .impact-card p { margin-top: 18px; color: var(--muted); line-height: 1.7; }
.visual-image { position: relative; margin: -40px; height: 520px; overflow:hidden; }
.visual-image img { width: 100%; height: 100%; object-fit: cover; opacity:.9; }
.visual-overlay { position:absolute; inset:0; background: linear-gradient(to top, rgba(0,0,0,.7), transparent); }
.visual-caption { position:absolute; left:32px; right:32px; bottom:32px; border: 1px solid var(--line); background: rgba(0,0,0,.32); backdrop-filter: blur(16px); border-radius: 24px; padding: 24px; }
.back-btn { margin-bottom: 40px; color: var(--gold); background:none; border:none; text-decoration: underline; text-underline-offset: 5px; }
@keyframes pulse { from { opacity:.75; transform: scale(.98); } to { opacity:1; transform: scale(1.02); } }
@keyframes float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@media (max-width: 980px) {
  .hero, .section, .case-page { padding: 80px 28px; }
  .hero-grid, .leadership-grid, .build-grid, .case-hero, .two-col { grid-template-columns: 1fr; }
  .work-grid, .insight-grid, .impact-grid { grid-template-columns: 1fr; }
  .field-grid, .audience-grid, .kpi-grid { grid-template-columns: 1fr; }
  .floating-nav { width: calc(100% - 24px); overflow-x:auto; }
  .hero-visual { margin: 0 auto; }
  .card-footer { flex-direction: column; }
}
@media (max-width: 640px) {
  .hero-title, .case-title { font-size: 42px; }
  .section-title { font-size: 36px; }
  .floating-nav-inner { overflow-x:auto; }
}
#navMount { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); z-index: 50; }

/* --- Text overflow safety fixes for case-study cards and portfolio boxes --- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

.card,
.case-card,
.metric-card,
.kpi-card,
.impact-card,
.strategy-card,
.insight-card,
.work-card,
[class*="card"],
[class*="box"],
[class*="metric"],
[class*="impact"],
[class*="strategy"],
[class*="insight"] {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
}

.card *,
.case-card *,
.metric-card *,
.kpi-card *,
.impact-card *,
.strategy-card *,
.insight-card *,
.work-card *,
[class*="card"] *,
[class*="box"] *,
[class*="metric"] *,
[class*="impact"] *,
[class*="strategy"] *,
[class*="insight"] * {
  max-width: 100%;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: normal;
  white-space: normal;
}

button,
a,
.chip,
.badge,
.tag,
.pill,
[class*="chip"],
[class*="badge"],
[class*="tag"],
[class*="pill"] {
  white-space: normal;
  overflow-wrap: anywhere;
}

.work-card button,
.case-card button,
.inline-link,
.text-link,
a {
  white-space: nowrap;
}

@media (max-width: 768px) {
  .work-card button,
  .case-card button,
  .inline-link,
  .text-link,
  a {
    white-space: normal;
  }
}

/* --- v2 Hostinger layout hardening: prevent card text overflow --- */
.metric-row {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 20px !important;
}
.metric {
  min-width: 0 !important;
  width: 100% !important;
  flex: initial !important;
  overflow: hidden !important;
}
.metric strong,
.metric span,
.kpi strong,
.kpi span,
.card h3,
.card p,
.impact-text,
.strategy-panel h3,
.strategy-list div,
.insight-card h3,
.insight-card p,
.impact-card h3,
.impact-card p {
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  hyphens: auto !important;
  max-width: 100% !important;
}
.metric strong {
  font-size: 15px !important;
  line-height: 1.35 !important;
}
.metric span {
  display: block !important;
  line-height: 1.35 !important;
}
.card-footer {
  min-width: 0 !important;
}
.card-footer > div:first-child {
  min-width: 0 !important;
}
.text-link {
  white-space: nowrap !important;
}
@media (max-width: 1180px) {
  .metric-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 640px) {
  .metric-row {
    grid-template-columns: 1fr !important;
  }
  .text-link {
    white-space: normal !important;
  }
}
