:root {
  --ink: #08111f;
  --ink-2: #101b2d;
  --ink-3: #17253b;
  --paper: #f5f7fb;
  --white: #ffffff;
  --violet: #7c5cff;
  --violet-2: #a896ff;
  --cyan: #54d7ff;
  --mint: #7cf0ce;
  --text: #172033;
  --muted: #697386;
  --line: rgba(8, 17, 31, .12);
  --line-dark: rgba(255, 255, 255, .12);
  --shadow-sm: 0 12px 34px rgba(8, 17, 31, .08);
  --shadow-md: 0 28px 75px rgba(8, 17, 31, .16);
  --shadow-lg: 0 38px 110px rgba(0, 0, 0, .30);
  --radius-sm: 14px;
  --radius: 22px;
  --radius-lg: 34px;
  --container: 1240px;
  --ease: cubic-bezier(.2, .75, .2, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 96px; overflow-x: clip; }
body { margin: 0; color: var(--text); background: var(--paper); font-family: "DM Sans", Arial, sans-serif; font-size: 16px; line-height: 1.65; overflow-x: hidden; }
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }
.container { width: min(var(--container), calc(100% - 40px)); margin-inline: auto; }
.section { padding: clamp(82px, 10vw, 140px) 0; }
.hidden-field { position: absolute !important; left: -9999px !important; }
[hidden] { display: none !important; }

.skip-link { position: fixed; z-index: 9999; top: 12px; left: 12px; padding: 11px 15px; color: var(--ink); background: var(--white); border-radius: 10px; box-shadow: var(--shadow-sm); transform: translateY(-160%); transition: transform .2s ease; }
.skip-link:focus { transform: none; }

h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: "Manrope", "DM Sans", sans-serif; line-height: 1.02; letter-spacing: -.045em; }
h1 { font-size: clamp(3.3rem, 7.4vw, 7.25rem); }
h2 { font-size: clamp(2.4rem, 5vw, 5rem); }
h3 { font-size: clamp(1.25rem, 2vw, 1.75rem); }

.eyebrow { display: inline-flex; align-items: center; gap: 11px; margin-bottom: 18px; color: rgba(255, 255, 255, .72); font-family: "Manrope", sans-serif; font-size: .73rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow::before { content: ""; width: 30px; height: 3px; background: linear-gradient(90deg, var(--violet), var(--cyan)); border-radius: 99px; }
.eyebrow.dark { color: var(--ink); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 54px; padding: 0 23px; color: var(--white); background: linear-gradient(135deg, var(--violet), #6847ef); border: 1px solid transparent; border-radius: 999px; box-shadow: 0 12px 30px rgba(124, 92, 255, .23); font-weight: 800; line-height: 1; cursor: pointer; transition: transform .25s var(--ease), box-shadow .25s ease, background .25s ease, border-color .25s ease; }
.btn:hover { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(124, 92, 255, .32); }
.btn:active { transform: none; }
.btn-sm { min-height: 43px; padding-inline: 18px; font-size: .9rem; }
.btn-ghost { color: var(--white); background: rgba(255, 255, 255, .06); border-color: rgba(255, 255, 255, .18); box-shadow: none; backdrop-filter: blur(10px); }
.btn-ghost:hover { background: rgba(255, 255, 255, .11); box-shadow: none; }
.btn-light { color: var(--ink); background: var(--white); box-shadow: none; }
.btn-light:hover { box-shadow: 0 15px 34px rgba(0, 0, 0, .16); }
.btn:focus-visible, a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 3px solid var(--cyan); outline-offset: 3px; }

.utility-bar { position: relative; z-index: 60; color: rgba(255, 255, 255, .72); background: #040912; font-size: .78rem; font-weight: 600; }
.utility-inner { display: flex; align-items: center; justify-content: space-between; min-height: 37px; gap: 20px; }
.utility-inner > span { display: inline-flex; align-items: center; gap: 8px; }
.utility-links { display: flex; gap: 22px; }
.utility-links a { transition: color .2s ease; }
.utility-links a:hover { color: var(--white); }

.site-header { position: sticky; z-index: 50; top: 0; color: var(--white); background: rgba(8, 17, 31, .84); border-bottom: 1px solid var(--line-dark); backdrop-filter: blur(20px); transition: background .25s ease, box-shadow .25s ease; }
.site-header.scrolled { background: rgba(8, 17, 31, .96); box-shadow: 0 15px 42px rgba(0, 0, 0, .16); }
.nav { display: flex; align-items: center; min-height: 78px; gap: 28px; }
.brand { display: inline-flex; align-items: center; gap: 12px; min-width: max-content; }
.brand img { width: 46px; height: 46px; }
.brand-copy { display: grid; line-height: 1.05; }
.brand-copy strong { font-family: "Manrope", sans-serif; font-size: .98rem; letter-spacing: -.02em; }
.brand-copy small { margin-top: 5px; color: rgba(255, 255, 255, .5); font-size: .64rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.nav-links { display: flex; align-items: center; gap: 27px; margin-left: auto; }
.nav-links a { position: relative; color: rgba(255, 255, 255, .7); font-size: .91rem; font-weight: 650; }
.nav-links a::after { content: ""; position: absolute; right: 0; bottom: -8px; left: 0; height: 2px; background: var(--violet-2); transform: scaleX(0); transform-origin: right; transition: transform .25s var(--ease); }
.nav-links a:hover { color: var(--white); }
.nav-links a:hover::after { transform: scaleX(1); transform-origin: left; }
.nav-toggle { display: none; width: 44px; height: 44px; margin-left: auto; color: var(--white); background: rgba(255, 255, 255, .07); border: 1px solid var(--line-dark); border-radius: 13px; cursor: pointer; }

.hero { position: relative; min-height: calc(100svh - 115px); color: var(--white); background: var(--ink); overflow: hidden; }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 78px 78px; mask-image: linear-gradient(to bottom, black, transparent 90%); pointer-events: none; }
.hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, rgba(8,17,31,.12), rgba(8,17,31,.65)); pointer-events: none; }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(3px); pointer-events: none; }
.hero-glow-one { width: 690px; height: 690px; top: -390px; right: 8%; background: radial-gradient(circle, rgba(124, 92, 255, .25), transparent 68%); }
.hero-glow-two { width: 650px; height: 650px; bottom: -420px; left: 16%; background: radial-gradient(circle, rgba(84, 215, 255, .14), transparent 70%); }
.hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: .93fr 1.07fr; align-items: center; gap: clamp(45px, 7vw, 110px); min-height: calc(100svh - 115px); padding: 72px 0 88px; }
.hero-copy { position: relative; z-index: 5; }
.hero h1 { max-width: 800px; margin-bottom: 28px; }
.hero h1 span { color: transparent; background: linear-gradient(90deg, var(--violet-2), var(--cyan)); -webkit-background-clip: text; background-clip: text; }
.hero-lead { max-width: 670px; margin-bottom: 34px; color: rgba(255, 255, 255, .67); font-size: clamp(1.05rem, 1.45vw, 1.22rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 13px; margin-bottom: 36px; }
.hero-notes { display: flex; flex-wrap: wrap; gap: 10px; margin: 0; padding: 0; list-style: none; }
.hero-notes li { display: inline-flex; align-items: center; gap: 8px; padding: 9px 12px; color: rgba(255, 255, 255, .7); background: rgba(255, 255, 255, .045); border: 1px solid rgba(255, 255, 255, .08); border-radius: 999px; font-size: .8rem; font-weight: 650; }
.hero-notes i { color: var(--mint); }
.hero-visual { position: relative; min-height: 630px; }
.dashboard-card { position: absolute; inset: 40px 0 30px 6%; padding: 28px; color: var(--ink); background: rgba(255, 255, 255, .96); border: 1px solid rgba(255, 255, 255, .65); border-radius: 34px; box-shadow: var(--shadow-lg); backdrop-filter: blur(20px); overflow: hidden; }
.dashboard-card::after { content: ""; position: absolute; width: 340px; height: 340px; top: -220px; right: -110px; background: radial-gradient(circle, rgba(124,92,255,.22), transparent 70%); }
.dashboard-head { position: relative; z-index: 2; display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; margin-bottom: 25px; }
.dashboard-head div { display: grid; }
.dashboard-head small, .metric small { color: var(--muted); font-size: .68rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.dashboard-head strong { margin-top: 5px; font-family: "Manrope", sans-serif; font-size: 1.5rem; letter-spacing: -.035em; }
.live-pill { display: inline-flex; align-items: center; gap: 7px; padding: 8px 11px; color: #176e56; background: #e5fff6; border-radius: 999px; font-size: .72rem; font-weight: 800; }
.live-pill i { width: 8px; height: 8px; background: #35c996; border-radius: 50%; box-shadow: 0 0 0 5px rgba(53,201,150,.14); }
.metric-row { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.metric { display: grid; padding: 18px; background: #f7f8fc; border: 1px solid rgba(8,17,31,.07); border-radius: 18px; }
.metric strong { margin: 5px 0 1px; font-family: "Manrope", sans-serif; font-size: 1.22rem; }
.metric span { color: var(--muted); font-size: .76rem; }
.chart { position: relative; height: 195px; margin: 24px 0 16px; background: linear-gradient(180deg, rgba(124,92,255,.06), transparent); border: 1px solid rgba(8,17,31,.07); border-radius: 20px; overflow: hidden; }
.chart-grid { position: absolute; inset: 0; background: linear-gradient(rgba(8,17,31,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(8,17,31,.05) 1px, transparent 1px); background-size: 100% 42px, 65px 100%; }
.chart svg { position: absolute; right: 0; bottom: 0; left: 0; width: 100%; height: 90%; }
.chart-fill { fill: url(#chartFill); }
.chart-line { fill: none; stroke: var(--violet); stroke-width: 5; stroke-linecap: round; }
.activity-list { display: grid; gap: 10px; }
.activity-list > div { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 13px; padding: 12px 13px; border: 1px solid rgba(8,17,31,.08); border-radius: 15px; }
.activity-icon { display: grid; place-items: center; width: 38px; height: 38px; color: var(--violet); background: #f0edff; border-radius: 11px; }
.activity-list p { display: grid; margin: 0; line-height: 1.3; }
.activity-list p strong { font-size: .84rem; }
.activity-list p small { margin-top: 3px; color: var(--muted); font-size: .7rem; }
.activity-list > div > span:last-child { color: #a5adba; font-family: "Manrope", sans-serif; font-size: .8rem; font-weight: 800; }
.terminal-card { position: absolute; z-index: 4; top: 0; left: -20px; width: 335px; color: #dfe8ff; background: rgba(8, 17, 31, .92); border: 1px solid rgba(255, 255, 255, .12); border-radius: 18px; box-shadow: 0 20px 60px rgba(0,0,0,.34); backdrop-filter: blur(14px); overflow: hidden; }
.terminal-top { display: flex; align-items: center; gap: 6px; padding: 11px 14px; background: rgba(255,255,255,.045); border-bottom: 1px solid rgba(255,255,255,.08); }
.terminal-top span { width: 8px; height: 8px; background: #ff7474; border-radius: 50%; }
.terminal-top span:nth-child(2) { background: #ffd36a; }
.terminal-top span:nth-child(3) { background: #62dfab; }
.terminal-top small { margin-left: auto; color: rgba(255,255,255,.45); font-size: .68rem; }
.terminal-body { padding: 18px; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .75rem; line-height: 1.8; }
.code-line { display: flex; gap: 13px; }
.line-no { color: rgba(255,255,255,.27); }
.code-line b { color: var(--violet-2); font-weight: 500; }
.code-line em { color: var(--mint); font-style: normal; }
.mini-card { position: absolute; z-index: 5; display: flex; align-items: center; gap: 11px; min-width: 220px; padding: 14px 16px; color: var(--ink); background: rgba(255,255,255,.95); border: 1px solid rgba(255,255,255,.7); border-radius: 17px; box-shadow: 0 20px 55px rgba(0,0,0,.24); backdrop-filter: blur(14px); }
.mini-card i { display: grid; place-items: center; width: 37px; height: 37px; color: var(--violet); background: #efecff; border-radius: 11px; }
.mini-card span { display: grid; line-height: 1.25; }
.mini-card strong { font-size: .78rem; }
.mini-card small { margin-top: 3px; color: var(--muted); font-size: .66rem; }
.mini-card-one { right: -25px; bottom: 0; }
.mini-card-two { left: -16px; bottom: 65px; }

.trust-strip { position: relative; z-index: 4; color: var(--white); background: var(--ink-2); border-top: 1px solid var(--line-dark); border-bottom: 1px solid var(--line-dark); }
.trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.trust-grid > div { display: grid; align-content: center; min-height: 118px; padding: 25px 30px; border-right: 1px solid var(--line-dark); }
.trust-grid > div:first-child { border-left: 1px solid var(--line-dark); }
.trust-grid small { color: rgba(255,255,255,.45); font-size: .69rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.trust-grid strong { display: flex; align-items: center; gap: 9px; margin-top: 6px; font-family: "Manrope", sans-serif; font-size: 1.1rem; }
.status-dot { width: 9px; height: 9px; background: #35c996; border-radius: 50%; box-shadow: 0 0 0 5px rgba(53,201,150,.14); }

.section-head { display: grid; grid-template-columns: minmax(0, 1.55fr) minmax(270px, .7fr); align-items: end; gap: 70px; margin-bottom: 55px; }
.section-head h2 { margin-bottom: 0; color: var(--ink); }
.section-head p { max-width: 510px; margin-bottom: 7px; color: var(--muted); font-size: 1.06rem; }
.service-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.service-card { position: relative; min-height: 350px; padding: 31px; background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow-sm); overflow: hidden; transition: border-color .25s ease, box-shadow .25s ease; }
.service-card:hover { border-color: rgba(124,92,255,.32); box-shadow: var(--shadow-md); }
.service-card.featured { background: linear-gradient(160deg, #101b2d, #08111f); border-color: rgba(255,255,255,.08); color: var(--white); }
.service-card.featured::before { content: ""; position: absolute; width: 270px; height: 270px; top: -160px; right: -90px; background: radial-gradient(circle, rgba(124,92,255,.35), transparent 70%); }
.card-number { position: absolute; top: 28px; right: 28px; color: rgba(8,17,31,.25); font-family: "Manrope", sans-serif; font-size: .78rem; font-weight: 800; }
.featured .card-number { color: rgba(255,255,255,.25); }
.service-icon { display: grid; place-items: center; width: 54px; height: 54px; margin-bottom: 48px; color: var(--violet); background: #f0edff; border-radius: 16px; font-size: 1.2rem; }
.featured .service-icon { color: var(--white); background: rgba(124,92,255,.26); }
.service-card h3 { margin-bottom: 13px; }
.service-card p { margin-bottom: 25px; color: var(--muted); }
.featured p { color: rgba(255,255,255,.61); }
.text-link { display: inline-flex; align-items: center; gap: 8px; margin-top: auto; color: var(--violet); font-size: .88rem; font-weight: 800; }
.featured .text-link { color: var(--violet-2); }
.text-link i { transition: transform .2s ease; }
.text-link:hover i { transform: translateX(4px); }

.section-dark { position: relative; color: var(--white); background: var(--ink); overflow: hidden; }
.section-dark::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px); background-size: 76px 76px; mask-image: radial-gradient(circle at center, black, transparent 83%); }
.approach-grid { position: relative; z-index: 2; display: grid; grid-template-columns: .86fr 1.14fr; align-items: start; gap: clamp(60px, 9vw, 130px); }
.approach-copy { position: sticky; top: 130px; }
.approach-copy h2 { max-width: 720px; margin-bottom: 25px; }
.approach-copy p { max-width: 570px; margin-bottom: 32px; color: rgba(255,255,255,.63); font-size: 1.07rem; }
.steps { display: grid; }
.step { display: grid; grid-template-columns: 65px 1fr; gap: 23px; padding: 32px 0; border-top: 1px solid var(--line-dark); }
.step:last-child { border-bottom: 1px solid var(--line-dark); }
.step > span { display: grid; place-items: center; width: 50px; height: 50px; color: var(--violet-2); background: rgba(124,92,255,.13); border: 1px solid rgba(124,92,255,.28); border-radius: 15px; font-family: "Manrope", sans-serif; font-size: .78rem; font-weight: 800; }
.step h3 { margin: 2px 0 10px; }
.step p { max-width: 520px; margin: 0; color: rgba(255,255,255,.58); }

.showcase-section { background: var(--white); }
.showcase-grid { display: grid; grid-template-columns: 1fr .88fr; align-items: center; gap: clamp(50px, 8vw, 110px); }
.showcase-image { position: relative; min-height: 650px; }
.showcase-image > img { width: 100%; height: 650px; object-fit: cover; border-radius: 36px 36px 140px 36px; box-shadow: var(--shadow-md); filter: saturate(.75) contrast(1.03); }
.image-note { position: absolute; right: -35px; bottom: 42px; display: grid; width: min(330px, 80%); padding: 23px; color: var(--white); background: rgba(8,17,31,.92); border: 1px solid rgba(255,255,255,.12); border-radius: 20px; box-shadow: var(--shadow-md); backdrop-filter: blur(14px); }
.image-note span { color: var(--violet-2); font-size: .69rem; font-weight: 800; letter-spacing: .11em; text-transform: uppercase; }
.image-note strong { margin-top: 7px; font-family: "Manrope", sans-serif; font-size: 1.2rem; }
.showcase-copy h2 { color: var(--ink); margin-bottom: 24px; }
.showcase-copy > p { margin-bottom: 32px; color: var(--muted); font-size: 1.07rem; }
.feature-list { display: grid; gap: 16px; }
.feature-list > div { display: grid; grid-template-columns: 48px 1fr; align-items: start; gap: 14px; padding: 17px 0; border-top: 1px solid var(--line); }
.feature-list > div:last-child { border-bottom: 1px solid var(--line); }
.feature-list i { display: grid; place-items: center; width: 43px; height: 43px; color: var(--violet); background: #f0edff; border-radius: 13px; }
.feature-list span { display: grid; }
.feature-list strong { font-family: "Manrope", sans-serif; }
.feature-list small { margin-top: 4px; color: var(--muted); font-size: .82rem; }

.company-section { background: #edeffd; }
.company-panel { display: grid; grid-template-columns: .8fr 1.2fr; gap: 70px; padding: clamp(36px, 6vw, 72px); color: var(--white); background: linear-gradient(145deg, var(--ink-3), var(--ink)); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.company-intro h2 { margin-bottom: 22px; }
.company-intro p { max-width: 510px; margin-bottom: 30px; color: rgba(255,255,255,.61); }
.company-details { margin: 0; border-top: 1px solid var(--line-dark); }
.company-details > div { display: grid; grid-template-columns: 160px 1fr; gap: 20px; padding: 17px 0; border-bottom: 1px solid var(--line-dark); }
.company-details dt { color: rgba(255,255,255,.44); font-size: .7rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.company-details dd { margin: 0; color: rgba(255,255,255,.9); font-weight: 650; }
.copy-btn { display: inline-grid; place-items: center; width: 31px; height: 31px; margin-left: 7px; color: var(--violet-2); background: rgba(255,255,255,.07); border: 1px solid var(--line-dark); border-radius: 9px; cursor: pointer; vertical-align: middle; }
.copy-btn.copied { color: var(--mint); }

.faq-section { background: var(--paper); }
.faq-grid { display: grid; grid-template-columns: .72fr 1.28fr; align-items: start; gap: clamp(55px, 8vw, 120px); }
.faq-grid h2 { color: var(--ink); }
.faq-intro { max-width: 510px; color: var(--muted); }
.faq-list { border-top: 1px solid var(--line); }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-question { display: grid; grid-template-columns: 1fr 42px; align-items: center; gap: 20px; width: 100%; padding: 24px 0; text-align: left; background: transparent; border: 0; cursor: pointer; }
.faq-question span { font-family: "Manrope", sans-serif; font-size: 1.08rem; font-weight: 800; letter-spacing: -.02em; }
.faq-question i { display: grid; place-items: center; width: 38px; height: 38px; color: var(--violet); background: #ece9ff; border-radius: 12px; transition: transform .25s ease; }
.faq-item.open .faq-question i { transform: rotate(45deg); }
.faq-answer { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .35s var(--ease); }
.faq-answer > p { min-height: 0; margin: 0; color: var(--muted); overflow: hidden; }
.faq-item.open .faq-answer { grid-template-rows: 1fr; }
.faq-item.open .faq-answer > p { padding: 0 70px 25px 0; }

.contact-section { position: relative; padding: clamp(90px, 11vw, 150px) 0; color: var(--white); background: var(--ink); overflow: hidden; }
.contact-section::before { content: ""; position: absolute; width: 760px; height: 760px; left: -450px; bottom: -430px; background: radial-gradient(circle, rgba(84,215,255,.17), transparent 68%); }
.contact-grid { position: relative; z-index: 2; display: grid; grid-template-columns: .8fr 1.2fr; align-items: start; gap: clamp(55px, 8vw, 110px); }
.contact-copy { position: sticky; top: 125px; }
.contact-copy h2 { margin-bottom: 24px; }
.contact-copy > p { max-width: 540px; color: rgba(255,255,255,.62); font-size: 1.05rem; }
.contact-card { display: grid; grid-template-columns: 50px 1fr; gap: 15px; max-width: 450px; margin-top: 35px; padding: 20px; background: rgba(255,255,255,.05); border: 1px solid var(--line-dark); border-radius: 18px; }
.contact-card > i { display: grid; place-items: center; width: 46px; height: 46px; color: var(--violet-2); background: rgba(124,92,255,.15); border-radius: 13px; }
.contact-card div { display: grid; }
.contact-card small { color: rgba(255,255,255,.43); font-size: .68rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.contact-card strong { margin: 6px 0; font-family: "Manrope", sans-serif; line-height: 1.35; }
.contact-card span { color: rgba(255,255,255,.46); font-size: .75rem; }
.contact-form { position: relative; padding: clamp(28px, 5vw, 48px); color: var(--text); background: var(--white); border-radius: 30px; box-shadow: var(--shadow-lg); }
.form-head { display: flex; align-items: center; justify-content: space-between; gap: 20px; margin-bottom: 28px; }
.form-head span { font-family: "Manrope", sans-serif; font-size: 1.35rem; font-weight: 800; letter-spacing: -.035em; }
.form-head small { color: var(--muted); font-size: .72rem; }
.field-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form > label, .field-grid label { display: grid; gap: 8px; margin-bottom: 17px; color: #333d50; font-size: .79rem; font-weight: 750; }
.contact-form input, .contact-form select, .contact-form textarea { width: 100%; color: var(--text); background: #f8f9fc; border: 1px solid rgba(8,17,31,.13); border-radius: 13px; outline: 0; transition: border-color .2s ease, box-shadow .2s ease, background .2s ease; }
.contact-form input, .contact-form select { min-height: 50px; padding: 0 14px; }
.contact-form textarea { min-height: 145px; padding: 13px 14px; resize: vertical; }
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus { background: var(--white); border-color: var(--violet); box-shadow: 0 0 0 4px rgba(124,92,255,.12); }
.checkbox { display: grid !important; grid-template-columns: auto 1fr; align-items: start; gap: 10px !important; margin: 4px 0 20px !important; color: var(--muted) !important; font-weight: 500 !important; line-height: 1.45; }
.checkbox input { width: 18px; height: 18px; min-height: 0; margin-top: 2px; accent-color: var(--violet); }
.checkbox a { color: var(--violet); font-weight: 700; text-decoration: underline; }
.btn-submit { width: 100%; border: 0; }
.form-note { display: flex; align-items: flex-start; gap: 8px; margin: 16px 0 0; color: var(--muted); font-size: .7rem; line-height: 1.5; }
.form-note i { margin-top: 3px; color: var(--violet); }

.site-footer { color: rgba(255,255,255,.64); background: #040912; }
.footer-top { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 40px; padding: 48px 0; border-bottom: 1px solid var(--line-dark); }
.footer-top p { margin: 0; text-align: center; }
.back-top { display: inline-flex; align-items: center; gap: 8px; color: var(--white); font-weight: 750; }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 24px 0 34px; font-size: .76rem; }
.footer-bottom nav { display: flex; flex-wrap: wrap; gap: 18px; }
.footer-bottom a:hover { color: var(--white); }

.cookie-banner { position: fixed; z-index: 1000; right: 20px; bottom: 20px; left: 20px; display: flex; align-items: center; justify-content: space-between; gap: 30px; max-width: 1040px; margin-inline: auto; padding: 18px 20px; color: var(--white); background: rgba(8,17,31,.96); border: 1px solid var(--line-dark); border-radius: 18px; box-shadow: var(--shadow-lg); backdrop-filter: blur(18px); }
.cookie-banner strong { font-family: "Manrope", sans-serif; }
.cookie-banner p { margin: 3px 0 0; color: rgba(255,255,255,.57); font-size: .78rem; }
.cookie-actions { display: flex; gap: 10px; min-width: max-content; }

/* Internal pages */
.subpage-main { min-height: 70vh; }
.subpage-hero { padding: 90px 0 65px; color: var(--white); background: var(--ink); }
.subpage-hero h1 { max-width: 900px; margin-bottom: 18px; font-size: clamp(2.8rem, 6vw, 5.8rem); }
.subpage-hero p { max-width: 760px; color: rgba(255,255,255,.62); font-size: 1.08rem; }
.legal-section { padding: 70px 0 110px; }
.legal-layout { display: grid; grid-template-columns: 250px minmax(0, 760px); gap: 70px; align-items: start; }
.legal-nav { position: sticky; top: 115px; display: grid; gap: 8px; padding: 18px; background: var(--white); border: 1px solid var(--line); border-radius: 16px; box-shadow: var(--shadow-sm); }
.legal-nav a { padding: 8px 10px; color: var(--muted); border-radius: 9px; font-size: .83rem; font-weight: 700; }
.legal-nav a:hover { color: var(--violet); background: #f1eeff; }
.legal-content { min-width: 0; }
.legal-content section { padding: 0 0 32px; margin-bottom: 32px; border-bottom: 1px solid var(--line); }
.legal-content h2 { margin-bottom: 15px; color: var(--ink); font-size: clamp(1.65rem, 3vw, 2.25rem); letter-spacing: -.035em; }
.legal-content h3 { margin: 24px 0 9px; color: var(--ink); font-size: 1.18rem; letter-spacing: -.02em; }
.legal-content p, .legal-content li { color: var(--muted); }
.legal-content ul { padding-left: 20px; }
.notice-box { padding: 18px 20px; background: #efedff; border-left: 4px solid var(--violet); border-radius: 12px; }
.notice-box p { margin: 0; color: #3d3a5a; }
.simple-page { display: grid; place-items: center; min-height: calc(100svh - 115px); padding: 70px 0; color: var(--white); background: var(--ink); text-align: center; }
.simple-card { max-width: 760px; padding: clamp(35px, 7vw, 70px); background: rgba(255,255,255,.05); border: 1px solid var(--line-dark); border-radius: 30px; }
.simple-icon { display: grid; place-items: center; width: 68px; height: 68px; margin: 0 auto 24px; color: var(--violet-2); background: rgba(124,92,255,.16); border-radius: 20px; font-size: 1.5rem; }
.simple-card h1 { margin-bottom: 18px; font-size: clamp(2.4rem, 6vw, 5rem); }
.simple-card p { color: rgba(255,255,255,.62); }

[data-reveal] { opacity: 1; transform: none; }
.js [data-reveal] { opacity: 0; transform: translateY(28px); }
.js [data-reveal="left"] { transform: translateX(-32px); }
.js [data-reveal="right"] { transform: translateX(32px); }
.js [data-reveal].revealed { opacity: 1; transform: none; transition: opacity .75s ease, transform .75s var(--ease); }

@media (max-width: 1080px) {
  .nav-links { position: fixed; top: 115px; right: 20px; left: 20px; display: grid; gap: 4px; padding: 14px; background: rgba(8,17,31,.98); border: 1px solid var(--line-dark); border-radius: 18px; box-shadow: var(--shadow-lg); transform: translateY(-20px); opacity: 0; visibility: hidden; transition: .25s ease; }
  .nav-links.open { transform: none; opacity: 1; visibility: visible; }
  .nav-links a { padding: 13px 14px; border-radius: 10px; }
  .nav-links a:hover { background: rgba(255,255,255,.06); }
  .nav-links a::after { display: none; }
  .nav-toggle { display: inline-grid; place-items: center; }
  .nav-cta { margin-left: auto; }
  .hero-grid { grid-template-columns: 1fr; padding-top: 85px; }
  .hero-copy { max-width: 850px; }
  .hero-visual { width: min(780px, 100%); margin-inline: auto; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .approach-grid, .showcase-grid, .company-panel, .faq-grid, .contact-grid { grid-template-columns: 1fr; }
  .approach-copy, .contact-copy { position: static; }
  .showcase-image { width: min(820px, 100%); }
  .company-panel { gap: 45px; }
  .legal-layout { grid-template-columns: 210px minmax(0, 1fr); gap: 42px; }
}

@media (max-width: 760px) {
  .container { width: min(100% - 28px, var(--container)); }
  .utility-links { display: none; }
  .nav-cta { display: none; }
  .nav-links { top: 114px; right: 14px; left: 14px; }
  .hero { min-height: auto; }
  .hero-grid { min-height: auto; padding: 68px 0 85px; }
  .hero-visual { min-height: 510px; }
  .dashboard-card { inset: 55px 0 25px; padding: 20px; }
  .terminal-card { left: -5px; width: 285px; }
  .mini-card-one { right: -7px; }
  .mini-card-two { left: -4px; bottom: 40px; }
  .activity-list > div:nth-child(2) { display: none; }
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .trust-grid > div { min-height: 96px; padding: 19px; border-bottom: 1px solid var(--line-dark); }
  .trust-grid > div:nth-child(odd) { border-left: 1px solid var(--line-dark); }
  .section-head { grid-template-columns: 1fr; gap: 24px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 320px; }
  .showcase-image, .showcase-image > img { min-height: 500px; height: 500px; }
  .image-note { right: 15px; bottom: 20px; }
  .company-details > div { grid-template-columns: 1fr; gap: 5px; }
  .field-grid { grid-template-columns: 1fr; gap: 0; }
  .form-head { display: grid; }
  .footer-top { grid-template-columns: 1fr; justify-items: start; gap: 20px; }
  .footer-top p { text-align: left; }
  .footer-bottom { align-items: flex-start; flex-direction: column; }
  .cookie-banner { align-items: stretch; flex-direction: column; gap: 15px; }
  .cookie-actions { display: grid; grid-template-columns: 1fr 1fr; min-width: 0; }
  .legal-layout { grid-template-columns: 1fr; }
  .legal-nav { position: static; }
}

@media (max-width: 520px) {
  .hero h1 { font-size: clamp(2.8rem, 15vw, 4.2rem); }
  .hero-actions .btn { width: 100%; }
  .hero-notes { display: grid; }
  .hero-visual { min-height: 465px; }
  .dashboard-card { inset: 58px 0 18px; border-radius: 25px; }
  .dashboard-head strong { font-size: 1.2rem; }
  .metric-row { grid-template-columns: 1fr; }
  .metric:nth-child(2) { display: none; }
  .chart { height: 165px; }
  .terminal-card { width: 245px; }
  .terminal-body { padding: 13px; font-size: .66rem; }
  .mini-card { min-width: 190px; padding: 11px 13px; }
  .mini-card-one { bottom: 0; }
  .mini-card-two { display: none; }
  .trust-grid strong { font-size: .9rem; }
  .showcase-image, .showcase-image > img { min-height: 420px; height: 420px; border-radius: 26px 26px 90px 26px; }
  .contact-form { padding: 24px 19px; }
  .cookie-actions { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
}

/* =========================================================
   ACCHECK commercial site — v2
   ========================================================= */
:root {
  --violet: #6f55f5;
  --violet-2: #aa9cff;
  --cyan: #5cd8ff;
  --mint: #74ebbd;
  --paper: #f3f5fa;
  --cream: #f9f7f2;
}
body { background: var(--paper); }
.nav { min-height: 74px; }
.nav-links { gap: 22px; }
.nav-links a { font-size: .86rem; }
.utility-status { display: inline-flex; align-items: center; gap: 8px; color: rgba(255,255,255,.86); }
.utility-status i { width: 7px; height: 7px; background: #51d69f; border-radius: 50%; box-shadow: 0 0 0 5px rgba(81,214,159,.12); }

.hero-v2 { min-height: 760px; background: radial-gradient(circle at 78% 14%, rgba(111,85,245,.18), transparent 28%), linear-gradient(145deg, #07101f 0%, #0a1425 58%, #0d1930 100%); }
.hero-v2::before { background-size: 72px 72px; opacity: .68; }
.hero-grid-v2 { grid-template-columns: .88fr 1.12fr; gap: clamp(44px, 6vw, 92px); min-height: 760px; padding-top: 78px; padding-bottom: 92px; }
.hero-grid-v2 .hero-copy { padding-top: 8px; }
.hero-kicker { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-bottom: 24px; }
.hero-kicker > span { display: inline-flex; align-items: center; gap: 8px; padding: 8px 11px; color: rgba(255,255,255,.68); background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.09); border-radius: 999px; font-size: .72rem; font-weight: 750; letter-spacing: .04em; }
.hero-kicker > span:first-child { color: #dffbf1; background: rgba(116,235,189,.08); border-color: rgba(116,235,189,.18); }
.hero-kicker i { width: 7px; height: 7px; background: var(--mint); border-radius: 50%; box-shadow: 0 0 0 5px rgba(116,235,189,.12); }
.hero-v2 h1 { max-width: 740px; margin-bottom: 24px; font-size: clamp(3.2rem, 5.65vw, 5.9rem); }
.hero-v2 .hero-lead { max-width: 700px; margin-bottom: 30px; line-height: 1.7; }
.hero-proof { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; max-width: 720px; margin-top: 24px; }
.hero-proof > div { display: grid; grid-template-columns: 34px 1fr; align-items: start; gap: 9px; padding: 13px; background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; }
.hero-proof > div > i { display: grid; place-items: center; width: 32px; height: 32px; color: var(--violet-2); background: rgba(111,85,245,.16); border-radius: 10px; font-size: .78rem; }
.hero-proof span { display: grid; line-height: 1.25; }
.hero-proof strong { font-family: "Manrope", sans-serif; font-size: .76rem; }
.hero-proof small { margin-top: 4px; color: rgba(255,255,255,.44); font-size: .63rem; }

.hero-product { min-height: 615px; }
.product-window { position: absolute; inset: 16px 0 18px 3%; color: var(--text); background: #f9fbff; border: 1px solid rgba(255,255,255,.72); border-radius: 28px; box-shadow: 0 40px 110px rgba(0,0,0,.37); overflow: hidden; transform: perspective(1100px) rotateY(-2.5deg) rotateX(1deg); transform-origin: center; }
.product-topbar { display: flex; align-items: center; justify-content: space-between; min-height: 74px; padding: 0 24px; background: #fff; border-bottom: 1px solid #e5e9f1; }
.product-brand { display: flex; align-items: center; gap: 11px; }
.product-logo { display: grid; place-items: center; width: 39px; height: 39px; color: #fff; background: linear-gradient(145deg, var(--violet), #4b34ca); border-radius: 12px; box-shadow: 0 9px 20px rgba(111,85,245,.25); }
.product-brand > span:last-child { display: grid; line-height: 1.1; }
.product-brand strong { font-family: "Manrope", sans-serif; font-size: .86rem; }
.product-brand small { margin-top: 5px; color: #8b95a7; font-size: .6rem; }
.product-user span { display: grid; place-items: center; width: 35px; height: 35px; color: #fff; background: #18253b; border-radius: 50%; font-size: .7rem; font-weight: 800; }
.product-layout { display: grid; grid-template-columns: 64px 1fr; min-height: 505px; }
.product-sidebar { display: flex; flex-direction: column; align-items: center; gap: 11px; padding-top: 22px; background: #0c1729; }
.product-sidebar span { display: grid; place-items: center; width: 38px; height: 38px; color: rgba(255,255,255,.43); border-radius: 11px; font-size: .82rem; }
.product-sidebar span.active { color: #fff; background: rgba(111,85,245,.85); box-shadow: 0 10px 22px rgba(111,85,245,.25); }
.product-sidebar span:last-child { margin-top: auto; margin-bottom: 18px; }
.product-main { min-width: 0; padding: 23px; }
.product-heading { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.product-heading > div { display: grid; }
.product-heading small { color: #8a93a3; font-size: .63rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }
.product-heading strong { margin-top: 3px; font-family: "Manrope", sans-serif; font-size: 1.28rem; letter-spacing: -.04em; }
.product-heading button { display: inline-flex; align-items: center; gap: 7px; min-height: 36px; padding: 0 12px; color: #fff; background: var(--violet); border: 0; border-radius: 10px; font-size: .66rem; font-weight: 800; }
.product-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 13px; }
.product-metrics article { display: grid; grid-template-columns: 38px 1fr; gap: 10px; padding: 13px; background: #fff; border: 1px solid #e7eaf1; border-radius: 15px; box-shadow: 0 8px 20px rgba(20,34,58,.04); }
.metric-icon { display: grid; place-items: center; width: 36px; height: 36px; border-radius: 11px; font-size: .75rem; }
.metric-icon.violet { color: #6f55f5; background: #eeeaff; }
.metric-icon.mint { color: #258b68; background: #e8fbf4; }
.metric-icon.blue { color: #247ca0; background: #e8f7fc; }
.product-metrics article > div { display: grid; line-height: 1.1; }
.product-metrics small { color: #8892a4; font-size: .56rem; font-weight: 700; }
.product-metrics strong { margin-top: 5px; font-family: "Manrope", sans-serif; font-size: 1.08rem; }
.product-metrics em { margin-top: 4px; color: #8e98aa; font-size: .54rem; font-style: normal; }
.product-columns { display: grid; grid-template-columns: 1.38fr .72fr; gap: 11px; }
.workflow-panel, .activity-panel { padding: 15px; background: #fff; border: 1px solid #e7eaf1; border-radius: 16px; }
.panel-title { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; margin-bottom: 12px; }
.panel-title > span:first-child { display: grid; line-height: 1.15; }
.panel-title strong { font-family: "Manrope", sans-serif; font-size: .73rem; }
.panel-title small { margin-top: 4px; color: #8d96a7; font-size: .56rem; }
.panel-tag { padding: 5px 8px; color: #26785d; background: #e8fbf4; border-radius: 999px; font-size: .53rem; font-weight: 800; }
.workflow-line { position: relative; display: grid; grid-template-columns: 29px 1fr auto; align-items: center; gap: 8px; min-height: 52px; }
.workflow-line:not(:last-child)::after { content: ""; position: absolute; z-index: 0; top: 40px; bottom: -10px; left: 14px; width: 1px; background: #e0e5ec; }
.workflow-line > span { position: relative; z-index: 1; display: grid; place-items: center; width: 28px; height: 28px; color: #9da7b6; background: #f1f3f7; border-radius: 50%; font-size: .58rem; }
.workflow-line > span.done { color: #fff; background: #45bf92; }
.workflow-line > span.current { color: #fff; background: var(--violet); box-shadow: 0 0 0 5px rgba(111,85,245,.09); }
.workflow-line p { display: grid; margin: 0; line-height: 1.15; }
.workflow-line p strong { font-size: .63rem; }
.workflow-line p small { margin-top: 4px; color: #8e97a6; font-size: .53rem; }
.workflow-line time { color: #9ba4b2; font-size: .51rem; }
.activity-panel { display: flex; flex-direction: column; }
.mini-chart { display: flex; align-items: end; gap: 6px; height: 132px; padding: 14px 8px 0; background: linear-gradient(180deg, #f6f3ff, rgba(246,243,255,.22)); border-radius: 12px; }
.mini-chart span { flex: 1; min-height: 14px; background: linear-gradient(180deg, #9d8bff, #6f55f5); border-radius: 5px 5px 2px 2px; opacity: .88; }
.activity-summary { display: grid; grid-template-columns: 31px 1fr; align-items: center; gap: 8px; margin-top: auto; padding-top: 12px; }
.activity-summary > span { display: grid; place-items: center; width: 30px; height: 30px; color: #258b68; background: #e8fbf4; border-radius: 9px; font-size: .65rem; }
.activity-summary p { display: grid; margin: 0; line-height: 1.2; }
.activity-summary strong { font-size: .62rem; }
.activity-summary small { margin-top: 3px; color: #8c96a6; font-size: .53rem; }
.float-note { position: absolute; z-index: 5; display: grid; grid-template-columns: 39px 1fr; align-items: center; gap: 10px; min-width: 210px; padding: 12px 14px; color: #fff; background: rgba(7,16,31,.92); border: 1px solid rgba(255,255,255,.13); border-radius: 15px; box-shadow: 0 18px 55px rgba(0,0,0,.28); backdrop-filter: blur(16px); }
.float-note > i { display: grid; place-items: center; width: 37px; height: 37px; color: var(--mint); background: rgba(116,235,189,.1); border-radius: 11px; }
.float-note span { display: grid; line-height: 1.2; }
.float-note strong { font-family: "Manrope", sans-serif; font-size: .73rem; }
.float-note small { margin-top: 4px; color: rgba(255,255,255,.47); font-size: .61rem; }
.float-note-one { right: -20px; bottom: 73px; }
.float-note-two { left: -14px; top: 73px; }

.trust-strip-v2 { position: relative; z-index: 4; }
.trust-strip-v2 .trust-grid > div { background: rgba(255,255,255,.015); }

.section-head-tight { align-items: end; }
.problem-section { background: var(--cream); }
.problem-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.problem-grid article { position: relative; min-height: 300px; padding: 30px; background: #fff; border: 1px solid rgba(8,17,31,.08); border-radius: 23px; box-shadow: 0 14px 38px rgba(8,17,31,.06); overflow: hidden; }
.problem-grid article::after { content: ""; position: absolute; right: -70px; bottom: -80px; width: 180px; height: 180px; background: radial-gradient(circle, rgba(111,85,245,.12), transparent 68%); }
.problem-grid article > span { position: absolute; top: 24px; right: 27px; color: #bbc1cd; font-family: "Manrope", sans-serif; font-size: .72rem; font-weight: 800; }
.problem-grid article > i { display: grid; place-items: center; width: 52px; height: 52px; margin-bottom: 35px; color: var(--violet); background: #eeeaff; border-radius: 15px; }
.problem-grid h3 { max-width: 260px; margin-bottom: 15px; color: var(--ink); }
.problem-grid p { margin: 0; color: var(--muted); font-size: .92rem; }

.services-v2 { background: #f4f6fb; }
.service-bento { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.service-bento-card { position: relative; min-height: 340px; padding: 30px; background: #fff; border: 1px solid rgba(8,17,31,.09); border-radius: 24px; box-shadow: 0 12px 34px rgba(8,17,31,.055); overflow: hidden; }
.service-bento-card.large { grid-row: span 2; min-height: 698px; }
.service-bento-card.wide { grid-column: span 2; }
.service-bento-card.dark-card { color: #fff; background: linear-gradient(155deg, #17243a, #091321 70%); border-color: rgba(255,255,255,.08); box-shadow: 0 30px 76px rgba(8,17,31,.23); }
.service-bento-card.dark-card::after { content: ""; position: absolute; right: -130px; bottom: -150px; width: 420px; height: 420px; background: radial-gradient(circle, rgba(111,85,245,.28), transparent 68%); }
.service-bento-card.soft-card { background: linear-gradient(135deg, #fff, #f2efff); }
.service-top { position: relative; z-index: 2; display: flex; align-items: center; justify-content: space-between; margin-bottom: 42px; }
.service-bento-card .service-icon { display: grid; place-items: center; width: 50px; height: 50px; color: var(--violet); background: #eeeaff; border-radius: 15px; }
.dark-card .service-icon { color: var(--violet-2); background: rgba(111,85,245,.18); }
.service-bento-card .card-number { color: #b7bdc9; font-family: "Manrope", sans-serif; font-size: .72rem; font-weight: 800; }
.dark-card .card-number { color: rgba(255,255,255,.34); }
.service-bento-card h3 { position: relative; z-index: 2; margin-bottom: 16px; color: var(--ink); }
.dark-card h3 { max-width: 380px; color: #fff; font-size: clamp(1.7rem, 3vw, 2.55rem); }
.service-bento-card p { position: relative; z-index: 2; color: var(--muted); }
.dark-card p { color: rgba(255,255,255,.58); }
.service-bento-card ul { position: relative; z-index: 2; display: grid; gap: 11px; margin: 33px 0 42px; padding: 0; list-style: none; }
.service-bento-card li { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,.72); font-size: .86rem; }
.service-bento-card li::before { content: ""; width: 7px; height: 7px; background: var(--mint); border-radius: 50%; box-shadow: 0 0 0 5px rgba(116,235,189,.09); }
.service-bento-card .text-link { position: relative; z-index: 2; }
.wide-copy { display: grid; grid-template-columns: 1fr 250px; align-items: end; gap: 35px; }
.dashboard-preview { display: flex; align-items: end; gap: 10px; height: 130px; padding: 18px; background: rgba(111,85,245,.08); border: 1px solid rgba(111,85,245,.12); border-radius: 17px; }
.dashboard-preview span { flex: 1; min-height: 20px; background: linear-gradient(180deg, #9c8bff, var(--violet)); border-radius: 7px 7px 3px 3px; }

.projects-section { background: #fff; }
.project-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.project-card { position: relative; padding: 18px 18px 28px; background: #f7f8fb; border: 1px solid rgba(8,17,31,.09); border-radius: 25px; }
.project-card.featured-project { background: #f2efff; border-color: rgba(111,85,245,.22); box-shadow: 0 22px 54px rgba(111,85,245,.12); }
.project-label { position: absolute; z-index: 4; top: 30px; right: 30px; padding: 7px 10px; color: #fff; background: var(--violet); border-radius: 999px; font-size: .61rem; font-weight: 800; }
.project-visual { display: flex; align-items: center; justify-content: center; height: 210px; margin-bottom: 24px; background: #e9ecf4; border-radius: 18px; overflow: hidden; }
.quote-flow { gap: 23px; background: linear-gradient(145deg, #eef0f7, #e3e6ef); }
.quote-flow span { position: relative; display: grid; place-items: center; width: 58px; height: 58px; color: var(--violet); background: #fff; border-radius: 17px; box-shadow: 0 12px 26px rgba(8,17,31,.11); }
.quote-flow span:not(:last-child)::after { content: ""; position: absolute; left: calc(100% + 5px); width: 15px; height: 2px; background: #9ca6b9; }
.portal-flow { gap: 8px; padding: 25px; background: linear-gradient(145deg, #201d3e, #10182b); }
.portal-flow > div { display: grid; place-items: center; gap: 9px; width: 31%; min-height: 118px; color: #fff; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 15px; }
.portal-flow i { color: var(--violet-2); font-size: 1.2rem; }
.portal-flow small { color: rgba(255,255,255,.56); font-size: .63rem; }
.report-flow { gap: 26px; padding: 26px; background: linear-gradient(145deg, #edf8f5, #e7f1fb); }
.report-ring { display: grid; place-items: center; width: 105px; height: 105px; background: conic-gradient(var(--violet) 68%, rgba(111,85,245,.12) 0); border-radius: 50%; }
.report-ring::before { content: ""; position: absolute; width: 75px; height: 75px; background: #edf6f5; border-radius: 50%; }
.report-ring span { position: relative; z-index: 2; font-family: "Manrope", sans-serif; font-size: 1rem; font-weight: 800; }
.report-lines { display: grid; gap: 12px; width: 43%; }
.report-lines i { display: block; height: 9px; background: rgba(111,85,245,.42); border-radius: 99px; }
.project-meta { display: flex; align-items: center; justify-content: space-between; gap: 15px; margin-bottom: 16px; }
.project-meta span { color: var(--muted); font-size: .73rem; font-weight: 700; }
.project-meta strong { color: var(--violet); font-family: "Manrope", sans-serif; font-size: .88rem; }
.project-card h3 { margin-bottom: 13px; color: var(--ink); }
.project-card > p { color: var(--muted); font-size: .9rem; }
.project-card > ul { display: grid; gap: 8px; margin: 21px 0 0; padding: 18px 0 0; border-top: 1px solid rgba(8,17,31,.09); list-style: none; }
.project-card > ul li { display: flex; align-items: center; gap: 9px; color: #505c70; font-size: .8rem; }
.project-card > ul li::before { content: "\f00c"; color: #36a47d; font: var(--fa-font-solid); font-size: .68rem; }

.pricing-section { color: #fff; background: radial-gradient(circle at 15% 8%, rgba(111,85,245,.21), transparent 25%), #08111f; }
.pricing-intro { max-width: 840px; margin-bottom: 56px; }
.pricing-intro h2 { margin-bottom: 22px; }
.pricing-intro p { max-width: 720px; color: rgba(255,255,255,.59); font-size: 1.03rem; }
.pricing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.price-card { position: relative; display: flex; flex-direction: column; min-height: 610px; padding: 27px 24px 24px; color: var(--text); background: #fff; border: 1px solid rgba(255,255,255,.12); border-radius: 23px; overflow: hidden; }
.price-card.recommended { background: linear-gradient(180deg, #f3efff, #fff 44%); border-color: rgba(170,156,255,.7); box-shadow: 0 25px 70px rgba(111,85,245,.23); transform: translateY(-12px); }
.recommended-label { position: absolute; top: 0; right: 0; left: 0; padding: 8px; color: #fff; background: var(--violet); text-align: center; font-size: .66rem; font-weight: 800; letter-spacing: .03em; }
.price-card.recommended .price-card-head { margin-top: 20px; }
.price-card-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 28px; }
.price-icon { display: grid; place-items: center; width: 46px; height: 46px; color: var(--violet); background: #eeeaff; border-radius: 14px; }
.price-time { color: var(--muted); font-size: .64rem; font-weight: 750; }
.price-card h3 { margin-bottom: 11px; color: var(--ink); font-size: 1.35rem; }
.price-card > p { min-height: 78px; margin-bottom: 24px; color: var(--muted); font-size: .83rem; }
.price { display: grid; padding-bottom: 23px; border-bottom: 1px solid var(--line); }
.price small { color: var(--muted); font-size: .66rem; font-weight: 700; }
.price strong { margin-top: 4px; color: var(--ink); font-family: "Manrope", sans-serif; font-size: 2.15rem; letter-spacing: -.05em; }
.price-card > ul { display: grid; gap: 10px; margin: 23px 0 27px; padding: 0; list-style: none; }
.price-card > ul li { display: flex; gap: 9px; color: #4e596d; font-size: .76rem; }
.price-card > ul li::before { content: "\f00c"; margin-top: 4px; color: #2d9c74; font: var(--fa-font-solid); font-size: .64rem; }
.btn-price { width: 100%; min-height: 46px; margin-top: auto; padding-inline: 13px; font-size: .76rem; }
.pricing-foot { display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: 50px; margin-top: 35px; padding: 26px 28px; background: rgba(255,255,255,.055); border: 1px solid rgba(255,255,255,.1); border-radius: 20px; }
.pricing-foot > div { display: grid; grid-template-columns: 45px 1fr; align-items: center; gap: 13px; }
.pricing-foot > div > i { display: grid; place-items: center; width: 44px; height: 44px; color: var(--mint); background: rgba(116,235,189,.1); border-radius: 13px; }
.pricing-foot span { display: grid; line-height: 1.35; }
.pricing-foot strong { font-family: "Manrope", sans-serif; font-size: .88rem; }
.pricing-foot small { margin-top: 4px; color: rgba(255,255,255,.48); font-size: .68rem; }
.pricing-foot > p { margin: 0; color: rgba(255,255,255,.52); font-size: .78rem; }

.estimator-section { background: linear-gradient(145deg, #eef0ff, #f7f8fb 65%); }
.estimator-grid { display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: clamp(55px, 8vw, 115px); }
.estimator-copy h2 { margin-bottom: 22px; color: var(--ink); }
.estimator-copy > p { max-width: 540px; color: var(--muted); }
.estimator-points { display: grid; gap: 18px; margin-top: 32px; }
.estimator-points > div { display: grid; grid-template-columns: 24px 1fr; gap: 11px; }
.estimator-points > div > i { margin-top: 4px; color: #36a47d; }
.estimator-points span { display: grid; }
.estimator-points strong { font-family: "Manrope", sans-serif; font-size: .86rem; }
.estimator-points small { margin-top: 4px; color: var(--muted); font-size: .77rem; }
.estimator-card { padding: clamp(28px, 4vw, 45px); background: #fff; border: 1px solid rgba(8,17,31,.09); border-radius: 28px; box-shadow: 0 25px 70px rgba(8,17,31,.13); }
.estimator-fields { display: grid; grid-template-columns: 1.15fr 1fr 1fr; gap: 12px; }
.estimator-fields label { display: grid; gap: 8px; }
.estimator-fields label > span { color: #4a5568; font-size: .7rem; font-weight: 800; }
.estimator-fields select { width: 100%; min-height: 50px; padding: 0 12px; color: var(--text); background: #f6f7fa; border: 1px solid rgba(8,17,31,.12); border-radius: 12px; outline: none; }
.estimator-fields select:focus { border-color: var(--violet); box-shadow: 0 0 0 4px rgba(111,85,245,.1); }
.estimate-result { margin: 25px 0 18px; padding: 25px; color: #fff; background: linear-gradient(145deg, #131f35, #08111f); border-radius: 20px; }
.estimate-result > span { color: rgba(255,255,255,.49); font-size: .7rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; }
.estimate-result > strong { display: block; margin: 6px 0 17px; font-family: "Manrope", sans-serif; font-size: clamp(2rem, 4vw, 3.25rem); letter-spacing: -.055em; }
.estimate-result > div { display: flex; flex-wrap: wrap; gap: 9px; }
.estimate-result > div span { display: inline-flex; align-items: center; gap: 7px; padding: 7px 9px; color: rgba(255,255,255,.67); background: rgba(255,255,255,.06); border-radius: 999px; font-size: .65rem; }
.estimate-result > div i { color: var(--violet-2); }
.estimate-use { width: 100%; border: 0; }
.estimator-note { margin: 14px 0 0; color: var(--muted); font-size: .67rem; text-align: center; }

.process-section { background: #fff; }
.process-track { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.process-track::before { content: ""; position: absolute; top: 59px; right: 10%; left: 10%; height: 1px; background: linear-gradient(90deg, transparent, rgba(111,85,245,.45), transparent); }
.process-track article { position: relative; z-index: 2; min-height: 340px; padding: 27px; background: #f7f8fb; border: 1px solid rgba(8,17,31,.08); border-radius: 21px; }
.process-no { position: absolute; top: 22px; right: 24px; color: #c1c7d1; font-family: "Manrope", sans-serif; font-size: .68rem; font-weight: 800; }
.process-icon { display: grid; place-items: center; width: 62px; height: 62px; margin-bottom: 38px; color: var(--violet); background: #eeeaff; border: 8px solid #f7f8fb; border-radius: 19px; box-shadow: 0 0 0 1px rgba(111,85,245,.12); }
.process-track h3 { margin-bottom: 14px; color: var(--ink); font-size: 1.27rem; }
.process-track p { color: var(--muted); font-size: .86rem; }
.process-track small { display: block; margin-top: 23px; padding-top: 17px; color: #586579; border-top: 1px solid rgba(8,17,31,.08); font-size: .68rem; font-weight: 750; }
.commercial-panel { display: grid; grid-template-columns: .65fr 1.35fr; align-items: center; gap: 55px; margin-top: 20px; padding: clamp(30px, 5vw, 50px); color: #fff; background: linear-gradient(145deg, #17253a, #091321); border-radius: 26px; }
.commercial-panel h3 { margin: 0; font-size: clamp(1.6rem, 3vw, 2.45rem); }
.commercial-list { display: grid; grid-template-columns: 1fr 1fr; gap: 13px 20px; }
.commercial-list p { display: flex; align-items: flex-start; gap: 10px; margin: 0; color: rgba(255,255,255,.66); font-size: .8rem; }
.commercial-list i { margin-top: 5px; color: var(--mint); font-size: .68rem; }

.delivery-section { background: var(--cream); }
.delivery-grid { display: grid; grid-template-columns: .95fr 1.05fr; align-items: center; gap: clamp(55px, 8vw, 110px); }
.delivery-image { position: relative; }
.delivery-image img { width: 100%; height: 650px; object-fit: cover; border-radius: 28px 28px 110px 28px; box-shadow: var(--shadow-md); }
.delivery-badge { position: absolute; right: -25px; bottom: 35px; display: grid; grid-template-columns: 44px 1fr; align-items: center; gap: 12px; min-width: 280px; padding: 16px; color: #fff; background: rgba(8,17,31,.94); border: 1px solid rgba(255,255,255,.12); border-radius: 17px; box-shadow: 0 20px 55px rgba(0,0,0,.25); }
.delivery-badge > i { display: grid; place-items: center; width: 42px; height: 42px; color: var(--violet-2); background: rgba(111,85,245,.16); border-radius: 12px; }
.delivery-badge span { display: grid; }
.delivery-badge strong { font-family: "Manrope", sans-serif; font-size: .78rem; }
.delivery-badge small { margin-top: 4px; color: rgba(255,255,255,.47); font-size: .64rem; }
.delivery-copy h2 { margin-bottom: 22px; color: var(--ink); }
.delivery-copy > p { max-width: 630px; color: var(--muted); }
.included-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; margin-top: 32px; }
.included-grid > div { display: grid; grid-template-columns: 42px 1fr; gap: 11px; padding: 15px; background: #fff; border: 1px solid rgba(8,17,31,.08); border-radius: 15px; }
.included-grid > div > i { display: grid; place-items: center; width: 40px; height: 40px; color: var(--violet); background: #eeeaff; border-radius: 12px; }
.included-grid span { display: grid; }
.included-grid strong { font-family: "Manrope", sans-serif; font-size: .76rem; }
.included-grid small { margin-top: 4px; color: var(--muted); font-size: .66rem; }

.company-panel-v2 { overflow: hidden; }
.company-badges { display: flex; flex-wrap: wrap; gap: 8px; margin: 25px 0; }
.company-badges span { display: inline-flex; align-items: center; gap: 8px; padding: 8px 10px; color: rgba(255,255,255,.71); background: rgba(255,255,255,.055); border: 1px solid rgba(255,255,255,.1); border-radius: 999px; font-size: .68rem; font-weight: 700; }
.company-badges i { color: var(--mint); }
.faq-cta { margin-top: 20px; }

.contact-section-v2 { background: radial-gradient(circle at 14% 10%, rgba(111,85,245,.2), transparent 25%), #08111f; }
.response-note { display: grid; grid-template-columns: 46px 1fr; gap: 13px; max-width: 480px; margin-top: 31px; padding: 17px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09); border-radius: 16px; }
.response-note > i { display: grid; place-items: center; width: 44px; height: 44px; color: var(--mint); background: rgba(116,235,189,.1); border-radius: 13px; }
.response-note span { display: grid; }
.response-note strong { font-family: "Manrope", sans-serif; font-size: .8rem; }
.response-note small { margin-top: 4px; color: rgba(255,255,255,.48); font-size: .68rem; }
.contact-section-v2 .contact-card { margin-top: 14px; }
.contact-form-v2 { border: 1px solid rgba(255,255,255,.4); }

.footer-main { display: grid; grid-template-columns: 1.5fr .7fr .7fr .85fr; gap: 60px; padding: 60px 0 48px; border-bottom: 1px solid var(--line-dark); }
.footer-about p { max-width: 340px; margin: 22px 0 0; color: rgba(255,255,255,.48); font-size: .82rem; }
.footer-column { display: grid; align-content: start; gap: 10px; }
.footer-column strong, .footer-company > strong { margin-bottom: 7px; color: #fff; font-family: "Manrope", sans-serif; font-size: .77rem; }
.footer-column a { color: rgba(255,255,255,.5); font-size: .76rem; }
.footer-column a:hover { color: #fff; }
.footer-company p { margin: 0 0 13px; color: rgba(255,255,255,.5); font-size: .76rem; line-height: 1.7; }
.footer-company span { color: rgba(255,255,255,.38); font-size: .68rem; }

@media (max-width: 1180px) {
  .nav-links { gap: 15px; }
  .nav-links a { font-size: .8rem; }
  .pricing-grid { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .price-card { min-height: 560px; }
  .price-card.recommended { transform: none; }
}

@media (max-width: 1080px) {
  .hero-grid-v2 { grid-template-columns: 1fr; min-height: auto; }
  .hero-product { width: min(880px, 100%); min-height: 620px; }
  .product-window { right: 2%; left: 2%; }
  .problem-grid, .project-cards { grid-template-columns: 1fr 1fr; }
  .problem-grid article:last-child, .project-card:last-child { grid-column: span 2; }
  .service-bento { grid-template-columns: 1fr 1fr; }
  .service-bento-card.large { grid-row: auto; min-height: 430px; }
  .service-bento-card.wide { grid-column: span 2; }
  .estimator-grid, .delivery-grid { grid-template-columns: 1fr; }
  .estimator-copy { max-width: 780px; }
  .process-track { grid-template-columns: 1fr 1fr; }
  .process-track::before { display: none; }
  .commercial-panel { grid-template-columns: 1fr; }
  .delivery-image { width: min(820px, 100%); }
  .footer-main { grid-template-columns: 1.3fr 1fr 1fr; }
  .footer-company { grid-column: span 3; padding-top: 25px; border-top: 1px solid var(--line-dark); }
}

@media (max-width: 760px) {
  .hero-v2 h1 { font-size: clamp(2.85rem, 13vw, 4.6rem); }
  .hero-proof { grid-template-columns: 1fr; }
  .hero-product { min-height: 535px; }
  .product-window { inset: 18px 0 14px; transform: none; border-radius: 23px; }
  .product-layout { grid-template-columns: 48px 1fr; min-height: 440px; }
  .product-sidebar { gap: 7px; padding-top: 16px; }
  .product-sidebar span { width: 32px; height: 32px; }
  .product-main { padding: 15px; }
  .product-heading { margin-bottom: 12px; }
  .product-heading strong { font-size: 1.03rem; }
  .product-metrics { grid-template-columns: 1fr 1fr; }
  .product-metrics article:nth-child(3) { display: none; }
  .product-columns { grid-template-columns: 1fr; }
  .activity-panel { display: none; }
  .float-note-two { display: none; }
  .float-note-one { right: -8px; bottom: 0; }
  .problem-grid, .project-cards { grid-template-columns: 1fr; }
  .problem-grid article:last-child, .project-card:last-child { grid-column: auto; }
  .service-bento { grid-template-columns: 1fr; }
  .service-bento-card.wide { grid-column: auto; }
  .wide-copy { grid-template-columns: 1fr; }
  .dashboard-preview { height: 110px; }
  .pricing-grid { grid-template-columns: 1fr; }
  .price-card { min-height: auto; }
  .price-card > p { min-height: auto; }
  .pricing-foot { grid-template-columns: 1fr; gap: 20px; }
  .estimator-fields { grid-template-columns: 1fr; }
  .process-track { grid-template-columns: 1fr; }
  .process-track article { min-height: auto; }
  .commercial-list, .included-grid { grid-template-columns: 1fr; }
  .delivery-image img { height: 500px; }
  .delivery-badge { right: -6px; bottom: 18px; min-width: 250px; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 35px; }
  .footer-about { grid-column: span 2; }
  .footer-company { grid-column: span 2; }
}

@media (max-width: 520px) {
  .hero-grid-v2 { padding-top: 55px; }
  .hero-kicker > span:last-child { display: none; }
  .hero-product { min-height: 500px; }
  .product-topbar { min-height: 62px; padding: 0 14px; }
  .product-layout { min-height: 412px; }
  .product-heading button { display: none; }
  .product-metrics article { grid-template-columns: 31px 1fr; padding: 10px; }
  .metric-icon { width: 30px; height: 30px; }
  .workflow-panel { padding: 11px; }
  .workflow-line { min-height: 48px; }
  .workflow-line p small { display: none; }
  .float-note { min-width: 190px; }
  .problem-grid article, .service-bento-card { padding: 24px; }
  .project-visual { height: 185px; }
  .pricing-intro { margin-bottom: 38px; }
  .price-card { padding: 24px 20px; }
  .estimate-result { padding: 21px 18px; }
  .estimate-result > strong { font-size: 2rem; }
  .commercial-panel { padding: 27px 22px; }
  .delivery-image img { height: 420px; border-radius: 24px 24px 75px 24px; }
  .delivery-badge { position: relative; right: auto; bottom: auto; min-width: 0; margin: -45px 14px 0; }
  .footer-main { grid-template-columns: 1fr; }
  .footer-about, .footer-company { grid-column: auto; }
}
