/* =========================================================================
   Rubikal — Main stylesheet
   Authored with CSS logical properties so layout mirrors under dir="rtl".
   ========================================================================= */

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

/* Skip link — visually hidden until focused (keyboard accessibility) */
.skip-link { position: absolute; inset-block-start: -100%; inset-inline-start: var(--s-4); background: var(--brand-blue); color: #fff; padding: var(--s-2) var(--s-4); border-radius: 0 0 var(--radius) var(--radius); font-size: var(--t-sm); font-weight: 600; z-index: 9999; text-decoration: none; transition: inset-block-start .15s; }
.skip-link:focus { inset-block-start: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

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

img, svg, video { display: block; max-inline-size: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: none; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px; }

/* ---- Typography --------------------------------------------------------- */
h1, h2, h3, h4 { font-family: var(--font-display); font-weight: 600; line-height: var(--lh-snug); color: var(--fg-strong); letter-spacing: -0.02em; }
h1 { font-size: var(--t-h1); }
h2 { font-size: var(--t-h2); }
h3 { font-size: var(--t-h3); letter-spacing: -0.01em; }
p { color: var(--fg); }

.display { font-family: var(--font-display); font-weight: 600; font-size: var(--t-display); line-height: var(--lh-tight); letter-spacing: -0.03em; color: var(--fg-strong); }
.lead { font-size: var(--t-lead); line-height: 1.5; color: var(--muted); }
.muted { color: var(--muted); }
.balance { text-wrap: balance; }
.gradient-text {
  background: var(--grad-text);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
[data-theme="light"] .gradient-text { background: var(--grad-brand); -webkit-background-clip: text; background-clip: text; }

.eyebrow {
  display: inline-flex; align-items: center; gap: var(--s-2);
  font-family: var(--font-body); font-size: var(--t-eyebrow); font-weight: 600;
  letter-spacing: var(--tracking-eyebrow); text-transform: uppercase;
  color: var(--accent);
}
.eyebrow::before { content: ""; inline-size: 22px; block-size: 2px; background: currentColor; border-radius: 2px; opacity: .7; }

/* ---- Layout ------------------------------------------------------------- */
.section { padding-block: var(--section-y); background: var(--bg); color: var(--fg); position: relative; }
.container { inline-size: 100%; max-inline-size: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.narrow { max-inline-size: var(--maxw-narrow); }
.section-head { max-inline-size: 760px; margin-block-end: var(--s-8); }
.section-head .lead { margin-block-start: var(--s-4); }

.grid { display: grid; gap: var(--s-5); }
@media (min-width: 720px) { .cols-2 { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px) { .cols-3 { grid-template-columns: repeat(3, 1fr); } .cols-4 { grid-template-columns: repeat(4, 1fr); } }

/* ---- Buttons ------------------------------------------------------------ */
.btn {
  --pad-i: 26px;
  display: inline-flex; align-items: center; justify-content: center; gap: var(--s-2);
  padding: 15px var(--pad-i); border-radius: var(--r-pill);
  font-family: var(--font-body); font-weight: 600; font-size: var(--t-sm);
  letter-spacing: .01em; position: relative; isolation: isolate;
  transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur) var(--ease-out), background var(--dur) var(--ease-out), color var(--dur) var(--ease-out);
  will-change: transform;
}
.btn:active { transform: translateY(1px); }
.btn .arrow { transition: transform var(--dur) var(--ease-out); }
.btn:hover .arrow { transform: translateX(4px); }
[dir="rtl"] .btn .arrow { transform: scaleX(-1); }
[dir="rtl"] .btn:hover .arrow { transform: scaleX(-1) translateX(4px); }

.btn-primary { background: var(--grad-brand); color: #fff; box-shadow: var(--glow); background-size: 160% 160%; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 0 80px -8px rgba(30,96,253,.6); background-position: 100% 50%; }
.btn-ghost { background: var(--surface); color: var(--fg-strong); border: 1px solid var(--border-strong); }
.btn-ghost:hover { background: var(--surface-2); transform: translateY(-2px); }
.btn-lg { padding: 18px 34px; font-size: var(--t-body); }

.link-arrow { display: inline-flex; align-items: center; gap: var(--s-2); font-weight: 600; color: var(--accent); }
.link-arrow .arrow { transition: transform var(--dur) var(--ease-out); }
.link-arrow:hover .arrow { transform: translateX(4px); }
[dir="rtl"] .link-arrow .arrow { transform: scaleX(-1); }
[dir="rtl"] .link-arrow:hover .arrow { transform: scaleX(-1) translateX(4px); }

/* ---- Header / Nav ------------------------------------------------------- */
.site-header {
  position: fixed; inset-block-start: 0; inset-inline: 0; z-index: 100;
  block-size: var(--header-h); display: flex; align-items: center;
  transition: background var(--dur) var(--ease-out), border-color var(--dur), backdrop-filter var(--dur);
  border-block-end: 1px solid transparent;
}
.site-header.scrolled {
  background: color-mix(in srgb, var(--ink-900) 72%, transparent);
  backdrop-filter: blur(16px) saturate(160%);
  border-block-end-color: rgba(255,255,255,.08);
}
.nav { inline-size: 100%; max-inline-size: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); display: flex; align-items: center; gap: var(--s-6); }
.brand { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 700; font-size: 1.32rem; letter-spacing: -0.03em; color: #fff; }
.brand .mark { inline-size: 26px; block-size: 26px; border-radius: 7px; background: var(--grad-brand); box-shadow: var(--glow); display: inline-block; position: relative; }
.brand .mark::after { content: ""; position: absolute; inset: 5px; border-radius: 3px; border: 1.5px solid rgba(255,255,255,.85); }
.brand .dot { color: var(--brand-blue); }
.brand-logo { block-size: 32px; inline-size: auto; display: block; }
.site-footer .brand-logo { block-size: 34px; }

.nav-links { display: none; align-items: center; gap: var(--s-6); margin-inline-start: var(--s-5); }
.nav-links a { color: rgba(255,255,255,.82); font-size: var(--t-sm); font-weight: 500; position: relative; padding-block: 6px; }
.nav-links a::after { content: ""; position: absolute; inset-block-end: 0; inset-inline-start: 0; inline-size: 0; block-size: 2px; background: var(--grad-brand); border-radius: 2px; transition: inline-size var(--dur) var(--ease-out); }
.nav-links a:hover::after, .nav-links a[aria-current="page"]::after { inline-size: 100%; }
.nav-links a:hover { color: #fff; }

.nav-end { margin-inline-start: auto; display: flex; align-items: center; gap: var(--s-3); }
.lang-switch { display: inline-flex; align-items: center; gap: 6px; font-size: var(--t-sm); font-weight: 600; color: rgba(255,255,255,.82); padding: 9px 14px; border-radius: var(--r-pill); border: 1px solid rgba(255,255,255,.16); transition: background var(--dur-fast), color var(--dur-fast); }
.lang-switch:hover { background: rgba(255,255,255,.08); color: #fff; }
.nav-end .btn { display: none; }

.nav-toggle { display: inline-flex; flex-direction: column; gap: 5px; padding: 8px; }
.nav-toggle span { inline-size: 24px; block-size: 2px; background: #fff; border-radius: 2px; transition: transform var(--dur) var(--ease-out), opacity var(--dur-fast); }
.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (min-width: 1000px) {
  .nav-links { display: flex; }
  .nav-toggle { display: none; }
  .nav-end .btn { display: inline-flex; }
}

/* Mobile menu drawer */
.mobile-menu {
  position: fixed; inset: 0; z-index: 95; background: var(--ink-900);
  display: flex; flex-direction: column; justify-content: center; gap: var(--s-4);
  padding: var(--gutter); padding-block-start: calc(var(--header-h) + 20px);
  transform: translateY(-100%); transition: transform var(--dur) var(--ease-in-out);
  visibility: hidden;
}
.nav-open .mobile-menu { transform: translateY(0); visibility: visible; }
.mobile-menu a { font-family: var(--font-display); font-size: clamp(1.6rem, 7vw, 2.4rem); color: #fff; font-weight: 500; }
.mobile-menu a:hover { color: var(--brand-blue); }
.mobile-menu .btn { margin-block-start: var(--s-4); align-self: flex-start; }

/* ---- Hero --------------------------------------------------------------- */
.hero { position: relative; min-block-size: 100svh; display: flex; align-items: center; padding-block-start: var(--header-h); overflow: hidden; }
.hero-canvas { position: absolute; inset: 0; z-index: 0; }
.hero-glow { position: absolute; inset-block-start: -10%; inset-inline-start: 50%; transform: translateX(-50%); inline-size: 900px; block-size: 900px; max-inline-size: 120%; background: radial-gradient(circle at 50% 40%, rgba(30,96,253,.42), rgba(255,0,84,.12) 42%, transparent 68%); filter: blur(20px); z-index: 0; pointer-events: none; }
.hero-grid-overlay { position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(circle at 50% 35%, #000 0%, transparent 75%); }
.hero .container { position: relative; z-index: 2; }
.hero-inner { max-inline-size: 940px; }
.hero h1 { margin-block: var(--s-5) var(--s-5); }
.hero .lead { max-inline-size: 620px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: var(--s-3); margin-block-start: var(--s-7); }
.hero-badge { display: inline-flex; align-items: center; gap: var(--s-2); padding: 8px 16px 8px 12px; border-radius: var(--r-pill); background: rgba(255,255,255,.05); border: 1px solid var(--border); font-size: var(--t-sm); color: var(--fg); }
.hero-badge .pulse { inline-size: 8px; block-size: 8px; border-radius: 50%; background: var(--brand-yellow); box-shadow: 0 0 0 0 rgba(248,206,58,.6); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(248,206,58,.5);} 70% { box-shadow: 0 0 0 12px rgba(248,206,58,0);} 100% { box-shadow: 0 0 0 0 rgba(248,206,58,0);} }

/* ---- 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); }
.marquee-track { display: flex; gap: var(--s-8); inline-size: max-content; animation: marquee 38s linear infinite; will-change: transform; backface-visibility: hidden; }
[dir="rtl"] .marquee-track { animation-direction: reverse; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track span { font-family: var(--font-display); font-weight: 500; font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--muted); white-space: nowrap; opacity: .85; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---- Cards -------------------------------------------------------------- */
.card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r-lg); padding: clamp(24px, 3vw, 40px); position: relative; overflow: hidden; transition: transform var(--dur) var(--ease-out), border-color var(--dur), box-shadow var(--dur); }
.card:hover { transform: translateY(-4px); border-color: var(--border-strong); box-shadow: var(--card-shadow); }
.card h3 { margin-block-end: var(--s-3); }
.card .card-num { font-family: var(--font-display); font-size: var(--t-sm); color: var(--accent); font-weight: 600; }
.card-icon { inline-size: 52px; block-size: 52px; border-radius: var(--r-sm); display: grid; place-items: center; background: var(--grad-brand-soft); border: 1px solid var(--border); margin-block-end: var(--s-4); color: var(--accent); }
.card-icon svg { inline-size: 26px; block-size: 26px; }

/* Service feature card (large) */
.service-card { padding: clamp(28px, 4vw, 56px); display: flex; flex-direction: column; gap: var(--s-4); min-block-size: 100%; }
.service-card .tag-row { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-block-start: auto; padding-block-start: var(--s-5); }
.tag { font-size: var(--t-xs); padding: 6px 12px; border-radius: var(--r-pill); background: var(--surface); border: 1px solid var(--border); color: var(--fg); font-weight: 500; }
.service-card::before { content: ""; position: absolute; inset-block-start: -40%; inset-inline-end: -20%; inline-size: 60%; block-size: 80%; background: var(--grad-brand-soft); filter: blur(40px); opacity: 0; transition: opacity var(--dur); }
.service-card:hover::before { opacity: 1; }

/* ---- Process steps ------------------------------------------------------ */
.process { display: grid; gap: var(--s-5); counter-reset: step; }
@media (min-width: 900px) { .process { grid-template-columns: repeat(4, 1fr); } }
.step { position: relative; padding-block-start: var(--s-6); border-block-start: 1px solid var(--border); }
.step::before { counter-increment: step; content: counter(step, decimal-leading-zero); position: absolute; inset-block-start: var(--s-4); font-family: var(--font-display); font-size: var(--t-sm); color: var(--accent); font-weight: 600; }
.step .tick { position: absolute; inset-block-start: -7px; inset-inline-start: 0; inline-size: 13px; block-size: 13px; border-radius: 50%; background: var(--grad-brand); box-shadow: var(--glow); }
.step h3 { font-size: var(--t-h3); margin-block: var(--s-3) var(--s-2); }
.step p { font-size: var(--t-sm); color: var(--muted); }

/* ---- Stats -------------------------------------------------------------- */
.stats { display: grid; gap: var(--s-6); grid-template-columns: repeat(2, 1fr); }
@media (min-width: 760px) { .stats { grid-template-columns: repeat(4, 1fr); } }
.stat .num { font-family: var(--font-display); font-weight: 600; font-size: clamp(2.6rem, 6vw, 4.2rem); line-height: 1; letter-spacing: -0.03em; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
[data-theme="light"] .stat .num { background: var(--grad-brand); -webkit-background-clip: text; background-clip: text; }
.stat .label { margin-block-start: var(--s-3); color: var(--muted); font-size: var(--t-sm); }

/* ---- Testimonials ------------------------------------------------------- */
.quote { font-family: var(--font-display); font-size: clamp(1.3rem, 2.6vw, 2rem); line-height: 1.32; font-weight: 500; letter-spacing: -0.02em; color: var(--fg-strong); }
.quote-meta { display: flex; align-items: center; gap: var(--s-3); margin-block-start: var(--s-6); }
.quote-meta .avatar { inline-size: 48px; block-size: 48px; border-radius: 50%; background: var(--grad-brand); display: grid; place-items: center; color: #fff; font-family: var(--font-display); font-weight: 600; }
.quote-meta .who strong { display: block; color: var(--fg-strong); }
.quote-meta .who span { font-size: var(--t-sm); color: var(--muted); }

/* ---- CTA band ----------------------------------------------------------- */
.cta-band { position: relative; border-radius: var(--r-xl); padding: clamp(40px, 6vw, 88px); overflow: hidden; background: var(--ink-850); border: 1px solid var(--border-strong); text-align: center; }
.cta-band::before { content: ""; position: absolute; inset: 0; background: var(--grad-brand); opacity: .14; }
.cta-band::after { content: ""; position: absolute; inset-block-start: -50%; inset-inline-start: 50%; transform: translateX(-50%); inline-size: 700px; block-size: 700px; max-inline-size: 130%; background: radial-gradient(circle, rgba(30,96,253,.5), rgba(255,0,84,.18) 55%, transparent 70%); filter: blur(30px); }
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; max-inline-size: 720px; margin-inline: auto; }
.cta-band .lead { color: rgba(255,255,255,.78); margin-block: var(--s-4) var(--s-7); max-inline-size: 560px; margin-inline: auto; }

/* ---- Footer ------------------------------------------------------------- */
.site-footer { background: var(--ink-900); color: #C9C9DE; padding-block: var(--s-9) var(--s-6); border-block-start: 1px solid rgba(255,255,255,.08); }
.footer-grid { display: grid; gap: var(--s-7); grid-template-columns: 1fr; }
@media (min-width: 760px) { .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; } }
.footer-grid h4 { font-family: var(--font-body); font-size: var(--t-xs); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: #7A7A95; margin-block-end: var(--s-4); font-weight: 600; }
.footer-grid a { color: #B6B6CE; font-size: var(--t-sm); display: inline-block; padding-block: 5px; transition: color var(--dur-fast); }
.footer-grid a:hover { color: #fff; }
.footer-about p { color: #9292AC; font-size: var(--t-sm); max-inline-size: 320px; margin-block-start: var(--s-4); }
.footer-bottom { display: flex; flex-wrap: wrap; gap: var(--s-4); justify-content: space-between; align-items: center; margin-block-start: var(--s-8); padding-block-start: var(--s-5); border-block-start: 1px solid rgba(255,255,255,.08); font-size: var(--t-sm); color: #7A7A95; }
.footer-offices { display: flex; flex-wrap: wrap; gap: var(--s-6); }
.footer-offices .office strong { color: #E6E6F2; display: block; font-family: var(--font-display); }
.footer-offices .office span { font-size: var(--t-sm); color: #9292AC; }
.socials { display: flex; gap: var(--s-3); }
.socials a { inline-size: 38px; block-size: 38px; border-radius: 50%; border: 1px solid rgba(255,255,255,.14); display: grid; place-items: center; color: #B6B6CE; }
.socials a:hover { background: rgba(255,255,255,.08); color: #fff; }
.cookie-settings-link { background: none; border: none; padding: 0; color: #7A7A95; font-size: var(--t-sm); font-family: inherit; cursor: pointer; text-decoration: underline; text-underline-offset: 3px; }
.cookie-settings-link:hover { color: #B6B6CE; }

/* ---- Calendly modal -------------------------------------------------- */
.cal-modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: var(--s-4); }
.cal-modal[hidden] { display: none; }
.cal-modal-backdrop { position: absolute; inset: 0; background: rgba(7,7,12,.62); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); }
.cal-modal-panel { position: relative; inline-size: min(480px, 100%); block-size: min(760px, 90vh); background: #fff; border-radius: 18px; overflow: hidden; box-shadow: 0 32px 90px rgba(0,0,0,.55); animation: cal-in .25s var(--ease-out, ease); }
.cal-modal-iframe { inline-size: 100%; block-size: 100%; border: 0; display: block; }
.cal-modal-close { position: absolute; inset-block-start: 12px; inset-inline-end: 12px; z-index: 2; inline-size: 38px; block-size: 38px; border: none; border-radius: 50%; background: rgba(7,7,12,.6); color: #fff; font-size: 22px; line-height: 1; cursor: pointer; display: grid; place-items: center; transition: background .2s; }
.cal-modal-close:hover { background: rgba(7,7,12,.85); }
@keyframes cal-in { from { opacity: 0; transform: translateY(14px) scale(.98); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .cal-modal-panel { animation: none; } }

/* ---- Forms -------------------------------------------------------------- */
.form { display: grid; gap: var(--s-4); }
.field { display: grid; gap: var(--s-2); }
.field label { font-size: var(--t-sm); font-weight: 600; color: var(--fg-strong); }
.field input, .field textarea, .field select {
  inline-size: 100%; padding: 14px 16px; border-radius: var(--r-sm);
  background: var(--bg-elev); border: 1px solid var(--border-strong); color: var(--fg);
  font: inherit; font-size: var(--t-sm); transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.field input:focus, .field textarea:focus, .field select:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 18%, transparent); }
.field textarea { resize: vertical; min-block-size: 130px; }

/* ---- Page hero (interior pages) ----------------------------------------- */
.page-hero { padding-block: calc(var(--header-h) + var(--s-9)) var(--section-y); position: relative; overflow: hidden; }
.page-hero .hero-glow { inline-size: 700px; block-size: 700px; opacity: .7; }
.page-hero h1 { max-inline-size: 18ch; }
.page-hero .lead { margin-block-start: var(--s-5); max-inline-size: 60ch; }

/* ---- Split / media rows ------------------------------------------------- */
.split { display: grid; gap: var(--s-7); align-items: center; }
@media (min-width: 900px) { .split { grid-template-columns: 1fr 1fr; gap: var(--s-9); } .split.reverse > :first-child { order: 2; } }
.media-frame { border-radius: var(--r-lg); border: 1px solid var(--border); background: var(--grad-brand-soft); aspect-ratio: 4/3; position: relative; overflow: hidden; }
.media-frame .blob { position: absolute; inset: 0; background: var(--grad-brand); opacity: .25; filter: blur(30px); }

/* ---- Pricing / tiers ---------------------------------------------------- */
.tier { display: flex; flex-direction: column; gap: var(--s-3); }
.tier.featured { border-color: var(--accent); box-shadow: var(--glow); }
.tier .tier-name { font-family: var(--font-display); font-size: var(--t-h3); color: var(--fg-strong); }
ul.checks { display: grid; gap: var(--s-3); margin-block-start: var(--s-4); }
ul.checks li { display: flex; gap: var(--s-3); align-items: flex-start; font-size: var(--t-sm); color: var(--muted); }
ul.checks li::before { content: ""; flex: none; inline-size: 20px; block-size: 20px; border-radius: 50%; margin-block-start: 2px; background: var(--grad-brand-soft); background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235C8DFF' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E"); background-size: 13px; background-position: center; background-repeat: no-repeat; }

/* ---- Reveal animation utilities ----------------------------------------- */
[data-reveal] { opacity: 0; transform: translateY(30px); filter: blur(7px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out), filter var(--dur-slow) var(--ease-out); transition-delay: var(--reveal-delay, 0s); }
[data-reveal="left"] { transform: translateX(-34px); }
[data-reveal="right"] { transform: translateX(34px); }
[data-reveal="scale"] { transform: scale(.94); }
[data-reveal].in { opacity: 1; transform: none; filter: none; }

/* ---- Kinetic headline (word-by-word reveal) ----------------------------- */
.kinetic .word { display: inline-block; opacity: 0; transform: translateY(.5em); filter: blur(10px); transition: opacity .7s var(--ease-out), transform .8s var(--ease-out), filter .7s var(--ease-out); transition-delay: var(--wd, 0s); will-change: transform, opacity, filter; }
.kinetic.in .word { opacity: 1; transform: none; filter: none; }

/* ---- Scroll progress bar ------------------------------------------------ */
.scroll-progress { position: fixed; inset-block-start: 0; inset-inline-start: 0; block-size: 3px; inline-size: 100%; transform: scaleX(var(--p, 0)); transform-origin: inline-start; background: var(--grad-brand); z-index: 200; box-shadow: 0 0 14px rgba(30, 96, 253, .65); }

/* ---- Card spotlight + 3D tilt ------------------------------------------- */
.card { transform-style: preserve-3d; will-change: transform; }
.card > * { position: relative; z-index: 1; }
.card::after { content: ""; position: absolute; inset: 0; border-radius: inherit; z-index: 0; opacity: 0; pointer-events: none; transition: opacity .45s var(--ease-out); background: radial-gradient(260px circle at var(--mx, 50%) var(--my, 50%), color-mix(in srgb, var(--accent) 26%, transparent), transparent 60%); }
.card:hover::after { opacity: 1; }

/* ---- Ambient drift for hero glow & blobs -------------------------------- */
@keyframes drift { 0%, 100% { transform: translateX(-50%) translateY(0) scale(1); } 50% { transform: translateX(-47%) translateY(24px) scale(1.07); } }
.hero-glow { animation: drift 16s var(--ease-in-out) infinite; }
@keyframes blob { 0%, 100% { transform: translate(0, 0) scale(1); } 33% { transform: translate(6%, -6%) scale(1.12); } 66% { transform: translate(-5%, 4%) scale(.95); } }
.media-frame .blob { animation: blob 12s var(--ease-in-out) infinite; }

[data-parallax] { will-change: transform; }

@media (prefers-reduced-motion: reduce) {
  [data-reveal], .kinetic .word { opacity: 1 !important; transform: none !important; filter: none !important; transition: none; }
  .marquee-track, .hero-badge .pulse, .hero-glow, .media-frame .blob { animation: none !important; }
  .btn-primary { background-size: 100% 100%; }
  .scroll-progress { display: none !important; }
  [data-parallax] { transform: none !important; }
}

/* ---- Helpers ------------------------------------------------------------ */
.center { text-align: center; }
.mt-lg { margin-block-start: var(--s-8); }
.divider { block-size: 1px; background: var(--border); border: 0; }
.sr-only { position: absolute; inline-size: 1px; block-size: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.no-scroll { overflow: hidden; }

/* =========================================================================
   Hero split + interactive "delivery modes" panel
   (inspired by product-panel heroes; Rubikal's own content & palette)
   ========================================================================= */
.hero-grid-2 { display: grid; gap: var(--s-7); align-items: center; }
@media (min-width: 980px) { .hero-grid-2 { grid-template-columns: 1.04fr 0.96fr; gap: var(--s-9); } }

.display { font-weight: 700; }

.modes-panel {
  position: relative; border-radius: var(--r-lg);
  background: color-mix(in srgb, var(--ink-800) 82%, transparent);
  border: 1px solid var(--border-strong);
  backdrop-filter: blur(14px) saturate(150%);
  box-shadow: var(--shadow-lg);
  padding: var(--s-4);
  overflow: hidden;
}
.modes-panel::before { content: ""; position: absolute; inset-block-start: -40%; inset-inline-end: -30%; inline-size: 70%; block-size: 80%; background: var(--grad-brand-soft); filter: blur(50px); pointer-events: none; }
.modes-head { position: relative; display: flex; align-items: center; justify-content: space-between; padding: var(--s-2) var(--s-2) var(--s-4); border-block-end: 1px solid var(--border); }
.modes-head .eyebrow { margin: 0; }
.modes-dots { display: flex; gap: 6px; }
.modes-dots i { inline-size: 8px; block-size: 8px; border-radius: 50%; background: var(--border-strong); }
.modes-list { position: relative; display: grid; gap: 4px; padding-block: var(--s-3); }
.mode-row { display: flex; align-items: center; gap: var(--s-3); padding: 14px var(--s-3); border-radius: var(--r-sm); border: 1px solid transparent; cursor: pointer; transition: background var(--dur) var(--ease-out), border-color var(--dur), transform var(--dur) var(--ease-out); }
.mode-row:hover, .mode-row.active { background: var(--surface); border-color: var(--border-strong); transform: translateX(2px); }
[dir="rtl"] .mode-row:hover, [dir="rtl"] .mode-row.active { transform: translateX(-2px); }
.mode-row.active { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent) 45%, transparent), var(--glow); }
.mode-chip { flex: none; inline-size: 40px; block-size: 40px; border-radius: 11px; display: grid; place-items: center; font-family: var(--font-display); font-weight: 700; font-size: var(--t-sm); color: #fff; }
.modes-list .mode-row:nth-child(1) .mode-chip { background: linear-gradient(135deg, #1E60FD, #4D82FF); }
.modes-list .mode-row:nth-child(2) .mode-chip { background: linear-gradient(135deg, #3D63FF, #6A47F0); }
.modes-list .mode-row:nth-child(3) .mode-chip { background: linear-gradient(135deg, #6A47F0, #C13DAE); }
.modes-list .mode-row:nth-child(4) .mode-chip { background: linear-gradient(135deg, #FF0054, #FF5C8A); }
.modes-list .mode-row:nth-child(5) .mode-chip { background: linear-gradient(135deg, #F8CE3A, #FFD95E); color: var(--ink-900); }
.mode-name { font-weight: 600; color: var(--fg-strong); font-size: var(--t-body); }
.mode-tag { margin-inline-start: auto; font-size: var(--t-xs); color: var(--muted); font-weight: 500; transition: color var(--dur); white-space: nowrap; }
.mode-row.active .mode-tag { color: var(--accent); }
.modes-foot { position: relative; text-align: center; padding-block-start: var(--s-4); border-block-start: 1px solid var(--border); font-size: var(--t-xs); color: var(--muted); }

/* =========================================================================
   Corner-bracket framed stats (logical borders → mirror in RTL)
   ========================================================================= */
.stats .stat { position: relative; padding: var(--s-4); }
.stats .stat::before, .stats .stat::after { content: ""; position: absolute; inline-size: 14px; block-size: 14px; border: 2px solid var(--accent); opacity: .55; }
.stats .stat::before { inset-block-start: 0; inset-inline-start: 0; border-inline-end: 0; border-block-end: 0; }
.stats .stat::after { inset-block-end: 0; inset-inline-end: 0; border-inline-start: 0; border-block-start: 0; }
.stats .stat .num { margin-block-start: 0; }

/* =========================================================================
   Illustration artwork in media frames (bespoke brand SVGs)
   ========================================================================= */
.media-frame { background-size: cover; background-position: center; background-repeat: no-repeat; }
.work-3 .media-frame .blob, .work-6 .media-frame .blob, .media-frame[class*="media--"] .blob { display: none; }

.work-3 .card:nth-child(1) .media-frame { background-image: url(../img/illus-board.svg); }
.work-3 .card:nth-child(2) .media-frame { background-image: url(../img/illus-mobility.svg); }
.work-3 .card:nth-child(3) .media-frame { background-image: url(../img/illus-learn.svg); }

.work-6 .card:nth-child(1) .media-frame { background-image: url(../img/illus-board.svg); }
.work-6 .card:nth-child(2) .media-frame { background-image: url(../img/illus-mobility.svg); }
.work-6 .card:nth-child(3) .media-frame { background-image: url(../img/illus-learn.svg); }
.work-6 .card:nth-child(4) .media-frame { background-image: url(../img/illus-media.svg); }
.work-6 .card:nth-child(5) .media-frame { background-image: url(../img/illus-logistics.svg); }
.work-6 .card:nth-child(6) .media-frame { background-image: url(../img/illus-commerce.svg); }

.media--code { background-image: url(../img/illus-code.svg); }
.media--team { background-image: url(../img/illus-team.svg); }
.media--ai   { background-image: url(../img/illus-ai.svg); }
.media--ksa  { background-image: url(../img/illus-ksa.svg); }
.media--board     { background-image: url(../img/illus-board.svg); }
.media--mobility  { background-image: url(../img/illus-mobility.svg); }
.media--learn     { background-image: url(../img/illus-learn.svg); }
.media--media     { background-image: url(../img/illus-media.svg); }
.media--logistics { background-image: url(../img/illus-logistics.svg); }
.media--commerce  { background-image: url(../img/illus-commerce.svg); }

/* Case study cards (whole card is a link) */
.case-card { text-decoration: none; display: flex; flex-direction: column; }
.case-card .media-frame { aspect-ratio: 16/10; margin-block-end: var(--s-4); }
.case-card h3 { margin-block: var(--s-1) var(--s-2); }
.case-card .link-arrow { margin-block-start: auto; padding-block-start: var(--s-4); }
.case-card .media-frame { background: var(--surface); }
.case-card .media-frame .case-thumb { inline-size: 100%; block-size: 100%; object-fit: cover; display: block; transition: transform var(--dur-slow) var(--ease-out); }
.case-card:hover .media-frame .case-thumb { transform: scale(1.05); }

/* Case study detail */
.case-meta { display: flex; flex-wrap: wrap; gap: var(--s-7); margin-block-start: var(--s-6); }
.case-meta div span { display: block; font-size: var(--t-xs); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--muted); margin-block-end: 4px; }
.case-meta div strong { font-family: var(--font-display); font-weight: 600; color: var(--fg-strong); font-size: var(--t-h3); }
.case-cover { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); background: var(--surface); }
.case-cover img, .case-shot img { display: block; inline-size: 100%; height: auto; }
.case-shot { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); background: var(--surface); }
.case-prose { max-inline-size: 760px; }
.case-prose p { color: var(--muted); font-size: var(--t-lead); line-height: 1.6; margin-block-end: var(--s-4); }
.case-prose h2 { margin-block: var(--s-8) var(--s-4); }
.case-prose h2:first-child { margin-block-start: 0; }
.case-prose figure { margin-block: var(--s-6); border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--border); background: var(--surface); }
.case-prose figure img { display: block; inline-size: 100%; height: auto; }
.chip-row { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-block-start: var(--s-5); }
.case-stat { text-align: center; }
.case-stat .num { font-family: var(--font-display); font-weight: 600; font-size: clamp(3rem, 8vw, 5.5rem); line-height: 1; letter-spacing: -.03em; background: var(--grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.case-stat .label { color: var(--muted); margin-block-start: var(--s-3); }

/* =========================================================================
   Client logos — monochrome white on dark, full on hover
   ========================================================================= */
.marquee-track { align-items: center; }
.client-logo { block-size: 30px; inline-size: auto; max-inline-size: 150px; object-fit: contain; filter: brightness(0) invert(1); opacity: .6; transition: opacity var(--dur) var(--ease-out), transform var(--dur) var(--ease-out); }
.marquee-track .client-logo { flex: none; }
.client-logo:hover { opacity: 1; }

/* Client logos grid — work page */
.client-logos-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--s-8) var(--s-6); align-items: center; justify-items: center; }
@media (max-width: 900px) { .client-logos-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 560px) { .client-logos-grid { grid-template-columns: repeat(3, 1fr); gap: var(--s-6) var(--s-4); } }
.client-logo-cell { display: flex; align-items: center; justify-content: center; }
.client-logo-cell img { height: 32px; width: auto; max-width: 130px; object-fit: contain; filter: brightness(0) invert(1); opacity: .55; transition: opacity .25s ease, transform .25s ease; }
.client-logo-cell img:hover { opacity: 1; transform: scale(1.06); }

.logo-wall { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-7) var(--s-5); align-items: center; justify-items: center; }
@media (min-width: 620px) { .logo-wall { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 920px) { .logo-wall { grid-template-columns: repeat(5, 1fr); } }
.logo-wall .client-logo { block-size: 40px; max-inline-size: 150px; }
.logo-wall .client-logo:hover { transform: translateY(-3px); }
/* Dense/illustrative logos: smaller + softer so solid fills don't dominate */
.logo-wall .client-logo.soft { block-size: 28px; opacity: .42; }
.logo-wall .client-logo.soft:hover { opacity: .9; }

/* =========================================================================
   Awards & recognition
   ========================================================================= */
.awards { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }
@media (min-width: 760px) { .awards { grid-template-columns: repeat(4, 1fr); } }
.award { background: #fff; border-radius: var(--r-md); padding: var(--s-5) var(--s-4); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--s-3); text-align: center; min-block-size: 168px; transition: transform var(--dur) var(--ease-out), box-shadow var(--dur); }
.award:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.award img { block-size: 92px; inline-size: auto; max-inline-size: 100%; object-fit: contain; }
.award span { font-size: var(--t-xs); font-weight: 600; color: #5A5A6E; letter-spacing: .02em; }

/* =========================================================================
   Office gallery (inside the studio)
   ========================================================================= */
.office-gallery { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-4); }
@media (min-width: 760px) { .office-gallery { grid-template-columns: repeat(3, 1fr); grid-auto-rows: 1fr; } }
.office-gallery figure { margin: 0; border-radius: var(--r-md); overflow: hidden; aspect-ratio: 4 / 3; border: 1px solid var(--border); }
.office-gallery img { inline-size: 100%; block-size: 100%; object-fit: cover; display: block; transition: transform var(--dur-slow) var(--ease-out); }
.office-gallery figure:hover img { transform: scale(1.07); }
@media (min-width: 760px) { .office-gallery figure:first-child { grid-column: span 2; grid-row: span 2; aspect-ratio: auto; } }

/* =========================================================================
   Testimonials grid
   ========================================================================= */
.testimonials { display: grid; gap: var(--s-5); }
@media (min-width: 720px) { .testimonials { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1040px) { .testimonials { grid-template-columns: repeat(3, 1fr); } }
.tcard { display: flex; flex-direction: column; gap: var(--s-4); }
.tcard .qmark { font-family: var(--font-display); font-size: 2.8rem; line-height: .5; color: var(--accent); opacity: .55; }
.tcard .t-quote { margin: 0; color: var(--fg); font-size: var(--t-body); line-height: 1.62; }
.tcard .quote-meta { margin-block-start: auto; }
[dir="rtl"] .tcard .qmark { transform: scaleX(-1); align-self: flex-start; }
img.avatar { object-fit: cover; }
.quote-meta .li-link { margin-inline-start: auto; flex: none; inline-size: 34px; block-size: 34px; border-radius: 50%; display: grid; place-items: center; color: var(--muted); border: 1px solid var(--border-strong); transition: color var(--dur-fast), background var(--dur-fast), border-color var(--dur-fast); }
.quote-meta .li-link svg { inline-size: 16px; block-size: 16px; }
.quote-meta .li-link:hover { color: #fff; background: #0A66C2; border-color: #0A66C2; }
.quote-meta .stars { margin-inline-start: auto; flex: none; color: var(--brand-yellow); font-size: .82rem; letter-spacing: 1px; }
.clutch-badge { display: inline-flex; align-items: center; gap: var(--s-2); margin-block-start: var(--s-5); padding: 11px 20px; border-radius: var(--r-pill); background: var(--surface); border: 1px solid var(--border-strong); color: var(--fg); font-size: var(--t-sm); font-weight: 500; transition: border-color var(--dur-fast), transform var(--dur-fast); }
.clutch-badge:hover { border-color: var(--accent); transform: translateY(-2px); }
.clutch-badge .stars { color: var(--brand-yellow); letter-spacing: 1px; }
.clutch-badge strong { color: var(--fg-strong); }
.clutch-badge .arrow { transition: transform var(--dur) var(--ease-out); }
.clutch-badge:hover .arrow { transform: translateX(3px); }
[dir="rtl"] .clutch-badge:hover .arrow { transform: scaleX(-1) translateX(3px); }
[dir="rtl"] .clutch-badge .arrow { transform: scaleX(-1); }
a.stars { text-decoration: none; transition: filter var(--dur-fast); }
a.stars:hover { filter: brightness(1.18); }
.tcard .t-source { margin-block-start: auto; display: inline-flex; align-items: center; gap: 8px; align-self: flex-start; text-decoration: none; font-size: var(--t-xs); font-weight: 600; color: var(--muted); transition: color var(--dur-fast); }
.tcard .t-source .stars { color: var(--brand-yellow); font-size: .85rem; letter-spacing: 1px; }
.tcard .t-source:hover { color: var(--fg-strong); }
.tcard .t-source + .quote-meta { margin-block-start: var(--s-4); }

/* Testimonials carousel */
.t-carousel { overflow: hidden; }
.t-track { display: flex; transition: transform var(--dur-slow) var(--ease-out); }
.t-page { flex: 0 0 100%; max-inline-size: 100%; }
.t-page .testimonials { margin: 0; }
.t-controls { display: flex; align-items: center; justify-content: center; gap: var(--s-4); margin-block-start: var(--s-7); }
.t-arrow { inline-size: 46px; block-size: 46px; border-radius: 50%; border: 1px solid var(--border-strong); display: grid; place-items: center; color: var(--fg-strong); transition: background var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast); }
.t-arrow:hover { background: var(--surface-2); border-color: var(--accent); transform: translateY(-2px); }
.t-arrow .arrow { font-size: 1.2rem; line-height: 1; }
[dir="rtl"] .t-controls .arrow { transform: scaleX(-1); }
.t-dots { display: flex; gap: var(--s-2); }
.t-dot { inline-size: 10px; block-size: 10px; border-radius: 50%; background: var(--border-strong); transition: background var(--dur-fast), transform var(--dur-fast); }
.t-dot.is-active { background: var(--accent); transform: scale(1.35); }

/* ===================== Cookie consent banner ===================== */
.consent-banner {
  position: fixed; inset-inline: var(--s-4); inset-block-end: var(--s-4); z-index: 200;
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--s-4);
  margin-inline: auto; max-inline-size: 1100px;
  padding: var(--s-4) var(--s-5);
  background: #14141F;
  background-image: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0));
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  color: #F5F5FA;
  border: 1px solid var(--border-strong); border-radius: var(--r-lg);
  box-shadow: 0 24px 60px -12px rgba(0, 0, 0, 0.65), 0 0 0 1px rgba(0,0,0,0.4);
  transform: translateY(140%); opacity: 0;
  transition: transform .35s cubic-bezier(.2,.7,.2,1), opacity .35s ease;
}
.consent-banner.is-in { transform: translateY(0); opacity: 1; }
.consent-text { margin: 0; flex: 1 1 320px; font-size: var(--t-sm, .95rem); line-height: 1.5; color: rgba(245,245,250,0.85); }
.consent-actions { display: flex; gap: var(--s-3); flex: 0 0 auto; }
.consent-btn { padding-block: .55rem; padding-inline: 1.1rem; }
@media (max-width: 560px) {
  .consent-banner { flex-direction: column; align-items: stretch; }
  .consent-actions { justify-content: stretch; }
  .consent-actions .consent-btn { flex: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .consent-banner { transition: opacity .2s ease; transform: none; }
}
