

.ltr-mix { unicode-bidi: plaintext; }

.prob-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.prob-card {
  background: var(--surface-2); border: 1px solid var(--hairline); border-radius: 16px; padding: 26px 22px;
  transition: border-color .25s var(--ease-out), background .25s;
}
.prob-card:hover { background: var(--card); border-color: var(--hairline-2); box-shadow: 0 16px 36px rgba(11,18,32,.07); }
.prob-ico { width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center; background: var(--card); border: 1px solid var(--hairline); color: var(--brand-primary); font-size: 24px; margin-bottom: 18px; }
.prob-card h4 { margin: 0 0 8px; font-size: 16.5px; font-weight: 500; color: var(--ink); }
.prob-card p { margin: 0; font-size: 13.5px; line-height: 1.85; color: var(--ink-3); }
@media (max-width: 920px){ .prob-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .prob-grid { grid-template-columns: 1fr; } }

.services { background: var(--surface-2); }
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.svc-card { padding: 28px 24px; display: flex; flex-direction: column; align-items: flex-start; }
.svc-ico { width: 54px; height: 54px; border-radius: 14px; display: grid; place-items: center; background: var(--brand-primary-50); color: var(--brand-primary-dark); font-size: 27px; margin-bottom: 18px; }
.svc-card h4 { margin: 0 0 10px; font-size: 18px; font-weight: 500; color: var(--ink); }
.svc-card p { margin: 0 0 16px; font-size: 14px; line-height: 1.9; color: var(--ink-2); }
.svc-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 18px; }
.svc-card .link-cta { margin-top: auto; }
@media (max-width: 920px){ .svc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .svc-grid { grid-template-columns: 1fr; } }

.pc-icn { width: 46px; height: 46px; border-radius: 12px; display: grid; place-items: center; background: rgba(255,255,255,.22); color: #fff; font-size: 24px; backdrop-filter: blur(6px); }
.pc-cat { font-size: 12px; color: rgba(255,255,255,.9); font-weight: 500; letter-spacing: .02em; }
.pc-desc { font-size: 14px; line-height: 1.9; color: var(--ink-2); margin: 0 0 16px; }
.pc-meta { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.pc-row { display: flex; flex-direction: column; gap: 3px; }
.pc-k { font-size: 11px; color: var(--ink-3); font-weight: 500; }
.pc-v { font-size: 13px; color: var(--ink); line-height: 1.7; }
.pc-feats { display: flex; flex-wrap: wrap; gap: 6px 14px; margin-bottom: 20px; padding-top: 14px; border-top: 1px dashed var(--hairline-2); }
.pc-feat { display: inline-flex; align-items: center; gap: 5px; font-size: 12.5px; color: var(--ink-2); }
.pc-feat i { font-size: 14px; color: var(--brand-primary); }
.pc-cta { display: flex; align-items: center; gap: 16px; margin-top: auto; flex-wrap: wrap; }

.prod-show { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.prod-card { display: flex; flex-direction: column; overflow: hidden; }
.prod-card.feat { grid-column: span 1; }
.pc-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; }
.pc-content { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.pc-content h3 { margin: 0 0 10px; font-size: 19px; font-weight: 500; color: var(--ink); }
@media (max-width: 920px){ .prod-show { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ .prod-show { grid-template-columns: 1fr; } }

.prod-tabs { display: grid; grid-template-columns: 320px 1fr; gap: 20px; }
.pt-list { display: flex; flex-direction: column; gap: 8px; }
.pt-tab { display: flex; align-items: center; gap: 12px; padding: 14px; background: var(--surface); border: 1px solid var(--hairline); border-radius: 14px; cursor: pointer; text-align: right; transition: border-color .2s, background .2s, box-shadow .2s; }
.pt-tab:hover { border-color: var(--hairline-2); }
.pt-tab.on { border-color: color-mix(in srgb, var(--brand-primary) 45%, transparent); box-shadow: 0 8px 22px rgba(11,18,32,.08); background: var(--card); }
.pt-ico { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; color: #fff; font-size: 21px; flex: none; transition: background .2s; }
.pt-tab:not(.on) .pt-ico { color: var(--ink-3); }
.pt-name { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.pt-name b { font-size: 15px; font-weight: 500; color: var(--ink); }
.pt-name i { font-size: 11.5px; color: var(--ink-3); font-style: normal; }
.pt-arr { color: var(--ink-3); font-size: 18px; opacity: 0; transition: opacity .2s; }
.pt-tab.on .pt-arr { opacity: 1; color: var(--brand-primary); }
.pt-panel { overflow: hidden; display: flex; flex-direction: column; }
.pt-panel-head { display: flex; align-items: center; gap: 16px; padding: 26px; color: #fff; }
.pt-panel-head h3 { margin: 0 0 4px; font-size: 22px; font-weight: 500; }
.pt-panel-head span { font-size: 13px; color: rgba(255,255,255,.9); }
.pt-panel-body { padding: 26px; display: flex; flex-direction: column; flex: 1; }
@media (max-width: 820px){ .prod-tabs { grid-template-columns: 1fr; } .pt-list { flex-direction: row; overflow-x: auto; } .pt-tab { min-width: 220px; } .pt-arr { display: none; } }

.solutions { background: var(--surface-2); }
.sol-tabbar { display: inline-flex; gap: 6px; background: var(--card); border: 1px solid var(--hairline); border-radius: 100px; padding: 6px; margin-bottom: 28px; }
.sol-tab { display: inline-flex; align-items: center; gap: 8px; padding: 10px 18px; border-radius: 100px; border: none; background: transparent; font-size: 14px; font-weight: 500; color: var(--ink-2); cursor: pointer; transition: all .2s; white-space: nowrap; }
.sol-tab i { font-size: 18px; }
.sol-tab.on { background: var(--ink); color: #fff; }
.sol-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.sol-card { display: flex; gap: 14px; padding: 22px; align-items: flex-start; }
.sol-card.feat { grid-column: span 1; border-color: color-mix(in srgb, var(--brand-primary) 35%, transparent); box-shadow: 0 10px 30px color-mix(in srgb, var(--brand-primary) 12%, transparent); }
.sol-ico { width: 46px; height: 46px; border-radius: 12px; flex: none; display: grid; place-items: center; background: var(--brand-primary-50); color: var(--brand-primary-dark); font-size: 23px; }
.sol-card.feat .sol-ico { background: var(--brand-gradient); color: #fff; }
.sol-body h4 { margin: 0 0 6px; font-size: 16px; font-weight: 500; color: var(--ink); }
.sol-body p { margin: 0 0 12px; font-size: 13px; line-height: 1.8; color: var(--ink-3); }
.sol-feat-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 12px; }
@media (max-width: 920px){ .sol-grid { grid-template-columns: repeat(2,1fr); } .sol-tabbar { display: flex; overflow-x: auto; } }
@media (max-width: 560px){ .sol-grid { grid-template-columns: 1fr; } }

.sol-mega { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.sol-col { background: var(--card); border: 1px solid var(--hairline); border-radius: 18px; padding: 22px; }
.sol-col-head { display: flex; align-items: center; gap: 10px; font-size: 15px; font-weight: 500; color: var(--ink); padding-bottom: 14px; margin-bottom: 8px; border-bottom: 1px solid var(--hairline); }
.sol-col-head i { font-size: 21px; color: var(--brand-primary); }
.sol-col-items { display: flex; flex-direction: column; }
.sol-line { display: flex; align-items: center; gap: 11px; padding: 12px 8px; border-radius: 10px; transition: background .18s; }
.sol-line:hover { background: var(--surface-2); }
.sol-line-ico { width: 34px; height: 34px; border-radius: 9px; display: grid; place-items: center; background: var(--surface-3); color: var(--ink-2); font-size: 18px; flex: none; }
.sol-line.feat .sol-line-ico { background: var(--brand-primary-50); color: var(--brand-primary-dark); }
.sol-line-t { flex: 1; font-size: 14px; color: var(--ink); font-weight: 500; }
.sol-line-arr { font-size: 16px; color: var(--ink-3); opacity: 0; transition: opacity .18s; }
.sol-line:hover .sol-line-arr { opacity: 1; }
@media (max-width: 820px){ .sol-mega { grid-template-columns: 1fr; } }

.case-tag { display: inline-flex; align-items: center; font-size: 12px; font-weight: 500; color: var(--brand-primary-dark); background: var(--brand-primary-50); border-radius: 100px; padding: 5px 12px; width: max-content; }
.case-hero { display: grid; grid-template-columns: 1.3fr 1fr; gap: 0; overflow: hidden; margin-bottom: 18px; }
.ch-left { padding: 36px; display: flex; flex-direction: column; align-items: flex-start; gap: 16px; }
.ch-left h3 { margin: 4px 0 6px; font-size: 26px; font-weight: 500; line-height: 1.35; color: var(--ink); }
.ch-block { display: flex; flex-direction: column; gap: 4px; }
.ch-k { display: inline-flex; align-items: center; gap: 7px; font-size: 12.5px; font-weight: 500; color: var(--ink-3); }
.ch-k i { font-size: 16px; color: var(--brand-primary); }
.ch-block p { margin: 0; font-size: 14.5px; line-height: 1.85; color: var(--ink); }
.ch-tech { display: flex; flex-wrap: wrap; gap: 6px; }
.ch-right { background: var(--navy); color: #fff; padding: 36px; display: flex; flex-direction: column; justify-content: center; }
.ch-results-h { display: inline-flex; align-items: center; gap: 8px; font-size: 12px; letter-spacing: .04em; color: rgba(255,255,255,.6); margin-bottom: 22px; }
.ch-results-h i { color: var(--green-400); font-size: 18px; }
.ch-results { display: grid; grid-template-columns: 1fr 1fr; gap: 26px 18px; }
.ch-res .n { font-size: 34px; font-weight: 700; letter-spacing: -0.01em; background: var(--brand-gradient-h); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.ch-res .l { font-size: 12.5px; color: rgba(255,255,255,.7); margin-top: 4px; }
@media (max-width: 880px){ .case-hero { grid-template-columns: 1fr; } }

.case-small-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.case-small { padding: 24px; display: flex; flex-direction: column; align-items: flex-start; gap: 12px; }
.cs-top { display: flex; align-items: center; gap: 12px; width: 100%; }
.cs-ico { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; color: #fff; font-size: 21px; flex: none; }
.case-small h4 { margin: 0; font-size: 16.5px; font-weight: 500; line-height: 1.5; color: var(--ink); }
.cs-desc { margin: 0; font-size: 13px; line-height: 1.75; color: var(--ink-3); flex: 1; }
.case-small .link-cta { margin-top: auto; padding-top: 4px; }
@media (max-width: 1100px){ .case-small-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ .case-small-grid { grid-template-columns: 1fr; } }
.cases-allcta { display: flex; justify-content: center; margin-top: 30px; }

.arch { position: relative; overflow: hidden; }
.arch-dark { background: var(--navy); }
.arch-dark::before { content:""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px); background-size: 46px 46px; mask-image: radial-gradient(ellipse 70% 60% at 50% 0%, #000, transparent 75%); -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 0%, #000, transparent 75%); pointer-events: none; }
.arch-dark .sec-title { color: #fff; }
.arch-dark .sec-sub { color: rgba(255,255,255,.7); }
.arch-light { background: var(--surface-2); }
.arch-rule { height: 2px; background: var(--brand-gradient-h); opacity: .85; }
.arch-light .arch-rule { opacity: .5; }
.arch-grid { position: relative; display: grid; grid-template-columns: 1fr 1.05fr; gap: 32px; align-items: start; }

.arch-diagram { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: 18px; padding: 24px; position: relative; }
.arch-light .arch-diagram { background: var(--card); border-color: var(--hairline); }
.arch-diagram-label { position: absolute; top: 16px; left: 24px; font-size: 9.5px; letter-spacing: .2em; color: rgba(255,255,255,.4); }
.arch-light .arch-diagram-label { color: var(--ink-3); }
.arch-layer { display: flex; align-items: center; gap: 14px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); border-radius: 12px; padding: 14px 16px; }
.arch-light .arch-layer { background: var(--surface-2); border-color: var(--hairline); }
.arch-layer:first-of-type { margin-top: 14px; }
.arch-layer-ico { width: 40px; height: 40px; border-radius: 10px; flex: none; display: grid; place-items: center; background: var(--brand-gradient); color: #fff; font-size: 20px; }
.arch-layer-txt { display: flex; flex-direction: column; gap: 2px; }
.arch-layer-txt b { font-size: 14px; font-weight: 600; color: #fff; letter-spacing: .01em; }
.arch-light .arch-layer-txt b { color: var(--ink); }
.arch-layer-txt span { font-size: 12px; color: rgba(255,255,255,.6); }
.arch-light .arch-layer-txt span { color: var(--ink-3); }
.arch-conn { display: grid; place-items: center; height: 22px; color: rgba(255,255,255,.3); }
.arch-light .arch-conn { color: var(--ink-3); }
.arch-conn i { font-size: 18px; }

.arch-side { display: flex; flex-direction: column; gap: 18px; }
.arch-caps { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.arch-cap { display: flex; align-items: center; gap: 10px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.1); border-radius: 11px; padding: 13px 14px; font-size: 13px; color: rgba(255,255,255,.88); }
.arch-light .arch-cap { background: var(--card); border-color: var(--hairline); color: var(--ink); }
.arch-cap i { font-size: 19px; color: var(--green-400); flex: none; }
.arch-light .arch-cap i { color: var(--green-600); }
.arch-term { background: #050B14; border: 1px solid rgba(255,255,255,.12); border-radius: 14px; overflow: hidden; }
.arch-light .arch-term { border-color: var(--hairline-2); }
.term-bar { display: flex; align-items: center; gap: 6px; padding: 11px 14px; border-bottom: 1px solid rgba(255,255,255,.08); }
.term-bar span { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,.2); }
.term-bar em { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: rgba(255,255,255,.4); font-style: normal; }
.arch-term pre { margin: 0; padding: 16px 18px; font-family: var(--font-mono); font-size: 12.5px; line-height: 1.9; color: #8BC34A; white-space: pre-wrap; }
@media (max-width: 880px){ .arch-grid { grid-template-columns: 1fr; } }
@media (max-width: 520px){ .arch-caps { grid-template-columns: 1fr; } }

.proc-track { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0; position: relative; }
.proc-track::before { content:""; position: absolute; top: 36px; right: 7%; left: 7%; height: 2px; background: var(--brand-gradient-h); opacity: .3; }
.proc-step { display: flex; flex-direction: column; align-items: center; text-align: center; padding: 0 8px; position: relative; }
.proc-num-wrap { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.proc-ico { width: 56px; height: 56px; border-radius: 16px; display: grid; place-items: center; background: var(--card); border: 1px solid var(--hairline); color: var(--brand-primary); font-size: 26px; position: relative; z-index: 1; box-shadow: 0 6px 18px rgba(11,18,32,.06); }
.proc-n {
  font-size: 30px; font-weight: 900; letter-spacing: -.03em; line-height: 1; margin-top: 0;
  background: var(--brand-gradient); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.proc-step h4 { margin: 10px 0 6px; font-size: 13.5px; font-weight: 500; color: var(--ink); line-height: 1.5; }
.proc-o { display: inline-flex; align-items: flex-start; gap: 5px; font-size: 11px; color: var(--ink-3); line-height: 1.6; }
.proc-o i { font-size: 13px; color: var(--brand-primary); margin-top: 2px; }
@media (max-width: 920px){
  .proc-track { grid-template-columns: 1fr; gap: 0; }
  .proc-track::before { top: 0; bottom: 0; right: 27px; left: auto; width: 2px; height: auto; }
  .proc-step { flex-direction: row; align-items: flex-start; text-align: right; gap: 16px; padding: 0 0 26px; }
  .proc-num-wrap { flex-direction: row; align-items: center; gap: 10px; }
  .proc-step h4 { margin: 0 0 4px; }
  .proc-n { font-size: 22px; }
  .proc-txt { flex: 1; }
}

.team-orbit-wrap { position: relative; width: 320px; height: 320px; margin: 0 auto; }
.team-orbit-svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.team-orbit-ring { position: absolute; inset: 0; }
.orbit-node {
  position: absolute; top: 50%; left: 50%;
  transform: rotate(var(--angle)) translateX(var(--r)) rotate(calc(-1 * var(--angle))) translate(-50%, -50%);
}
.orbit-card {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  background: var(--card); border: 1px solid var(--hairline); border-radius: 12px;
  padding: 8px 10px; min-width: 68px; text-align: center;
  box-shadow: 0 4px 16px rgba(11,18,32,.08); transition: border-color .2s, box-shadow .2s;
}
.orbit-card:hover { border-color: var(--brand-primary); box-shadow: 0 6px 24px color-mix(in srgb,var(--brand-primary) 16%,transparent); }
.orbit-ico { font-size: 20px; color: var(--brand-primary); }
.orbit-label { font-size: 10px; font-weight: 500; color: var(--ink-2); white-space: nowrap; font-family: var(--font-mono); direction: ltr; }

.testi-head-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 28px; }
.testi-nav { display: flex; gap: 10px; flex: none; }
.testi-nav button {
  width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center;
  background: var(--card); border: 1px solid var(--hairline); color: var(--ink-2); font-size: 21px;
  cursor: pointer; transition: background .2s, color .2s, border-color .2s;
}
.testi-nav button:hover { background: var(--brand-primary); color: #fff; border-color: var(--brand-primary); }
.testi-viewport { overflow: hidden; }
.testi-track {
  display: flex; gap: 24px; overflow-x: auto; scroll-snap-type: x mandatory;
  scroll-behavior: smooth; padding: 6px 2px 12px; margin: -6px -2px 0; scrollbar-width: none;
}
.testi-track::-webkit-scrollbar { display: none; }
.testi-card {
  scroll-snap-align: start; flex: 0 0 calc((100% - 48px) / 3); min-width: 260px;
  padding: 28px; display: flex; flex-direction: column; gap: 16px;
  transition: border-color .25s, box-shadow .3s, transform .3s;
}
.testi-card.testi-active { border-color: var(--brand-primary); box-shadow: 0 12px 40px color-mix(in srgb,var(--brand-primary) 12%,transparent); transform: translateY(-3px); }
.testi-q { font-size: 36px; color: var(--brand-primary); opacity: .25; line-height: 1; }
.testi-card blockquote { margin: 0; font-size: 14.5px; line-height: 1.85; color: var(--ink-2); flex: 1; }
.testi-card figcaption { display: flex; align-items: center; gap: 12px; margin: 0; padding-top: 12px; border-top: 1px solid var(--hairline); }
.testi-av { width: 42px; height: 42px; border-radius: 50%; flex: none; }
.testi-who { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.testi-who b { font-size: 13.5px; color: var(--ink); font-weight: 600; }
.testi-who span { font-size: 12px; color: var(--ink-3); }
.testi-proj { font-size: 11px; font-family: var(--font-mono); color: var(--brand-primary-dark); background: var(--brand-primary-50); border-radius: 6px; padding: 3px 9px; white-space: nowrap; flex: none; direction: rtl; }
[data-theme="dark"] .testi-proj { color: color-mix(in srgb,var(--brand-primary) 72%,#fff); }
.testi-dots { display: flex; gap: 8px; justify-content: center; margin-top: 16px; }
.testi-dots button { width: 8px; height: 8px; border-radius: 50%; border: 0; padding: 0; cursor: pointer; background: var(--hairline-2); transition: width .25s, background .25s; }
.testi-dots button.on { width: 26px; border-radius: 5px; background: var(--brand-primary); }
@media (max-width: 900px) { .testi-card { flex-basis: calc((100% - 24px) / 2); } .testi-head-row { flex-direction: column; align-items: stretch; } .testi-nav { justify-content: flex-end; } }
@media (max-width: 580px) { .testi-card { flex-basis: 88%; } }

.about-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center; }
.about-left { display: flex; flex-direction: column; align-items: flex-start; gap: 18px; }
.about-left .sec-title { margin: 0; }
.about-left .sec-sub { margin: 0; }
.about-values { display: flex; flex-wrap: wrap; gap: 10px; }
.about-val { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; color: var(--ink); }
.about-val i { color: var(--green-600); font-size: 17px; }
.about-stats { display: flex; gap: 36px; margin-top: 6px; padding-top: 22px; border-top: 1px solid var(--hairline); width: 100%; }
.about-stats b { display: block; font-size: 30px; font-weight: 700; color: var(--ink); letter-spacing: -.01em; }
.about-stats span { font-size: 12.5px; color: var(--ink-3); }
.about-right { background: var(--surface-2); border: 1px solid var(--hairline); border-radius: 20px; padding: 28px; }
.about-roles-h { font-size: 14px; font-weight: 500; color: var(--ink); margin-bottom: 16px; }
.about-roles { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.about-role { display: flex; align-items: center; gap: 11px; background: var(--card); border: 1px solid var(--hairline); border-radius: 12px; padding: 13px 14px; font-size: 13.5px; color: var(--ink); }
.ar-ico { width: 36px; height: 36px; border-radius: 10px; flex: none; display: grid; place-items: center; background: var(--brand-primary-50); color: var(--brand-primary-dark); font-size: 19px; }
@media (max-width: 880px){ .about-grid { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 460px){ .about-stats { gap: 22px; } .about-roles { grid-template-columns: 1fr; } }

.testi { background: var(--surface-2); }
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.testi-card { padding: 28px 24px; display: flex; flex-direction: column; gap: 18px; }
.testi-q { font-size: 30px; color: var(--brand-primary-200); }
.testi-card blockquote { margin: 0; font-size: 15px; line-height: 2; color: var(--ink); flex: 1; }
.testi-card figcaption { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 12px; padding-top: 18px; border-top: 1px solid var(--hairline); }
.testi-av { width: 42px; height: 42px; border-radius: 50%; flex: none; }
.testi-who { display: flex; flex-direction: column; gap: 2px; }
.testi-who b { font-size: 14px; font-weight: 500; color: var(--ink); }
.testi-who span { font-size: 12px; color: var(--ink-3); }
.testi-metric { text-align: left; }
.testi-metric b { display: block; font-size: 15px; font-weight: 700; color: var(--brand-primary-dark); }
.testi-metric span { font-size: 10.5px; color: var(--ink-3); }
@media (max-width: 880px){ .testi-grid { grid-template-columns: 1fr; } }

.faq-wrap { display: grid; grid-template-columns: 360px 1fr; gap: 48px; align-items: start; }
.faq-head { position: sticky; top: 90px; display: flex; flex-direction: column; align-items: flex-start; gap: 16px; }
.faq-head .sec-title { margin: 0; font-size: 30px; }
.faq-head .sec-sub { margin: 0; }
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq-item { background: var(--card); border: 1px solid var(--hairline); border-radius: 14px; overflow: hidden; transition: border-color .2s, box-shadow .2s; }
.faq-item.open { border-color: var(--hairline-2); box-shadow: 0 14px 32px rgba(11,18,32,.07); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 22px; background: none; border: none; cursor: pointer; text-align: right; font-family: inherit; font-size: 15.5px; font-weight: 500; color: var(--ink); }
.faq-q i { font-size: 20px; color: var(--brand-primary); transition: transform .25s var(--ease-out); flex: none; }
.faq-item.open .faq-q i { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s var(--ease-out); }
.faq-item.open .faq-a { max-height: 240px; }
.faq-a p { margin: 0; padding: 0 22px 22px; font-size: 14px; line-height: 1.95; color: var(--ink-2); }
@media (max-width: 880px){ .faq-wrap { grid-template-columns: 1fr; gap: 28px; } .faq-head { position: static; } }

.contact { background: var(--navy); position: relative; overflow: hidden; }
.contact::before { content:""; position: absolute; inset: 0; background: radial-gradient(ellipse 700px 400px at 85% 10%, color-mix(in srgb, var(--brand-primary) 26%, transparent), transparent 60%); pointer-events: none; }
.contact-grid { position: relative; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.contact-intro { display: flex; flex-direction: column; align-items: flex-start; gap: 18px; }
.contact-intro .sec-title { color: #fff; margin: 0; }
.contact-intro .sec-sub { color: rgba(255,255,255,.72); margin: 0; }
.contact-assure { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; width: 100%; }
.contact-assure-item { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: rgba(255,255,255,.9); }
.contact-assure-item i { font-size: 20px; color: var(--green-400); flex: none; }
.contact-direct { display: flex; flex-wrap: wrap; gap: 20px; margin-top: 6px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,.12); width: 100%; }
.cd-item { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; color: #fff; }
.cd-item i { font-size: 18px; color: var(--brand-primary-200); }

.contact-card { background: var(--card); border-radius: 20px; padding: 30px; box-shadow: 0 40px 90px rgba(0,0,0,.3); }
.cf-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.cf-field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 14px; }
.cf-field label { font-size: 13px; font-weight: 500; color: var(--ink); }
.cf-field input, .cf-field textarea, .cf-select select {
  width: 100%; font-family: inherit; font-size: 14px; color: var(--ink);
  background: var(--surface-2); border: 1px solid var(--hairline); border-radius: 10px; padding: 12px 14px; outline: none;
  transition: border-color .2s, background .2s, box-shadow .2s;
}
.cf-field input:focus, .cf-field textarea:focus, .cf-select select:focus { border-color: var(--brand-primary); background: var(--card); box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand-primary) 16%, transparent); }
.cf-field textarea { resize: vertical; line-height: 1.8; }
.cf-select { position: relative; }
.cf-select select { appearance: none; cursor: pointer; }
.cf-select i { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--ink-3); font-size: 18px; pointer-events: none; }
.cf-submit { width: 100%; justify-content: center; margin-top: 6px; }
.cf-micro { display: flex; align-items: center; gap: 7px; font-size: 12px; color: var(--ink-3); margin: 14px 0 0; }
.cf-micro i { font-size: 15px; color: var(--green-600); }
.contact-sent { text-align: center; padding: 30px 10px; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.cs-check { width: 64px; height: 64px; border-radius: 50%; display: grid; place-items: center; background: var(--green-50); color: var(--green-600); font-size: 34px; }
.contact-sent h3 { margin: 0; font-size: 21px; font-weight: 500; color: var(--ink); }
.contact-sent p { margin: 0 0 8px; font-size: 14px; line-height: 1.9; color: var(--ink-2); }
@media (max-width: 880px){ .contact-grid { grid-template-columns: 1fr; gap: 32px; } }
@media (max-width: 460px){ .cf-row { grid-template-columns: 1fr; } .contact-assure { grid-template-columns: 1fr; } }

.foot { background: #060D18; color: #fff; padding: 0 0 28px; }
.foot-rule { height: 2px; background: var(--brand-gradient-h); }
.foot-top { display: grid; grid-template-columns: 1.2fr 2.4fr; gap: 48px; padding: 56px 0 40px; }
.foot-about { font-size: 13.5px; line-height: 2; color: rgba(255,255,255,.6); margin: 18px 0 20px; max-width: 320px; }
.foot-social { display: flex; gap: 10px; }
.foot-soc { width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); color: rgba(255,255,255,.7); font-size: 19px; transition: background .2s, color .2s; }
.foot-soc:hover { background: rgba(255,255,255,.12); color: #fff; }
.foot-cols { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; }
.foot-col { display: flex; flex-direction: column; }
.foot-col h5 { margin: 0 0 16px; font-size: 13px; font-weight: 600; color: #fff; }.foot-col a, .foot-addr { font-size: 13px; color: rgba(255,255,255,.6); padding: 6px 0; display: flex; align-items: center; gap: 8px; transition: color .18s; }
.foot-col a:hover { color: #fff; }
.foot-ci { font-size: 16px; color: var(--brand-primary-200); }
.foot-login { margin-top: 10px; color: var(--brand-primary-200) !important; font-weight: 500; }
.foot-col-contact a, .foot-col-contact .foot-addr { align-items: flex-start; line-height: 1.7; }
.foot-col-contact .foot-ci { margin-top: 2px; }
.foot-col-contact .foot-addr { color: rgba(255,255,255,.7); }
.foot-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1); font-size: 12.5px; color: rgba(255,255,255,.5); flex-wrap: wrap; }
.foot-bar-links { display: flex; gap: 20px; }
.foot-bar-links a { color: rgba(255,255,255,.5); }
.foot-bar-links a:hover { color: #fff; }
@media (max-width: 880px){ .foot-top { grid-template-columns: 1fr; gap: 32px; } .foot-cols { grid-template-columns: repeat(2, 1fr); } }

.foot-acc-btn {
  background: none; border: none; padding: 0; width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; text-align: right; color: inherit;
}
.foot-acc-btn h5 { margin: 0 0 16px; font-size: 13px; font-weight: 600; color: #fff; }
.foot-acc-chev { display: none; color: rgba(255,255,255,.45); font-size: 17px; transition: transform .3s ease; flex-shrink: 0; }
.fc-open .foot-acc-chev { transform: rotate(180deg); }
.foot-acc-body { display: flex; flex-direction: column; }

.foot-soc-bale img { width: 20px; height: 20px; filter: brightness(0) invert(1); opacity: .7; display: block; }
.foot-soc-bale:hover img { opacity: 1; }

@media (max-width: 640px) {
  .foot-cols { grid-template-columns: 1fr !important; gap: 0; }
  .foot-col { border-bottom: 1px solid rgba(255,255,255,.08); }
  .foot-acc-btn { padding: 16px 0; }
  .foot-acc-btn h5 { margin: 0; }
  .foot-acc-chev { display: block; }
  .foot-acc-body {
    max-height: 0; overflow: hidden;
    transition: max-height .36s cubic-bezier(.4,0,.2,1), padding .36s;
    padding-bottom: 0;
  }
  .fc-open .foot-acc-body { max-height: 520px; padding-bottom: 12px; }
  .foot-col a, .foot-addr { padding: 7px 0; }
}

.anim-off *, .anim-off *::before, .anim-off *::after { animation: none !important; }
.anim-low .dash, .anim-low .dash-badge, .anim-low .globe-sphere::before { animation: none !important; }
