/* ── DEVVISTA SERVICE PAGES CSS ── */
/* Shared across all /services/<slug>/ pages */

/* ─── SHARED UTILITIES ─── */
.section-label{display:inline-flex;align-items:center;gap:0.6rem;font-size:0.67rem;font-weight:800;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);margin-bottom:1.25rem;}
.section-label::before{content:'';width:22px;height:2px;background:var(--accent);flex-shrink:0;}
.section-label.light{color:rgba(255,255,255,0.65);}
.section-label.light::before{background:rgba(255,255,255,0.4);}
.section-label.dark-label{color:var(--accent);}
.section-heading{font-size:clamp(1.9rem,3.5vw,2.9rem);font-weight:900;color:var(--white);line-height:1.05;letter-spacing:-1px;margin-bottom:1rem;}
.section-heading.on-cream{color:var(--dark);}
.section-sub{color:var(--muted);font-size:0.95rem;line-height:1.85;}
.section-sub.on-cream{color:rgba(14,16,15,0.55);}
.text-accent{color:var(--accent);}
.text-stroke{-webkit-text-stroke:2px var(--white);color:transparent;}
.text-stroke-accent{-webkit-text-stroke:2px var(--accent);color:transparent;}

/* ─── BUTTONS ─── */
.btn-primary-custom{background:var(--cream);color:var(--dark);font-weight:800;font-size:0.82rem;padding:0.9rem 2rem;border-radius:6px;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:0.55rem;letter-spacing:0.03em;transition:all 0.22s;}
.btn-primary-custom:hover{background:var(--accent);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,58,26,0.35);}
.btn-outline-custom{background:transparent;color:var(--cream);font-weight:700;font-size:0.82rem;padding:0.9rem 2rem;border-radius:6px;border:1.5px solid rgba(245,230,211,0.22);text-decoration:none;display:inline-flex;align-items:center;gap:0.55rem;transition:all 0.22s;}
.btn-outline-custom:hover{border-color:var(--cream);color:var(--white);background:rgba(245,230,211,0.05);}
.btn-accent-sharp{background:var(--accent);color:var(--white);font-weight:800;font-size:0.82rem;padding:0.9rem 2rem;border-radius:6px;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:0.55rem;letter-spacing:0.03em;transition:all 0.22s;}
.btn-accent-sharp:hover{background:var(--accent-h);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,58,26,0.4);}
.btn-white-sharp{background:var(--white);color:var(--accent);font-weight:800;font-size:0.875rem;padding:1rem 2.4rem;border-radius:6px;border:none;text-decoration:none;display:inline-flex;align-items:center;gap:0.55rem;transition:all 0.22s;letter-spacing:0.02em;}
.btn-white-sharp:hover{background:var(--cream);color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,0.2);}
.btn-ghost-white{background:transparent;color:var(--white);font-weight:700;font-size:0.875rem;padding:1rem 2.4rem;border-radius:6px;border:1.5px solid rgba(255,255,255,0.35);text-decoration:none;display:inline-flex;align-items:center;gap:0.55rem;transition:all 0.22s;}
.btn-ghost-white:hover{border-color:var(--white);background:rgba(255,255,255,0.08);}

/* ─── BREADCRUMB ─── */
.breadcrumb-bar{background:var(--dark-2);border-bottom:1px solid var(--border);padding:0.65rem 0;}
.breadcrumb{margin:0;font-size:0.77rem;}
.breadcrumb-item a{color:var(--muted);text-decoration:none;transition:color 0.2s;}
.breadcrumb-item a:hover{color:var(--cream);}
.breadcrumb-item.active{color:var(--accent);}
.breadcrumb-item+.breadcrumb-item::before{color:var(--muted);}

/* ─── 1. HERO ─── */
.hero{padding:6.5rem 0 5rem;background:var(--dark);position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent) 0%,transparent 60%);}
.hero-bg-text{position:absolute;right:-60px;top:50%;transform:translateY(-50%);font-size:38vw;font-weight:900;line-height:1;-webkit-text-stroke:1px rgba(245,230,211,0.025);color:transparent;pointer-events:none;user-select:none;}
.hero-eyebrow{display:inline-flex;align-items:center;gap:0.55rem;background:rgba(232,58,26,0.1);border:1px solid rgba(232,58,26,0.28);border-radius:4px;padding:0.35rem 0.9rem;font-size:0.69rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);margin-bottom:1.75rem;}
.hero h1{font-size:clamp(2.8rem,6vw,5.5rem);font-weight:900;color:var(--white);line-height:1.0;letter-spacing:-3px;margin-bottom:1.75rem;}
.hero h1 .h-accent{color:var(--accent);}
.hero h1 .h-stroke{-webkit-text-stroke:2px var(--white);color:transparent;}
.hero-body{color:var(--muted);font-size:1rem;max-width:520px;line-height:1.9;margin-bottom:0;}
.hero-cta{display:flex;gap:0.75rem;flex-wrap:wrap;margin-top:2.25rem;}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:3rem;border:1px solid var(--border);}
.stat-item{padding:1.25rem 1.5rem;border-right:1px solid var(--border);}
.stat-item:last-child{border-right:none;}
.stat-num{font-size:2rem;font-weight:900;color:var(--white);line-height:1;letter-spacing:-2px;display:block;}
.stat-label{font-size:0.65rem;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-top:0.3rem;display:block;font-weight:700;}
.hero-svg-wrap{position:relative;width:100%;max-width:500px;opacity:0;transform:translateY(20px);animation:fadeUp 0.85s ease 0.35s forwards;}
.hero-svg-wrap::before{content:'';position:absolute;top:-14px;right:-14px;width:44px;height:44px;border-top:2px solid var(--accent);border-right:2px solid var(--accent);}
.hero-svg-wrap::after{content:'';position:absolute;bottom:-14px;left:-14px;width:44px;height:44px;border-bottom:2px solid rgba(232,58,26,0.4);border-left:2px solid rgba(232,58,26,0.4);}
.hero-svg{width:100%;height:auto;filter:drop-shadow(0 28px 48px rgba(0,0,0,0.55));}
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}
.cursor-blink{animation:blink 1.1s step-end infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.badge-float{animation:bob 3.5s ease-in-out infinite;}
.badge-float-2{animation:bob 3.5s ease-in-out infinite 1.3s;}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ─── MARQUEE ─── */
.marquee-strip{background:var(--cream);padding:0.85rem 0;overflow:hidden;}
.marquee-track{display:flex;white-space:nowrap;animation:marqueeScroll 24s linear infinite;}
.marquee-track:hover{animation-play-state:paused;}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-item{display:inline-flex;align-items:center;gap:0.75rem;font-size:0.75rem;font-weight:800;letter-spacing:0.12em;text-transform:uppercase;color:var(--dark);padding:0 2.5rem;}
.marquee-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);}

/* ─── 2. INTRO ─── */
.intro-section{background:var(--dark-2);padding:6rem 0;position:relative;overflow:hidden;}
.intro-pull{font-size:clamp(1.3rem,2.5vw,1.9rem);font-weight:800;color:var(--white);line-height:1.35;letter-spacing:-0.5px;border-left:4px solid var(--accent);padding-left:1.75rem;margin-bottom:2rem;}
.intro-body{color:var(--muted);font-size:0.95rem;line-height:1.9;}
.intro-cta-inline{margin-top:2rem;padding:1.5rem 1.75rem;background:rgba(232,58,26,0.06);border:1px solid rgba(232,58,26,0.18);border-left:3px solid var(--accent);}
.intro-cta-inline p{color:var(--cream);font-size:0.9rem;margin:0 0 0.75rem;line-height:1.7;}
.intro-cta-inline a{color:var(--accent);font-weight:700;font-size:0.82rem;text-decoration:none;display:inline-flex;align-items:center;gap:0.4rem;transition:gap 0.2s;}
.intro-cta-inline a:hover{gap:0.7rem;}

/* ─── 3. SERVICES BENTO ─── */
.services-section{background:var(--dark);padding:6rem 0;}
.bento-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:10px;}
.b-8{grid-column:span 8;}.b-4{grid-column:span 4;}.b-6{grid-column:span 6;}.b-12{grid-column:span 12;}
.bento-card{padding:2.5rem;position:relative;overflow:hidden;transition:transform 0.3s cubic-bezier(0.34,1.3,0.64,1);}
.bento-card:hover{transform:scale(0.985);}
.bc-dark{background:var(--dark-3);border:1px solid var(--border);}
.bc-accent{background:var(--accent);}
.bc-cream{background:var(--cream);}
.bc-outline{background:transparent;border:1px solid rgba(232,58,26,0.28);}
.bento-icon{width:46px;height:46px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:1.25rem;transition:transform 0.3s;}
.bento-card:hover .bento-icon{transform:rotate(-8deg) scale(1.1);}
.bc-dark .bento-icon,.bc-outline .bento-icon{background:rgba(232,58,26,0.1);border:1px solid rgba(232,58,26,0.2);color:var(--accent);}
.bc-accent .bento-icon{background:rgba(0,0,0,0.18);border:1px solid rgba(255,255,255,0.2);color:var(--white);}
.bc-cream .bento-icon{background:rgba(232,58,26,0.1);border:1px solid rgba(232,58,26,0.18);color:var(--accent);}
.bento-num{font-size:0.63rem;font-weight:900;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:1.5rem;display:block;}
.bc-dark .bento-num,.bc-outline .bento-num{color:rgba(245,230,211,0.1);}
.bc-accent .bento-num{color:rgba(255,255,255,0.3);}
.bc-cream .bento-num{color:rgba(14,16,15,0.15);}
.bento-card h3{font-size:1.05rem;font-weight:800;letter-spacing:-0.2px;line-height:1.25;margin-bottom:0.65rem;}
.bc-dark h3,.bc-outline h3{color:var(--white);}
.bc-accent h3{color:var(--white);}
.bc-cream h3{color:var(--dark);}
.bento-card p{font-size:0.855rem;line-height:1.78;margin:0;}
.bc-dark p,.bc-outline p{color:var(--muted);}
.bc-accent p{color:rgba(255,255,255,0.75);}
.bc-cream p{color:rgba(14,16,15,0.6);}
.bento-ghost{position:absolute;bottom:-8px;right:-4px;font-size:4.5rem;font-weight:900;line-height:1;pointer-events:none;user-select:none;}
.bc-dark .bento-ghost,.bc-outline .bento-ghost{-webkit-text-stroke:1px rgba(245,230,211,0.05);color:transparent;}
.bc-accent .bento-ghost{-webkit-text-stroke:1px rgba(255,255,255,0.1);color:transparent;}
.bc-cream .bento-ghost{-webkit-text-stroke:1px rgba(14,16,15,0.07);color:transparent;}

/* ─── 4. PROCESS ─── */
.process-section{background:var(--accent);padding:6rem 0;position:relative;overflow:hidden;}
.process-section::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.045) 1px,transparent 1px);background-size:56px 56px;pointer-events:none;}
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid rgba(255,255,255,0.18);margin-top:3rem;}
.process-step{padding:2.5rem 2rem;border-right:1px solid rgba(255,255,255,0.18);position:relative;transition:background 0.3s;}
.process-step:hover{background:rgba(0,0,0,0.08);}
.process-step:last-child{border-right:none;}
.process-step:nth-child(n+4){border-top:1px solid rgba(255,255,255,0.18);}
.ps-num{font-size:3.5rem;font-weight:900;color:rgba(255,255,255,0.15);line-height:1;margin-bottom:0.75rem;letter-spacing:-2px;}
.ps-label{font-size:0.63rem;font-weight:800;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-bottom:0.5rem;}
.process-step h4{font-size:1rem;font-weight:800;color:var(--white);margin-bottom:0.6rem;letter-spacing:-0.2px;}
.process-step p{font-size:0.855rem;color:rgba(255,255,255,0.72);line-height:1.8;margin:0;}

/* ─── 5. TECH STACK ─── */
.tech-section{background:var(--cream);padding:6rem 0;}
.tech-section .section-label{color:var(--accent);}
.tech-section .section-label::before{background:var(--accent);}
.tech-tag{display:inline-flex;align-items:center;gap:0.4rem;background:rgba(14,16,15,0.06);border:1px solid rgba(14,16,15,0.14);color:var(--dark);font-size:0.8rem;font-weight:700;padding:0.5rem 1rem;border-radius:4px;margin:0.25rem;transition:all 0.2s;cursor:default;}
.tech-tag::before{content:'◆';font-size:0.35rem;color:var(--accent);transition:color 0.2s;}
.tech-tag:hover{background:var(--accent);color:var(--white);border-color:var(--accent);transform:translateY(-2px);}
.tech-tag:hover::before{color:rgba(255,255,255,0.6);}

/* ─── 6. INDUSTRIES ─── */
.industries-section{background:var(--dark-2);padding:6rem 0;}
.industry-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);}
.industry-item{background:var(--dark-2);padding:1.75rem 2rem;display:flex;align-items:center;gap:1.1rem;transition:background 0.25s,transform 0.2s;cursor:pointer;text-decoration:none;color:inherit;}.industry-item:hover{background:var(--dark);transform:translateY(-2px);}.industry-item:hover .ind-icon i{color:var(--accent);}
.industry-item:hover{background:rgba(232,58,26,0.06);}
.ind-icon{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);}
.industry-item span{font-weight:700;font-size:0.9rem;color:var(--cream);}

/* ─── 7. WHY DEVVISTA ─── */
.why-section{background:var(--dark);padding:6rem 0;}
.why-item{display:grid;grid-template-columns:2.5rem 1fr 1.5rem;align-items:start;gap:1.75rem;padding:2rem 0;border-bottom:1px solid var(--border);cursor:default;opacity:0;transform:translateY(14px);transition:opacity 0.5s ease,transform 0.5s ease,padding-left 0.3s;}
.why-item.visible{opacity:1;transform:translateY(0);}
.why-item:first-child{border-top:1px solid var(--border);}
.why-item:hover{padding-left:0.75rem;}
.why-num{font-size:0.65rem;font-weight:900;letter-spacing:0.1em;color:rgba(245,230,211,0.1);padding-top:4px;transition:color 0.3s;}
.why-item:hover .why-num{color:var(--accent);}
.why-title{font-size:clamp(1rem,2vw,1.25rem);font-weight:800;color:var(--white);margin-bottom:0.4rem;letter-spacing:-0.2px;line-height:1.2;transition:color 0.3s;}
.why-item:hover .why-title{color:var(--accent);}
.why-body{color:var(--muted);font-size:0.88rem;line-height:1.85;margin:0;max-width:580px;}
.why-arrow{color:rgba(245,230,211,0.12);font-size:1rem;padding-top:4px;transition:color 0.3s,transform 0.3s;}
.why-item:hover .why-arrow{color:var(--accent);transform:translate(3px,-3px);}

/* ─── 8. LINKS / CASE STUDIES ─── */
.links-section{background:var(--dark-3);padding:6rem 0;}
.link-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.3rem 0;border-bottom:1px solid var(--border);text-decoration:none;transition:padding-left 0.25s;}
.link-row:first-of-type{border-top:1px solid var(--border);}
.link-row:hover{padding-left:0.75rem;}
.link-row span{color:var(--cream);font-size:0.875rem;font-weight:600;}
.link-row i{color:var(--accent);flex-shrink:0;}

/* ─── 9. FAQ ─── */
.faq-section{background:var(--dark-2);padding:6rem 0;}
.accordion-item{background:transparent!important;border:none!important;border-bottom:1px solid var(--border)!important;border-radius:0!important;margin:0;}
.accordion-item:first-of-type{border-top:1px solid var(--border)!important;}
.accordion-button{background:transparent!important;color:var(--white)!important;font-weight:700;font-size:0.92rem;padding:1.5rem 0;box-shadow:none!important;letter-spacing:-0.1px;border-radius:0!important;font-family:'Montserrat',sans-serif;}
.accordion-button:not(.collapsed){color:var(--accent)!important;}
.accordion-button::after{filter:invert(1) sepia(1) saturate(5) hue-rotate(330deg);}
.accordion-body{background:transparent;color:var(--muted);font-size:0.88rem;line-height:1.85;padding:0 0 1.5rem;}

/* ─── 10. CTA ─── */
.cta-section{background:var(--dark);padding:8rem 0;position:relative;overflow:hidden;border-top:1px solid var(--border);}
.cta-bg-word{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:22vw;font-weight:900;white-space:nowrap;-webkit-text-stroke:1px rgba(245,230,211,0.025);color:transparent;pointer-events:none;user-select:none;}
.cta-line{width:56px;height:3px;background:var(--accent);margin:0 auto 2.25rem;}
.cta-section h2{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:900;color:var(--white);line-height:1.0;letter-spacing:-2px;margin-bottom:1.5rem;}
.cta-section h2 .stroke-word{-webkit-text-stroke:2px var(--accent);color:transparent;}
.cta-section p{color:var(--muted);font-size:1rem;line-height:1.85;max-width:440px;margin:0 auto 2.5rem;}
.cta-trust{display:flex;justify-content:center;gap:2.5rem;flex-wrap:wrap;margin-top:2.25rem;}
.cta-trust span{font-size:0.78rem;color:rgba(245,230,211,0.35);display:flex;align-items:center;gap:0.4rem;font-weight:600;}
.cta-trust i{color:var(--accent);}

/* ─── SCROLL ANIMATIONS ─── */
.fade-up{opacity:0;transform:translateY(26px);transition:opacity 0.6s ease,transform 0.6s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}
.stagger-1{transition-delay:0.07s;}.stagger-2{transition-delay:0.14s;}
.stagger-3{transition-delay:0.21s;}.stagger-4{transition-delay:0.28s;}
.stagger-5{transition-delay:0.35s;}.stagger-6{transition-delay:0.42s;}

/* ─── RESPONSIVE ─── */
@media(max-width:991px){
  .hero h1{letter-spacing:-2px;}
  .hero{padding:4rem 0 3rem;}
  .bento-grid{grid-template-columns:repeat(6,1fr);}
  .b-8{grid-column:span 4;}.b-4{grid-column:span 2;}.b-6{grid-column:span 3;}.b-12{grid-column:span 6;}
  .process-grid{grid-template-columns:repeat(2,1fr);}
  .process-step:nth-child(2n){border-right:none;}
  .process-step:nth-child(n+3){border-top:1px solid rgba(255,255,255,0.18);}
  .process-step:nth-child(n+4){border-top:none;}
}
@media(max-width:767px){
  .hero h1{letter-spacing:-1px;font-size:clamp(2.4rem,8vw,3.6rem);}
  .hero-stats{grid-template-columns:1fr 1fr 1fr;}
  .hero-cta{flex-direction:column;}
  .btn-primary-custom,.btn-outline-custom{justify-content:center;}
  .bento-grid{grid-template-columns:1fr 1fr;}
  .b-8,.b-4,.b-6,.b-12{grid-column:span 2;}
  .industry-grid{grid-template-columns:1fr;}
  .cta-section{padding:5rem 0;}
  .cta-section h2{letter-spacing:-1px;}
  .cta-bg-word{font-size:40vw;}
  .btn-white-sharp,.btn-ghost-white{width:100%;justify-content:center;}
  .d-flex.justify-content-center.gap-3{flex-direction:column;align-items:center;}
}
@media(max-width:575px){
  .process-grid{grid-template-columns:1fr;}
  .process-step{border-right:none;border-bottom:1px solid rgba(255,255,255,0.18);}
  .process-step:last-child{border-bottom:none;}
  .process-step:nth-child(n+3){border-top:none;}
  .industry-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .hero-stats{grid-template-columns:1fr;}
  .stat-item{border-right:none;border-bottom:1px solid var(--border);}
  .stat-item:last-child{border-bottom:none;}
  .bento-grid{grid-template-columns:1fr;}
  .b-8,.b-4,.b-6,.b-12{grid-column:span 1;}
}
