/* ================================================================
   Homepage — Professional Vivid variant
   Source: /final/index.html
   ================================================================ */

/* Hero */
.hero{padding:80px 0 100px;position:relative;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1fr 460px;gap:80px;align-items:end}
.eye{font-family:var(--fm);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);display:inline-flex;align-items:center;gap:10px;margin-bottom:32px}
.eye::before{content:'';width:28px;height:1px;background:var(--accent)}
.hero h1{font-family:var(--fs);font-weight:400;font-size:clamp(52px,7vw,104px);line-height:1.02;letter-spacing:-.025em;margin:0 0 28px;max-width:14ch}
.hero h1 em{font-style:italic;color:var(--pop-1);font-weight:500;background:linear-gradient(120deg,var(--pop-1) 0%,var(--pop-5) 50%,var(--pop-4) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-lead{font-size:19px;line-height:1.55;color:var(--ink-2);max-width:48ch;margin:0 0 36px}
.hero-act{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:48px}
.hero-trust{display:flex;gap:32px;padding-top:28px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-trust .t{display:flex;flex-direction:column;gap:4px}
.hero-trust .t .n{font-family:var(--fs);font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1}
.hero-trust .t:nth-child(1) .n{color:var(--pop-1)}
.hero-trust .t:nth-child(2) .n{color:var(--pop-3)}
.hero-trust .t:nth-child(3) .n{color:var(--pop-4)}
.hero-trust .t:nth-child(4) .n{color:var(--pop-2)}
.hero-trust .t .l{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}

/* Quote card */
.qcard{background:var(--paper);border:1px solid var(--line);padding:32px;border-radius:6px;box-shadow:0 40px 80px -50px rgba(0,0,0,.2)}
.qcard-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}
.qcard h3{font-family:var(--fs);font-weight:500;font-size:22px;margin:0 0 4px;letter-spacing:-.01em}
.qcard p.sub{color:var(--muted);font-size:13px;margin:0}
.qcard .badge{font-family:var(--fm);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:4px 8px;background:var(--bg);border:1px solid var(--line);border-radius:3px}
.qcard .field{margin-bottom:14px}
.qcard label{display:block;font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.qcard input,.qcard select,.qcard textarea{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:3px;background:var(--bg);font:inherit;font-size:14px;transition:border .15s,background .15s}
.qcard input:focus,.qcard select:focus,.qcard textarea:focus{outline:none;border-color:var(--pop-1);background:#fff;box-shadow:0 0 0 3px rgba(255,77,31,.12)}
.qcard .row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.qcard .btn-p{width:100%;justify-content:center;margin-top:8px}
.qcard .foot{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--line);font-size:12px;color:var(--muted);font-family:var(--fm)}
@media(max-width:1000px){.hero-grid{grid-template-columns:1fr;gap:48px}}

/* Logo row */
.logos{padding:48px 0;border-bottom:1px solid var(--line);background:var(--paper)}
.logos-in{display:flex;justify-content:space-between;align-items:center;gap:40px;flex-wrap:wrap}
.logos-lab{font-family:var(--fm);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);min-width:200px}
.logos-set{display:flex;gap:48px;align-items:center;flex-wrap:wrap;flex:1;justify-content:space-around}
.logos-set span{font-family:var(--fs);font-style:italic;font-size:22px;opacity:.5;transition:opacity .2s;color:var(--ink)}
.logos-set span:hover{opacity:1;color:var(--pop-1)}
.logos-set span:nth-child(3n):hover{color:var(--pop-4)}
.logos-set span:nth-child(3n+1):hover{color:var(--pop-3)}

/* Capabilities */
.caps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:6px;overflow:hidden;background:var(--paper)}
.cap{padding:40px 36px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-direction:column;min-height:320px;transition:background .25s;cursor:pointer;position:relative}
.cap:nth-child(3n){border-right:none}
.cap:nth-last-child(-n+3){border-bottom:none}
.cap:hover{background:var(--bg)}
.cap:nth-child(1){border-top:3px solid var(--pop-1)}.cap:nth-child(2){border-top:3px solid var(--pop-2)}.cap:nth-child(3){border-top:3px solid var(--pop-3)}.cap:nth-child(4){border-top:3px solid var(--pop-4)}.cap:nth-child(5){border-top:3px solid var(--pop-5)}.cap:nth-child(6){border-top:3px solid var(--pop-1)}
.cap:nth-child(1) .cap-arr{color:var(--pop-1)}.cap:nth-child(2) .cap-arr{color:var(--pop-2)}.cap:nth-child(3) .cap-arr{color:var(--pop-3)}.cap:nth-child(4) .cap-arr{color:var(--pop-4)}.cap:nth-child(5) .cap-arr{color:var(--pop-5)}.cap:nth-child(6) .cap-arr{color:var(--pop-1)}
.cap-n{font-family:var(--fm);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-bottom:28px;display:flex;justify-content:space-between}
.cap-arr{color:var(--accent);transition:transform .2s}
.cap:hover .cap-arr{transform:translate(4px,-4px)}
.cap h3{font-family:var(--fs);font-weight:500;font-size:28px;letter-spacing:-.015em;line-height:1.1;margin:0 0 12px}
.cap p{color:var(--muted);font-size:15px;margin:0 0 24px;flex:1}
.cap ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.cap ul li{font-family:var(--fm);font-size:11px;padding:4px 10px;background:var(--bg);border:1px solid var(--line);border-radius:3px;color:var(--ink-2)}
.cap:hover ul li{background:var(--paper)}
@media(max-width:900px){.caps{grid-template-columns:1fr 1fr}.cap,.cap:nth-child(3n){border-right:1px solid var(--line)}.cap:nth-child(even){border-right:none}}
@media(max-width:600px){.caps{grid-template-columns:1fr}.cap{border-right:none!important}}

/* Case studies */
.cases{display:flex;flex-direction:column;gap:0}
.case{display:grid;grid-template-columns:120px 1fr 1.3fr 180px;gap:40px;padding:36px 0;border-top:1px solid var(--line);align-items:center;transition:padding .35s;cursor:pointer;position:relative;text-decoration:none;color:inherit}
.case:last-child{border-bottom:1px solid var(--line)}
.case:hover{padding-left:20px;background:linear-gradient(to right,var(--paper),transparent 80%)}
.case-n{font-family:var(--fm);font-size:12px;color:var(--muted);letter-spacing:.1em}
.case-name{font-family:var(--fs);font-weight:500;font-size:30px;letter-spacing:-.015em;margin:0 0 4px;line-height:1.1}
.case-sec{font-family:var(--fm);font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.case-result{font-size:15px;color:var(--ink-2);margin:0;max-width:42ch}
.case-result strong{color:var(--pop-1);font-weight:700;background:linear-gradient(120deg,var(--pop-1),var(--pop-5));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.case-meta{display:flex;justify-content:flex-end;align-items:center;gap:10px;font-family:var(--fm);font-size:11px;color:var(--muted)}
.case-meta .arr{width:40px;height:40px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;color:var(--ink);transition:all .25s}
.case:hover .case-meta .arr{background:linear-gradient(135deg,var(--pop-1),var(--pop-5));color:#fff;border-color:transparent;transform:rotate(-45deg)}
@media(max-width:900px){.case{grid-template-columns:1fr;gap:14px}.case-meta{justify-content:flex-start}}

/* Industries */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ind{padding:28px 24px;background:var(--paper);border:1px solid var(--line);border-radius:6px;display:flex;flex-direction:column;gap:12px;min-height:180px;transition:all .25s;cursor:pointer;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.ind:hover{background:var(--ink);color:var(--bg);border-color:var(--ink);transform:translateY(-4px);box-shadow:0 16px 32px -16px rgba(0,0,0,.25)}
.ind:nth-child(1):hover{background:var(--pop-1);border-color:var(--pop-1)}.ind:nth-child(2):hover{background:var(--pop-4);border-color:var(--pop-4)}.ind:nth-child(3):hover{background:var(--pop-3);border-color:var(--pop-3)}.ind:nth-child(4):hover{background:var(--pop-5);border-color:var(--pop-5)}.ind:nth-child(5):hover{background:var(--pop-2);border-color:var(--pop-2);color:var(--ink)}.ind:nth-child(6):hover{background:var(--pop-1);border-color:var(--pop-1)}.ind:nth-child(7):hover{background:var(--pop-4);border-color:var(--pop-4)}.ind:nth-child(8):hover{background:var(--pop-3);border-color:var(--pop-3)}
.ind-n{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.ind h4{font-family:var(--fs);font-weight:500;font-size:22px;line-height:1.1;letter-spacing:-.01em;margin:0}
.ind-c{margin-top:auto;font-family:var(--fm);font-size:12px;opacity:.7}
.ind-arr{position:absolute;top:20px;right:20px;opacity:.3;transition:all .2s}
.ind:hover .ind-arr{opacity:1;color:var(--accent-2)}
@media(max-width:900px){.ind-grid{grid-template-columns:1fr 1fr}}

/* Why / differentiators */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;border-top:1px solid var(--line);padding-top:72px}
.why-c{display:flex;flex-direction:column;gap:16px}
.why-c .wn{font-family:var(--fs);font-style:italic;font-weight:400;font-size:64px;line-height:.9;letter-spacing:-.04em;background:linear-gradient(135deg,var(--pop-1),var(--pop-5));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.why-c:nth-child(2) .wn{background:linear-gradient(135deg,var(--pop-3),var(--pop-4));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.why-c:nth-child(3) .wn{background:linear-gradient(135deg,var(--pop-2),var(--pop-1));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.why-c h4{font-family:var(--fs);font-weight:500;font-size:24px;margin:0;letter-spacing:-.01em}
.why-c p{color:var(--muted);font-size:15px;margin:0;max-width:40ch}
@media(max-width:900px){.why{grid-template-columns:1fr}}

/* Process timeline */
.proc{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative}
.proc::before{content:'';position:absolute;top:28px;left:4%;right:4%;height:1px;background:var(--line-2)}
.proc-s{display:flex;flex-direction:column;align-items:flex-start;gap:16px;padding-right:24px;position:relative}
.proc-d{width:14px;height:14px;border-radius:50%;background:var(--bg);border:1px solid var(--line-2);position:relative;z-index:1;margin-top:22px}
.proc-s:nth-child(1) .proc-d{background:var(--pop-1);border-color:var(--pop-1);box-shadow:0 0 0 6px rgba(255,77,31,.15)}
.proc-s:nth-child(2) .proc-d{background:var(--pop-2);border-color:var(--pop-2)}
.proc-s:nth-child(3) .proc-d{background:var(--pop-3);border-color:var(--pop-3)}
.proc-s:nth-child(4) .proc-d{background:var(--pop-4);border-color:var(--pop-4)}
.proc-s:nth-child(5) .proc-d{background:var(--pop-5);border-color:var(--pop-5);box-shadow:0 0 0 6px rgba(232,62,140,.15)}
.proc-n{font-family:var(--fm);font-size:11px;color:var(--muted);letter-spacing:.1em}
.proc h5{font-family:var(--fs);font-weight:500;font-size:20px;letter-spacing:-.01em;margin:0}
.proc p{font-size:14px;color:var(--muted);margin:0}
@media(max-width:900px){.proc{grid-template-columns:1fr;gap:20px}.proc::before{display:none}}

/* Testimonials */
.testy{display:grid;grid-template-columns:1.4fr 1fr;gap:32px}
.ty-main{background:var(--paper);padding:56px;border:1px solid var(--line);border-radius:6px;display:flex;flex-direction:column;gap:32px}
.ty-quote{font-family:var(--fs);font-weight:400;font-style:italic;font-size:32px;line-height:1.3;letter-spacing:-.015em;margin:0}
.ty-quote::before{content:'\201C';font-family:var(--fs);font-size:3em;line-height:0;color:var(--pop-1);margin-right:4px;vertical-align:-.3em}
.ty-author{display:flex;align-items:center;gap:16px;padding-top:24px;border-top:1px solid var(--line)}
.ty-av{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--pop-1),var(--pop-5));color:#fff;display:grid;place-items:center;font-weight:600;font-size:15px;flex-shrink:0}
.ty-nm{font-weight:600;font-size:15px}
.ty-rl{font-family:var(--fm);font-size:12px;color:var(--muted)}
.ty-side{display:grid;gap:16px}
.ty-small{background:var(--paper);padding:24px;border:1px solid var(--line);border-radius:6px}
.ty-small .q{font-family:var(--fs);font-size:16px;line-height:1.45;margin:0 0 16px;font-style:italic}
.ty-small .by{font-family:var(--fm);font-size:12px;color:var(--muted)}
.ty-stars{color:var(--pop-2);letter-spacing:2px;font-size:14px}
@media(max-width:900px){.testy{grid-template-columns:1fr}}

/* Awards */
.awards{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border:1px solid var(--line);border-radius:6px;background:var(--paper);overflow:hidden}
.aw{padding:32px 20px;border-right:1px solid var(--line);display:flex;flex-direction:column;justify-content:space-between;min-height:180px;transition:background .2s;cursor:pointer}
.aw:last-child{border-right:none}
.aw:hover{background:var(--bg)}
.aw-bg{width:42px;height:42px;border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;font-family:var(--fs);font-style:italic;font-weight:500;font-size:16px}
.aw-y{font-family:var(--fm);font-size:11px;color:var(--muted);letter-spacing:.1em}
.aw h5{font-family:var(--fs);font-weight:500;font-size:16px;line-height:1.2;letter-spacing:-.01em;margin:6px 0 0}
@media(max-width:900px){.awards{grid-template-columns:repeat(2,1fr)}.aw{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}.aw:nth-child(even){border-right:none}}

/* CTA banner */
.cta-wrap{padding:120px 0}
.cta{background:var(--ink);color:#fff;border-radius:8px;padding:80px;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:-150px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,77,31,.35),transparent 60%);pointer-events:none}
.cta::after{content:'';position:absolute;bottom:-180px;left:-120px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(61,91,255,.3),transparent 60%);pointer-events:none}
.cta-grid{position:relative;display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:end}
.cta h2{font-family:var(--fs);font-weight:400;font-size:clamp(44px,6vw,84px);line-height:1.02;letter-spacing:-.025em;margin:0;max-width:14ch}
.cta h2 em{font-style:italic;background:linear-gradient(120deg,var(--pop-2),var(--pop-1),var(--pop-5));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.cta-info{display:grid;gap:20px}
.cta-info .r{display:flex;gap:16px;align-items:flex-start;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.15)}
.cta-info .r:last-child{border-bottom:none}
.cta-info .r .lb{font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);min-width:100px}
.cta-info .r .v{font-family:var(--fs);font-size:20px;font-weight:400}
.cta-foot{margin-top:56px;padding-top:32px;border-top:1px solid rgba(255,255,255,.15);display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;position:relative}
.cta .btn-p{background:linear-gradient(135deg,var(--pop-1),var(--pop-2));color:#fff;box-shadow:0 8px 24px -8px rgba(255,77,31,.6)}
.cta .btn-p:hover{background:linear-gradient(135deg,var(--pop-5),var(--pop-4));transform:translateY(-2px)}
.cta .btn-g{border-color:rgba(255,255,255,.25);color:#fff}
.cta .btn-g:hover{background:#fff;color:var(--ink)}
@media(max-width:900px){.cta{padding:48px}.cta-grid{grid-template-columns:1fr}}
