/* ============================================================
   CCA — Competitive Culture Advertising
   Homepage V2 · Light editorial · logo blue + orange
   ============================================================ */

:root {
  --paper:  #F7F5F0;   /* warm off-white */
  --ink:    #0A0A0A;
  --orange: #FF6B00;   /* logo "CCA" text — primary accent */
  --orange-d: #E55F00;
  --blue:   #0052CC;   /* logo icon — secondary accent */
  --blue-d: #003F9E;
  --hair:   #E0DDD8;
  --warm:   #8A8278;   /* secondary warm grey text */
  --faint:  #B0A99F;   /* tertiary / captions */
  --faint2: #C0BBB5;
  --noir:   #0A0A0A;   /* dark sections */
  --panel:  #0F0F0F;
  --dline:  #1A1A1A;   /* hairlines on dark */
  --dwarm:  #3A3A3A;

  --syne: "Outfit", "Archivo", Helvetica, Arial, sans-serif;
  --dm: "DM Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;

  --pad: clamp(20px, 4.5vw, 56px);
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
html.smooth { scroll-behavior: smooth; }

body {
  font-family: var(--dm); font-weight: 300;
  background: var(--paper); color: var(--ink);
  overflow-x: hidden; line-height: 1.5;
}
@media (pointer: fine) { body { cursor: none; } }
::selection { background: var(--orange); color: #fff; }
a { color: inherit; text-decoration: none; }

.label { font-family: var(--dm); font-weight: 500; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--warm); }
.syne { font-family: var(--syne); }

/* section shell */
.section { padding: clamp(64px,10vh,120px) var(--pad); position: relative; }
.sec-label { display: block; font-family: var(--dm); font-weight: 500; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; color: var(--blue); margin-bottom: 26px; }
.sec-label .grey { color: var(--warm); }
.sec-title { font-family: var(--syne); font-weight: 800; font-size: clamp(36px,5vw,64px); line-height: 0.96; letter-spacing: -0.03em; }
.sec-intro { font-size: 15px; color: var(--warm); max-width: 480px; line-height: 1.7; margin-top: 22px; }

/* reveal */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ============ CURSOR ============ */
.cur-dot, .cur-ring { position: fixed; top: 0; left: 0; z-index: 9600; pointer-events: none; border-radius: 50%; translate: -50% -50%; }
.cur-dot { width: 8px; height: 8px; background: var(--orange); }
.cur-ring { width: 34px; height: 34px; border: 1px solid rgba(244,122,28,0.5); transition: width .3s var(--ease), height .3s var(--ease), background .3s var(--ease), border-color .3s var(--ease); }
.cur-ring.grow { width: 64px; height: 64px; background: rgba(244,122,28,0.08); border-color: var(--orange); }
@media (pointer: coarse) { .cur-dot, .cur-ring { display: none; } }
body.no-cursor { cursor: auto; }
body.no-cursor .cur-dot, body.no-cursor .cur-ring { display: none; }

/* ============ LOADER ============ */
.loader { position: fixed; inset: 0; z-index: 10000; background: var(--paper); display: flex; align-items: center; justify-content: center; transition: opacity .7s var(--ease), visibility 0s linear .7s; }
.loader.done { opacity: 0; visibility: hidden; pointer-events: none; }
.loader .lnum { font-family: var(--syne); font-weight: 800; font-size: clamp(64px,15vw,180px); letter-spacing: -0.05em; line-height: 1; color: var(--ink); }
.loader .lnum sup { font-size: 0.32em; color: var(--orange); vertical-align: super; }
.loader .lbar { position: absolute; left: var(--pad); right: var(--pad); bottom: var(--pad); height: 1px; background: var(--hair); }
.loader .lbar i { display: block; height: 100%; width: 0; background: var(--blue); }
.loader .lfoot { position: absolute; top: var(--pad); left: var(--pad); right: var(--pad); display: flex; justify-content: space-between; }

/* ============ NAV ============ */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 800; height: 60px; display: flex; align-items: center; justify-content: space-between; padding: 0 var(--pad); background: rgba(247,245,240,0.9); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--hair); }
.nav .brand { display: flex; align-items: center; }
.nav .brand img { height: 38px; width: auto; display: block; }
.nav-left { display: flex; align-items: center; }
.eco-badge { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border: 1px solid #A8D5B5; border-radius: 20px; background: #F0FAF3; font-family: var(--dm); font-size: 10px; font-weight: 500; color: #2D7D46; letter-spacing: 0.04em; white-space: nowrap; transition: background .2s, border-color .2s; margin-left: 12px; }
.eco-badge:hover { background: #E0F5E8; border-color: #2D7D46; }
.eco-badge svg { flex-shrink: 0; }
@media (max-width: 768px) {
  .eco-badge span { display: none; }
  .eco-badge { margin-left: 8px; padding: 6px; border-radius: 50%; }
}
.logo-fallback { font-family: var(--syne); font-weight: 800; font-size: 22px; letter-spacing: -0.04em; }
.logo-fallback em { color: var(--orange); font-style: normal; }
.nav-right { display: flex; align-items: center; gap: clamp(16px,2vw,32px); }
.nav-links { display: flex; gap: clamp(14px,1.8vw,30px); }
.nav-links a { font-family: var(--dm); font-weight: 400; font-size: 13px; color: var(--warm); transition: color .2s; }
.nav-links a:hover { color: var(--ink); }
.nav-cta { font-family: var(--syne); font-weight: 700; font-size: 12px; letter-spacing: 0.04em; background: var(--orange); color: #fff; padding: 9px 18px; border-radius: 3px; transition: transform .25s var(--ease), filter .25s; }
.nav-cta:hover { transform: translateY(-2px); filter: brightness(1.06); }
.nav-burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: none; padding: 6px; }
.nav-burger span { width: 24px; height: 2px; background: var(--ink); transition: transform .35s var(--ease), opacity .3s; }
body.menu-open .nav-burger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.menu-open .nav-burger span:nth-child(2) { opacity: 0; }
body.menu-open .nav-burger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 880px) {
  .nav-links, .nav-cta { display: none; }
  .nav-burger { display: flex; }
  .mobile-menu { position: fixed; inset: 60px 0 0; z-index: 780; background: var(--paper); display: flex; flex-direction: column; justify-content: center; gap: 4px; padding: var(--pad); transform: translateY(-110%); transition: transform .55s var(--ease); }
  body.menu-open .mobile-menu { transform: none; }
  .mobile-menu a { font-family: var(--syne); font-weight: 800; font-size: clamp(30px,9vw,48px); letter-spacing: -0.03em; color: var(--ink); display: flex; align-items: baseline; gap: 14px; }
  .mobile-menu a span { font-family: var(--dm); font-weight: 500; font-size: 12px; color: var(--blue); letter-spacing: .1em; }
}
@media (min-width: 881px) { .mobile-menu { display: none; } }

/* ============ HERO (3 zones) ============ */
.hero { min-height: 100svh; display: flex; flex-direction: column; padding-top: 60px; border-bottom: 1px solid var(--hair); }

/* zone 1 + 3 : info strips */
.hero-strip { display: flex; align-items: center; justify-content: space-between; padding: 0 var(--pad); flex-shrink: 0; }
.hero-strip.top { height: 48px; border-bottom: 1px solid var(--hair); }
.hero-strip.bottom { height: 56px; border-top: 1px solid var(--hair); }
.strip-avail { display: flex; align-items: center; gap: 11px; }
.strip-avail .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--orange); animation: pulse 2s ease-in-out infinite; flex-shrink: 0; }
@keyframes pulse { 0%,100%{ opacity: 1; } 50%{ opacity: .25; } }
.strip-avail .label { font-size: 10px; letter-spacing: 0.26em; }
.strip-meta { font-family: var(--dm); font-weight: 400; font-size: 11px; color: var(--faint); letter-spacing: 0.02em; }
.hero-stats { display: flex; gap: clamp(20px,3vw,40px); }
.stat { display: flex; align-items: baseline; gap: 8px; }
.stat b { font-family: var(--syne); font-weight: 800; font-size: 20px; letter-spacing: -0.02em; }
.stat.o b { color: var(--orange); }
.stat.b b { color: var(--blue); }
.stat span { font-family: var(--dm); font-weight: 300; font-size: 11px; color: var(--faint); }
.strip-scroll { display: flex; align-items: center; gap: 8px; font-family: var(--dm); font-weight: 300; font-size: 11px; letter-spacing: 0.18em; color: var(--faint2); text-transform: uppercase; }
.strip-scroll .arr { animation: bounce 1.5s ease-in-out infinite; }
@keyframes bounce { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(4px); } }

/* zone 2 : main */
.hero-main { flex: 1; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,80px); align-items: center; padding: clamp(24px,4vh,48px) var(--pad); max-width: 1440px; width: 100%; margin: 0 auto; }
.hero-cat { display: block; font-family: var(--dm); font-weight: 500; font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; color: var(--faint); margin-bottom: 26px; }

.rotator { position: relative; height: clamp(120px,15vw,168px); margin-bottom: 22px; }
.phrase { position: absolute; top: 0; left: 0; width: 100%; opacity: 0; transform: translateY(14px); transition: opacity .65s var(--ease), transform .65s var(--ease); pointer-events: none; font-family: var(--syne); font-weight: 800; font-size: clamp(26px,3.4vw,46px); letter-spacing: -0.03em; line-height: 1.08; color: var(--ink); }
.phrase.active { opacity: 1; transform: none; pointer-events: auto; }
.phrase em { color: var(--orange); font-style: normal; }

.hero-sub { font-size: 15px; color: var(--warm); line-height: 1.8; max-width: 400px; }
.hero-sub b { color: var(--ink); font-weight: 400; }
.hero-ctas { display: flex; align-items: center; gap: 12px; margin-top: 34px; flex-wrap: wrap; }
.btn-primary { display: inline-flex; align-items: center; gap: 10px; font-family: var(--syne); font-weight: 700; font-size: 13px; background: var(--orange); color: #fff; padding: 13px 24px; border-radius: 3px; transition: transform .25s var(--ease), background .25s, box-shadow .25s; }
.btn-primary:hover { background: var(--orange-d); transform: translateY(-2px); box-shadow: 0 10px 28px rgba(255,107,0,0.26); }
.btn-ghost { font-family: var(--dm); font-weight: 400; font-size: 13px; color: var(--warm); border: 1px solid #D5D0CA; padding: 12px 20px; border-radius: 3px; transition: color .2s, border-color .2s; }
.btn-ghost:hover { color: var(--blue); border-color: var(--blue); }

.hero-right { position: relative; height: clamp(360px,44vw,540px); }
.word-cloud { position: absolute; inset: 0; user-select: none; }
.central-word { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-family: var(--syne); font-weight: 800; font-size: clamp(34px,3.8vw,52px); letter-spacing: -0.03em; color: transparent; -webkit-text-stroke: 1.5px var(--orange); text-stroke: 1.5px var(--orange); white-space: nowrap; pointer-events: none; z-index: 10; animation: centralPulse 4s ease-in-out infinite; transition: opacity .45s ease, transform .45s ease; }
@keyframes centralPulse { 0%,100%{ transform: translate(-50%,-50%) scale(1); } 50%{ transform: translate(-50%,-50%) scale(1.04); } }
.float-word { position: absolute; font-family: var(--dm); font-weight: 500; color: #BFBBB6; cursor: default; transition: color .3s ease; will-change: transform; white-space: nowrap; }
.float-word:hover { color: var(--orange); }
.float-word.blue:hover { color: var(--blue); }
body.no-cloud .float-word { display: none; }

/* mobile keyword strip (replaces cloud) */
.kw-strip { display: none; }
@media (max-width: 880px) {
  .hero-right { display: none; }
  .kw-strip { display: block; overflow-x: auto; white-space: nowrap; padding: 14px var(--pad); border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); margin-top: 20px; -webkit-overflow-scrolling: touch; }
  .kw-strip span { font-family: var(--dm); font-weight: 500; font-size: 11px; letter-spacing: 0.16em; color: var(--faint2); }
}

@media (max-width: 880px) {
  .hero-main { grid-template-columns: 1fr; gap: 24px; }
  .hero-right { height: 300px; max-width: 320px; margin: 0 auto; }
  .hero-stats { gap: 18px; }
  .stat span { display: none; }
  .strip-meta { display: none; }
}
@media (max-width: 560px) {
  .hero-strip.bottom { height: 50px; }
  .strip-scroll { display: none; }
}

/* ============ MARQUEE ============ */
.marquee { height: 56px; display: flex; align-items: center; background: var(--noir); border-top: 1px solid var(--dline); border-bottom: 1px solid var(--dline); overflow: hidden; }
.marquee .track { display: flex; width: max-content; white-space: nowrap; animation: scrollx 24s linear infinite; }
.marquee.rev .track { animation-direction: reverse; animation-duration: 30s; }
.marquee .track span { font-family: var(--syne); font-weight: 700; font-size: 13px; letter-spacing: 0.28em; text-transform: uppercase; color: #6E6A63; padding: 0 22px; }
.marquee .track span b { color: var(--orange); font-weight: 700; }
@keyframes scrollx { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============ SERVICES ============ */
.svc-list { margin-top: clamp(40px,6vh,64px); }
.svc { border-top: 1px solid var(--hair); }
.svc:last-child { border-bottom: 1px solid var(--hair); }
.svc-head { width: 100%; background: none; border: 0; color: inherit; cursor: none; text-align: left; display: grid; grid-template-columns: 48px 1fr auto; gap: 24px; align-items: center; padding: 24px 0; font-family: inherit; transition: padding-left .25s var(--ease); }
.svc-head:hover { padding-left: 16px; }
.svc-head .idx { font-family: var(--syne); font-weight: 800; font-size: 11px; letter-spacing: 0.1em; color: var(--hair); }
.svc-head .nm { font-family: var(--syne); font-weight: 700; font-size: clamp(19px,2.6vw,24px); letter-spacing: -0.01em; transition: color .25s; }
.svc.open .svc-head .nm { color: var(--blue); }
.svc-head .rt { display: flex; align-items: center; gap: 18px; }
.svc-head .tags { font-family: var(--dm); font-weight: 400; font-size: 12.5px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--warm); }
.svc-head .arw { font-size: 20px; color: var(--hair); transition: transform .25s var(--ease), color .25s; }
.svc-head:hover .arw { color: var(--orange); transform: rotate(-45deg); }
.svc.open .svc-head .arw { color: var(--orange); transform: rotate(45deg); }
.svc-body { max-height: 0; overflow: hidden; transition: max-height .4s var(--ease); }
.svc-body p { padding: 0 0 24px 72px; max-width: 60ch; font-size: 14px; color: var(--warm); line-height: 1.75; }
@media (max-width: 720px) { .svc-head { grid-template-columns: 32px 1fr auto; gap: 12px; } .svc-head .tags { display: none; } .svc-body p { padding-left: 44px; } }

/* ============ PACKS (dark) ============ */
.packs { background: var(--noir); color: var(--paper); }
.packs .sec-label { color: var(--orange); }
.packs .sec-label .grey { color: #4A4A4A; }
.packs .sec-title { color: var(--paper); }
.packs-sub { font-size: 13px; color: #4A4A4A; margin-top: 16px; }
.ptable { display: grid; grid-template-columns: minmax(150px,1.4fr) repeat(3,1fr); gap: 1px; background: #2E2E2E; border: 1px solid #2E2E2E; margin-top: clamp(36px,6vh,56px); }
.ptable > div { background: var(--noir); padding: 17px 18px; font-size: 13px; display: flex; align-items: center; }
.ph-corner { align-items: flex-end; }
.pcorner { font-family: var(--dm); font-weight: 500; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--faint); line-height: 1.3; }
.ptable .col-feat { background: var(--panel); }
.pcell-label { color: var(--paper); font-weight: 400; }
.tick { color: var(--orange); font-weight: 700; font-size: 16px; }
.col-feat .tick { color: var(--blue); }
.dash { color: #5A5650; font-size: 16px; }
.ph-cell { flex-direction: column; align-items: flex-start; gap: 6px; padding: 24px 18px; }
.ph-cell .pname { font-family: var(--syne); font-weight: 800; font-size: 18px; letter-spacing: -0.01em; }
.ph-cell .ptag { font-size: 11px; color: #4A4A4A; }
.ph-cell .pprice { font-family: var(--syne); font-weight: 800; font-size: 24px; color: var(--paper); margin-top: 4px; }
.ph-cell .pprice small { font-family: var(--dm); font-weight: 300; font-size: 12px; color: #6A6A6A; }
.col-feat.ph-cell { border-top: 2px solid var(--orange); }
.col-feat .pname { color: var(--orange); }
.pfeat-flag { display: block; font-family: var(--dm); font-weight: 500; font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--orange); margin-bottom: 8px; }
.opt { color: var(--faint); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; }
.pbtn { font-family: var(--syne); font-weight: 700; font-size: 12px; letter-spacing: 0.04em; padding: 12px 18px; border: 1px solid #2A2A2A; color: var(--paper); width: 100%; text-align: center; transition: all .25s; cursor: none; }
.pbtn:hover { border-color: var(--orange); }
.pbtn.inv { background: var(--paper); color: var(--orange); border-color: var(--paper); }
.pbtn.inv:hover { background: var(--orange); color: #fff; border-color: var(--orange); }
.pcta { padding: 20px 18px !important; }
@media (max-width: 860px) {
  .ptable { display: block; border: 0; }
  .ptable-mobile-row { display: grid; }
  .ptable > div { display: none; }
  .ptable.scroll { display: grid; grid-template-columns: minmax(140px,1fr) repeat(3,minmax(120px,1fr)); overflow-x: auto; }
  .ptable.scroll > div { display: flex; }
}

/* ============ RÉFÉRENCES ============ */
.logo-ticker { background: var(--noir); overflow: hidden; padding: 22px 0; display: flex; align-items: center; }
.logo-ticker .track { display: flex; width: max-content; white-space: nowrap; animation: scrollx 22s linear infinite; }
.logo-ticker .track span { font-family: var(--syne); font-weight: 800; font-size: 18px; letter-spacing: 0.04em; color: #B6AFA4; padding: 0 32px; }
.ref-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1px; background: var(--hair); }
.ref-card { background: var(--paper); padding: clamp(26px,3vw,36px) clamp(22px,2.4vw,28px); min-height: 230px; display: flex; flex-direction: column; transition: background .3s; }
.ref-card:hover { background: #FBF9F5; }
.ref-card .rname { font-family: var(--syne); font-weight: 800; font-size: 18px; letter-spacing: -0.01em; }
.ref-card .rsec { font-family: var(--dm); font-weight: 500; font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--warm); margin-top: 6px; }
.ref-card .rdesc { font-size: 13px; color: var(--warm); line-height: 1.65; margin-top: 14px; flex: 1; max-width: 32ch; }
.ref-card .rstat { border-top: 1px solid var(--hair); padding-top: 14px; margin-top: 18px; }
.ref-card .rstat b { font-family: var(--syne); font-weight: 800; font-size: 36px; letter-spacing: -0.03em; color: var(--orange); display: block; line-height: 1; }
.ref-card .rstat.blue b { color: var(--blue); }
.ref-card .rstat span { font-size: 11px; color: var(--warm); }
.ref-card.cta { justify-content: center; }
.ref-card.cta a { font-family: var(--syne); font-weight: 800; font-size: 22px; letter-spacing: -0.02em; color: var(--blue); display: inline-flex; align-items: center; gap: 10px; transition: gap .25s; }
.ref-card.cta a:hover { gap: 18px; }
@media (max-width: 820px) { .ref-grid { grid-template-columns: 1fr; } }

/* ============ PORTFOLIO ============ */
.pf-grid { display: grid; grid-template-columns: repeat(12,1fr); gap: 1px; background: var(--hair); margin-top: clamp(36px,6vh,56px); }
.pf { background: var(--noir); color: var(--paper); padding: clamp(28px,3vw,40px); position: relative; min-height: 240px; display: flex; flex-direction: column; justify-content: space-between; transition: background .25s; cursor: none; }
.pf:hover { background: #111; }
.pf.placeholder { background: #0D0D0D; }
.pf .tag { font-family: var(--dm); font-weight: 500; font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--orange); }
.pf .tag.blue { color: var(--blue); }
.pf .pf-name { font-family: var(--syne); font-weight: 800; font-size: clamp(24px,3vw,28px); letter-spacing: -0.02em; margin-top: 10px; }
.pf .pf-desc { font-size: 13px; color: #6A6A6A; margin-top: 10px; max-width: 40ch; }
.pf .pf-stat { position: absolute; top: clamp(28px,3vw,40px); right: clamp(28px,3vw,40px); font-family: var(--syne); font-weight: 800; font-size: clamp(26px,3.5vw,40px); color: #2A2A2A; letter-spacing: -0.03em; }
.pf .arw { font-size: 20px; color: #2A2A2A; transition: color .25s, transform .25s var(--ease); margin-top: 22px; align-self: flex-start; }
.pf:hover .arw { color: var(--orange); transform: translateX(8px); }
.pf-w8 { grid-column: span 8; } .pf-w4 { grid-column: span 4; } .pf-w6 { grid-column: span 6; }
@media (max-width: 820px) { .pf-w8, .pf-w4, .pf-w6 { grid-column: 1 / -1; } }

/* ============ PROCESS ============ */
.proc-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--hair); margin-top: clamp(36px,6vh,56px); }
.proc { background: var(--paper); padding: clamp(26px,3vw,36px); min-height: 210px; display: flex; flex-direction: column; }
.proc .pidx { font-family: var(--dm); font-weight: 500; font-size: 12px; letter-spacing: 0.2em; color: var(--blue); }
.proc .ptitle { font-family: var(--syne); font-weight: 700; font-size: 19px; letter-spacing: -0.01em; margin-top: auto; }
.proc .ptitle em { color: var(--blue); font-style: normal; }
.proc .pdesc { font-size: 13px; color: var(--warm); line-height: 1.65; margin-top: 12px; }
@media (max-width: 820px) { .proc-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .proc-grid { grid-template-columns: 1fr; } }

/* ============ CTA FINAL (orange) ============ */
.cta { background: var(--orange); color: #fff; padding: clamp(80px,14vh,120px) var(--pad); }
.cta-inner { display: grid; grid-template-columns: 1.25fr 1fr; gap: clamp(30px,5vw,72px); align-items: end; }
.cta h2 { font-family: var(--syne); font-weight: 800; font-size: clamp(48px,7vw,96px); line-height: 0.95; letter-spacing: -0.04em; }
.cta .right p { font-size: 15px; color: rgba(255,255,255,0.8); line-height: 1.7; margin-bottom: 28px; max-width: 40ch; }
.cta-btn { display: inline-flex; align-items: center; gap: 12px; font-family: var(--syne); font-weight: 700; font-size: 14px; background: #fff; color: var(--orange); padding: 16px 28px; border-radius: 3px; transition: transform .25s var(--ease); cursor: none; }
.cta-btn:hover { transform: translateY(-3px); }
.cta .contacts { margin-top: 28px; display: flex; flex-direction: column; gap: 8px; }
.cta .contacts a { font-size: 14px; color: #fff; border-bottom: 1px solid rgba(255,255,255,0.35); padding-bottom: 7px; width: fit-content; transition: border-color .25s; }
.cta .contacts a:hover { border-color: #fff; }
@media (max-width: 760px) { .cta-inner { grid-template-columns: 1fr; align-items: start; } }

/* ============ FOOTER ============ */
.footer { background: var(--noir); color: var(--paper); padding: clamp(50px,7vh,80px) var(--pad) 26px; }
.foot-grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.foot-brand img { height: 28px; width: auto; filter: brightness(0) invert(1); opacity: .92; }
.foot-brand p { color: #4A4A4A; font-size: 13px; line-height: 1.6; margin-top: 14px; max-width: 30ch; }
.fcol h4 { font-family: var(--dm); font-weight: 500; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: #4A4A4A; margin-bottom: 16px; }
.fcol a, .fcol p.fline { display: block; font-size: 13px; color: #6A6A6A; margin-bottom: 9px; transition: color .25s; }
.fcol a:hover { color: var(--paper); }
.foot-bar { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-top: clamp(48px,8vh,80px); padding-top: 22px; border-top: 1px solid var(--dline); font-size: 11px; letter-spacing: 0.05em; color: #3A3A3A; }
@media (max-width: 720px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

@media (prefers-reduced-motion: reduce) {
  .sphere .w, .sphere .center span, .marquee .track, .logo-ticker .track, .hero-eyebrow .dot { animation: none !important; }
  .reveal, .hero h1 .line-inner { transition: none !important; transform: none !important; opacity: 1 !important; }
}

/* word idle-float keyframes (magnetic JS adds displacement on top) */
@keyframes idle1 { 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(6px,-10px); } }
@keyframes idle2 { 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(-8px,7px); } }
@keyframes idle3 { 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(9px,8px); } }
@keyframes idle4 { 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(-6px,-9px); } }
@keyframes idle5 { 0%,100%{ transform: translate(0,0); } 50%{ transform: translate(7px,-6px); } }
