/* ============================================================
   Vanillas Technologies — Homepage styles
   Palette derived from the brand logo (violet → magenta gradient)
   ============================================================ */
:root {
    /* Brand palette sampled directly from the logo:
       deep navy #003070 → mid blue #0070C0 → bright sky-blue #00A0F0 */
    --navy:        #0B2447;
    --violet:      #1268C4;   /* primary blue (var name kept for compatibility) */
    --violet-600:  #0E5BB0;
    --pink:        #00A8F0;   /* bright sky-blue accent (logo dot) */
    --magenta:     #0090E0;
    --blue:        #2563EB;
    --grad:        linear-gradient(120deg, #0A2E63 0%, #1268C4 48%, #00A8F0 100%);
    --grad-soft:   linear-gradient(120deg, #1268C4 0%, #00A8F0 100%);
    --bg-soft:     #F4F8FD;
    --bg-lav:      #EAF4FD;
    --text:        #1E2B45;
    --muted:       #5B6B82;
    --border:      #E2ECF6;
    --shadow:      0 18px 45px -22px rgba(13, 71, 161, .35);
    --shadow-sm:   0 8px 24px -14px rgba(13, 71, 161, .28);
    --radius:      18px;
}

* { box-sizing: border-box; }

body {
    font-family: 'Poppins', system-ui, -apple-system, sans-serif;
    color: var(--text);
    background: #fff;
    line-height: 1.6;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5 { font-weight: 700; color: var(--navy); letter-spacing: -.02em; }
a { text-decoration: none; transition: all .25s ease; }
img { max-width: 100%; }

.text-gradient {
    background: var(--grad);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* ---------- Buttons ---------- */
.btn { font-weight: 600; border-radius: 12px; padding: .7rem 1.5rem; transition: all .28s ease; }
.btn-lg { padding: .85rem 1.8rem; }

.btn-gradient {
    background: var(--grad);
    color: #fff;
    border: none;
    box-shadow: 0 12px 26px -12px rgba(18, 104, 196, .7);
}
.btn-gradient:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 18px 32px -12px rgba(18, 104, 196, .85); }

.btn-outline-dark-soft {
    background: #fff;
    color: var(--navy);
    border: 1.5px solid var(--border);
}
.btn-outline-dark-soft:hover { border-color: var(--violet); color: var(--violet); transform: translateY(-2px); }

.btn-white { background: #fff; color: var(--violet-600); border: none; font-weight: 700; }
.btn-white:hover { transform: translateY(-2px); color: var(--pink); box-shadow: 0 14px 30px -14px rgba(0,0,0,.4); }

/* ---------- Header ---------- */
.site-header {
    position: sticky; top: 0; z-index: 1030;
    background: rgba(255,255,255,.85);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid transparent;
    transition: all .3s ease;
}
.site-header.scrolled { box-shadow: 0 6px 24px -16px rgba(15,23,42,.3); border-bottom-color: var(--border); }
.navbar { padding: .9rem 0; }
.navbar-nav .nav-link {
    font-weight: 500; color: var(--navy); margin: 0 .35rem; position: relative; font-size: .95rem;
}
.navbar-nav .nav-link:hover, .navbar-nav .nav-link.active { color: var(--violet); }
.navbar-nav .nav-link.active::after {
    content: ''; position: absolute; left: 0; bottom: -4px; width: 100%; height: 2px;
    background: var(--grad); border-radius: 2px;
}
.dropdown-menu {
    border: none; border-radius: 14px; box-shadow: var(--shadow); padding: .5rem; margin-top: .6rem;
}
.dropdown-item { border-radius: 9px; font-weight: 500; padding: .55rem .9rem; font-size: .9rem; }
.dropdown-item:hover { background: var(--bg-lav); color: var(--violet); }

/* ---------- Hero ---------- */
.hero { position: relative; padding: 5rem 0 4rem; overflow: hidden; }
.hero-bg {
    position: absolute; inset: 0; z-index: -1;
    background:
        radial-gradient(circle at 78% 32%, rgba(0,168,240,.16), transparent 42%),
        radial-gradient(circle at 92% 60%, rgba(18,104,196,.14), transparent 40%),
        radial-gradient(circle at 10% 10%, rgba(18,104,196,.06), transparent 35%);
}
.badge-pill {
    display: inline-flex; align-items: center; gap: .5rem;
    background: #fff; border: 1px solid var(--border);
    color: var(--violet-600); font-weight: 600; font-size: .82rem;
    padding: .5rem 1rem; border-radius: 30px; box-shadow: var(--shadow-sm);
    margin-bottom: 1.5rem;
}
.badge-pill .fa-sparkles { color: var(--pink); }
.hero-title { font-size: clamp(2.8rem, 6vw, 4.6rem); font-weight: 800; line-height: 1.02; margin-bottom: 1.4rem; }
.hero-sub { font-size: 1.1rem; color: var(--muted); max-width: 30rem; margin-bottom: 2rem; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; }

/* Hero orbit graphic */
.hero-orbit { position: relative; width: 100%; max-width: 480px; aspect-ratio: 1; margin: 0 auto; }
.orbit-ring {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
    border-radius: 50%; border: 1.5px dashed rgba(18,104,196,.25);
}
.ring-1 { width: 78%; height: 78%; animation: spin 26s linear infinite; }
.ring-2 { width: 100%; height: 100%; border-style: solid; border-color: rgba(0,168,240,.12); animation: spin 40s linear infinite reverse; }
@keyframes spin { to { transform: translate(-50%,-50%) rotate(360deg); } }

.orbit-core {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
    width: 46%; height: 46%; border-radius: 50%;
    background: radial-gradient(circle at 50% 40%, #fff 0%, #EAF4FD 70%, #CDE7FB 100%);
    display: grid; place-items: center;
    box-shadow: 0 30px 60px -25px rgba(18,104,196,.55), inset 0 0 40px rgba(255,255,255,.6);
    animation: floaty 6s ease-in-out infinite;
}
.orbit-core img { width: 62%; height: auto; }
@keyframes floaty { 0%,100% { transform: translate(-50%,-52%); } 50% { transform: translate(-50%,-48%); } }

.orbit-dot { position: absolute; width: 12px; height: 12px; border-radius: 50%; background: var(--grad); box-shadow: 0 0 12px rgba(0,168,240,.7); }
.dot-1 { top: 8%; left: 50%; }
.dot-2 { top: 50%; right: 2%; background: var(--violet); }
.dot-3 { bottom: 14%; left: 16%; background: var(--pink); }

.float-card {
    position: absolute; display: flex; align-items: center; gap: .55rem;
    background: #fff; border: 1px solid var(--border); border-radius: 14px;
    padding: .6rem .85rem; font-weight: 600; font-size: .82rem; color: var(--navy);
    box-shadow: var(--shadow); white-space: nowrap; animation: floaty 5s ease-in-out infinite;
}
.fc-top-left    { top: 6%;  left: -6%; }
.fc-top-right   { top: 20%; right: -8%; animation-delay: .8s; }
.fc-bottom-left { bottom: 22%; left: -10%; animation-delay: 1.4s; }
.fc-bottom-right{ bottom: 4%;  right: -4%; animation-delay: 2s; }
.fc-icon { width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; color: #fff; font-size: .8rem; }
.fc-icon.violet { background: var(--violet); }
.fc-icon.pink   { background: var(--pink); }
.fc-icon.blue   { background: var(--blue); }

/* ---------- Trusted brands ---------- */
.brands { padding: 1rem 0 2rem; }
.brands-wrap { background: var(--bg-soft); border: 1px solid var(--border); border-radius: var(--radius); padding: 1.8rem 2rem; }
.brands-title { text-align: center; font-size: .75rem; letter-spacing: .12em; color: var(--muted); font-weight: 600; margin-bottom: 1.2rem; }
.brands-logos { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1.5rem; }
.brand-item {
    font-weight: 700; font-size: 1.25rem; color: #94A3B8; letter-spacing: .02em;
    filter: grayscale(1); opacity: .8; transition: all .3s ease;
}
.brand-item:hover { color: var(--violet); opacity: 1; filter: grayscale(0); }

/* ---------- Sections ---------- */
.section { padding: 5rem 0; }
.section.pt-0 { padding-top: 0; }
.bg-soft { background: var(--bg-soft); }
.eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    background: #fff; border: 1px solid var(--border); color: var(--violet-600);
    font-size: .72rem; font-weight: 600; letter-spacing: .08em;
    padding: .35rem .85rem; border-radius: 30px; margin-bottom: 1rem;
}
.eyebrow .fa-circle { font-size: .4rem; color: var(--pink); }
.section-title { font-size: clamp(1.8rem, 3.5vw, 2.6rem); line-height: 1.15; }
.section-lead { color: var(--muted); font-size: 1.02rem; margin-bottom: .8rem; }

.link-arrow { color: var(--violet-600); font-weight: 600; display: inline-flex; align-items: center; gap: .4rem; }
.link-arrow:hover { color: var(--pink); gap: .65rem; }
.link-arrow.sm { font-size: .88rem; }

/* ---------- Service cards ---------- */
.service-card {
    background: #fff; border: 1px solid var(--border); border-radius: var(--radius);
    padding: 1.8rem 1.6rem; height: 100%; transition: all .3s ease;
}
.service-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: transparent; }
.service-icon {
    width: 54px; height: 54px; border-radius: 14px; display: grid; place-items: center;
    font-size: 1.3rem; margin-bottom: 1.2rem;
}
.service-icon.violet { background: rgba(18,104,196,.12); color: var(--violet); }
.service-icon.pink   { background: rgba(0,168,240,.12); color: var(--pink); }
.service-icon.blue   { background: rgba(37,99,235,.12);  color: var(--blue); }
.service-card h3 { font-size: 1.15rem; margin-bottom: .6rem; }
.service-card p  { color: var(--muted); font-size: .92rem; margin-bottom: 1.1rem; }

/* ---------- Why choose us ---------- */
.why-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 1.3rem; }
.why-list li { display: flex; gap: 1rem; align-items: flex-start; }
.why-icon {
    flex: none; width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center;
    background: var(--bg-lav); color: var(--violet); font-size: 1.05rem;
}
.why-list h4 { font-size: 1rem; margin-bottom: .15rem; }
.why-list p  { color: var(--muted); font-size: .9rem; margin: 0; }

.stats-card {
    background: linear-gradient(160deg, #F7FBFF 0%, #EAF4FD 100%);
    border: 1px solid var(--border); border-radius: 24px; padding: 2.5rem 2rem;
    box-shadow: var(--shadow);
}
.stat { padding: .5rem; }
.stat-icon {
    width: 48px; height: 48px; border-radius: 12px; display: grid; place-items: center;
    background: #fff; color: var(--violet); font-size: 1.15rem; box-shadow: var(--shadow-sm); margin-bottom: 1rem;
}
.stat-num { font-size: 2.6rem; font-weight: 800; background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; margin: 0; line-height: 1; }
.stat p { color: var(--muted); font-weight: 500; margin: .35rem 0 0; }

/* ---------- Portfolio ---------- */
.portfolio-carousel { position: relative; }
.portfolio-track { display: flex; gap: 1.5rem; overflow-x: auto; scroll-behavior: smooth; padding: .5rem; scrollbar-width: none; }
.portfolio-track::-webkit-scrollbar { display: none; }
.portfolio-card {
    flex: 0 0 calc(25% - 1.13rem); min-width: 240px; background: #fff; border-radius: var(--radius);
    overflow: hidden; border: 1px solid var(--border); transition: transform .35s ease, box-shadow .35s ease;
    display: flex; flex-direction: column; box-shadow: var(--shadow-sm); position: relative;
}
.portfolio-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
.portfolio-img { position: relative; height: 180px; flex-shrink: 0; overflow: hidden; display: grid; place-items: center; color: rgba(255,255,255,.7); font-size: 2.2rem; }
.portfolio-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,46,99,.55), rgba(10,46,99,0) 55%); opacity: .85; transition: opacity .35s ease; }
.portfolio-card:hover .portfolio-img::after { opacity: 1; }
.portfolio-card:hover .portfolio-img img { transform: scale(1.08); }
.grad-1 { background: linear-gradient(135deg,#0A2E63,#0E4FA0); }
.grad-2 { background: linear-gradient(135deg,#00A8F0,#1268C4); }
.grad-3 { background: linear-gradient(135deg,#2563EB,#06B6D4); }
.grad-4 { background: linear-gradient(135deg,#1268C4,#00A8F0); }
.portfolio-info { padding: 1.1rem 1.3rem 1.25rem; display: flex; flex-direction: column; gap: .15rem; }
.portfolio-info h4 { font-size: 1.08rem; margin: 0; transition: color .25s ease; }
.portfolio-card:hover .portfolio-info h4 { color: var(--violet); }
.portfolio-info p  { color: var(--muted); font-size: .85rem; margin: 0; }

/* floating category chip on card image */
.card-chip {
    position: absolute; top: .85rem; left: .85rem; z-index: 2;
    background: rgba(255,255,255,.92); color: var(--violet-600); backdrop-filter: blur(4px);
    font-size: .72rem; font-weight: 700; letter-spacing: .02em; padding: .32rem .75rem;
    border-radius: 30px; box-shadow: 0 4px 12px -4px rgba(10,46,99,.4);
}

.carousel-arrow {
    position: absolute; top: 38%; z-index: 3; width: 44px; height: 44px; border-radius: 50%;
    border: none; background: #fff; color: var(--violet); box-shadow: var(--shadow);
    display: grid; place-items: center; cursor: pointer; transition: all .25s ease;
}
.carousel-arrow:hover { background: var(--grad); color: #fff; }
.carousel-arrow.prev { left: -18px; }
.carousel-arrow.next { right: -18px; }

/* ---------- Testimonials ---------- */
.testimonial-card {
    background: #fff; border: 1px solid var(--border); border-radius: var(--radius);
    padding: 2rem 1.7rem; height: 100%; position: relative; transition: all .3s ease;
}
.testimonial-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.quote-mark { font-size: 3.5rem; line-height: 0; color: var(--violet); opacity: .25; font-family: Georgia, serif; }
.testimonial-text { color: var(--muted); font-size: .95rem; margin: 1rem 0 1.6rem; }
.testimonial-author { display: flex; align-items: center; gap: .8rem; }
.author-avatar {
    width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center;
    background: var(--grad); color: #fff; font-weight: 700;
}
.testimonial-author h5 { font-size: .95rem; margin: 0; }
.testimonial-author p  { font-size: .8rem; color: var(--muted); margin: 0; }

/* ---------- Blog ---------- */
.blog-card {
    background: #fff; border: 1px solid var(--border); border-radius: var(--radius);
    overflow: hidden; height: 100%; transition: transform .35s ease, box-shadow .35s ease;
    display: flex; flex-direction: column; box-shadow: var(--shadow-sm);
}
.blog-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); }
.blog-img { position: relative; height: 210px; flex-shrink: 0; overflow: hidden; display: grid; place-items: center; color: rgba(255,255,255,.6); font-size: 2.5rem; }
.blog-img::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to top, rgba(10,46,99,.45), rgba(10,46,99,0) 55%); opacity: .8; transition: opacity .35s ease; }
.blog-card:hover .blog-img::after { opacity: 1; }
.blog-card:hover .blog-img img { transform: scale(1.08); }
.blog-body { padding: 1.5rem 1.6rem; flex: 1 1 auto; display: flex; flex-direction: column; }
.blog-date { font-size: .8rem; color: var(--muted); display: inline-flex; align-items: center; gap: .4rem; margin-bottom: .7rem; }
.blog-card h4 { font-size: 1.12rem; margin-bottom: 1rem; line-height: 1.4; transition: color .25s ease;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.blog-card:hover h4 { color: var(--violet); }
.blog-card .link-arrow { margin-top: auto; }

/* ---------- CTA ---------- */
.cta-section { padding: 1rem 0 5rem; }
.cta-banner {
    background: var(--grad); border-radius: 24px; padding: 2.5rem 3rem;
    display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap;
    box-shadow: 0 30px 60px -28px rgba(18,104,196,.65); position: relative; overflow: hidden;
}
.cta-banner::after {
    content: ''; position: absolute; right: -40px; top: -40px; width: 220px; height: 220px;
    background: radial-gradient(circle, rgba(255,255,255,.18), transparent 70%); border-radius: 50%;
}
.cta-content { display: flex; align-items: center; gap: 1.3rem; }
.cta-icon { width: 60px; height: 60px; border-radius: 16px; background: rgba(255,255,255,.18); display: grid; place-items: center; color: #fff; font-size: 1.5rem; flex: none; }
.cta-banner h2 { color: #fff; font-size: 1.7rem; margin: 0; }
.cta-banner p  { color: rgba(255,255,255,.85); margin: .3rem 0 0; }

/* ---------- Footer ---------- */
.site-footer { background: #fff; border-top: 1px solid var(--border); padding: 3.5rem 0 1.5rem; }
.footer-brand { display: inline-block; margin-bottom: 1rem; }
.footer-about { color: var(--muted); font-size: .92rem; max-width: 22rem; }
.footer-social { display: flex; gap: .6rem; margin-top: 1.2rem; }
.footer-social a {
    width: 38px; height: 38px; border-radius: 10px; display: grid; place-items: center;
    background: var(--bg-soft); color: var(--navy); border: 1px solid var(--border);
}
.footer-social a:hover { background: var(--grad); color: #fff; border-color: transparent; transform: translateY(-2px); }
.site-footer h5 { font-size: .95rem; margin-bottom: 1.1rem; }
.footer-links, .footer-contact { list-style: none; padding: 0; margin: 0; display: grid; gap: .65rem; }
.footer-links a, .footer-contact a { color: var(--muted); font-size: .9rem; }
.footer-links a:hover, .footer-contact a:hover { color: var(--violet); }
.footer-contact li { color: var(--muted); font-size: .9rem; display: flex; gap: .55rem; align-items: flex-start; }
.footer-contact i { color: var(--violet); margin-top: .2rem; }
.footer-bottom {
    margin-top: 2.5rem; padding-top: 1.4rem; border-top: 1px solid var(--border);
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem;
}
.footer-bottom p { color: var(--muted); font-size: .85rem; margin: 0; }
.footer-legal { display: flex; gap: 1.5rem; }
.footer-legal a { color: var(--muted); font-size: .85rem; }
.footer-legal a:hover { color: var(--violet); }

/* ---------- Floating buttons ---------- */
.whatsapp-float {
    position: fixed; bottom: 24px; left: 24px; z-index: 1040;
    width: 56px; height: 56px; border-radius: 50%; background: #25D366; color: #fff;
    display: grid; place-items: center; font-size: 1.6rem; box-shadow: 0 12px 28px -10px rgba(37,211,102,.7);
    animation: floaty 3s ease-in-out infinite;
}
.whatsapp-float:hover { color: #fff; transform: scale(1.08); }
.back-to-top {
    position: fixed; bottom: 24px; right: 24px; z-index: 1040; width: 46px; height: 46px;
    border-radius: 50%; border: none; background: var(--grad); color: #fff; cursor: pointer;
    box-shadow: var(--shadow); opacity: 0; visibility: hidden; transition: all .3s ease;
}
.back-to-top.show { opacity: 1; visibility: visible; }
.back-to-top:hover { transform: translateY(-3px); }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 991px) {
    .navbar-collapse { background: #fff; border: 1px solid var(--border); border-radius: 16px; padding: 1rem; margin-top: .8rem; box-shadow: var(--shadow); }
    .navbar-nav { margin-bottom: 1rem; }
    .btn-gradient { width: 100%; text-align: center; }
    .hero { padding-top: 3rem; }
    .hero-orbit { max-width: 360px; margin-top: 2rem; }
    .portfolio-card { flex: 0 0 calc(50% - .75rem); }
}
@media (max-width: 575px) {
    .brands-logos { justify-content: center; gap: 1.4rem 2rem; }
    .cta-banner { padding: 2rem 1.6rem; text-align: center; }
    .cta-content { flex-direction: column; text-align: center; }
    .portfolio-card { flex: 0 0 80%; }
    .float-card { font-size: .72rem; padding: .45rem .6rem; }
    .carousel-arrow.prev { left: -6px; } .carousel-arrow.next { right: -6px; }
    .page-hero { padding: 3rem 0 2.5rem; }
}

/* ============================================================
   Inner pages
   ============================================================ */
a.plain, .plain { color: inherit; }
a.plain:hover { color: var(--violet); }
.portfolio-img img, .blog-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .55s ease; }

/* Page hero / breadcrumb banner */
.page-hero { position: relative; padding: 4.5rem 0 3.5rem; overflow: hidden; text-align: center; }
.page-hero::before {
    content: ''; position: absolute; inset: 0; z-index: -1;
    background:
        radial-gradient(circle at 20% 20%, rgba(18,104,196,.10), transparent 45%),
        radial-gradient(circle at 85% 40%, rgba(0,168,240,.10), transparent 45%),
        var(--bg-soft);
}
.page-hero h1 { font-size: clamp(2.1rem, 4.5vw, 3.2rem); font-weight: 800; }
.page-hero p { color: var(--muted); max-width: 38rem; margin: .8rem auto 0; }
.breadcrumb-pill {
    display: inline-flex; gap: .4rem; align-items: center; background: #fff; border: 1px solid var(--border);
    border-radius: 30px; padding: .4rem 1rem; font-size: .85rem; font-weight: 500; margin-bottom: 1.2rem;
}
.breadcrumb-pill a { color: var(--muted); } .breadcrumb-pill a:hover { color: var(--violet); }
.breadcrumb-pill .sep { color: var(--border); } .breadcrumb-pill .cur { color: var(--violet); font-weight: 600; }

/* About */
.about-img-wrap { position: relative; border-radius: 24px; overflow: hidden; box-shadow: var(--shadow); aspect-ratio: 4/3;
    background: var(--grad); display: grid; place-items: center; }
.about-img-wrap img { width: 70%; }
.value-card { background:#fff; border:1px solid var(--border); border-radius: var(--radius); padding:1.6rem; height:100%; transition: all .3s ease; }
.value-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.value-card .v-icon { width:50px;height:50px;border-radius:13px;display:grid;place-items:center;background:var(--grad);color:#fff;font-size:1.2rem;margin-bottom:1rem; }

/* Team */
.team-card { background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-align:center;transition:all .3s ease; }
.team-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.team-photo { height:230px; background: var(--grad-soft); display:grid;place-items:center;color:#fff;font-size:3.5rem; }
.team-card .t-body { padding:1.2rem; } .team-card h4 { margin:0;font-size:1.05rem; } .team-card p { color:var(--muted);font-size:.85rem;margin:.2rem 0 .6rem; }
.team-social a { color: var(--muted); margin:0 .35rem; } .team-social a:hover { color: var(--violet); }

/* Technologies */
.tech-card { background:#fff;border:1px solid var(--border);border-radius:16px;padding:1.6rem 1rem;text-align:center;transition:all .3s ease; }
.tech-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: transparent; }
.tech-card i { font-size:2.4rem; background: var(--grad); -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent; }
.tech-card h5 { margin:.8rem 0 .2rem; font-size:1rem; } .tech-card span { color:var(--muted); font-size:.78rem; }

/* Careers */
.job-card { background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.6rem 1.8rem;transition:all .3s ease;
    display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap; }
.job-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.job-card h4 { margin:0 0 .4rem; }
.job-meta { display:flex; gap:1.2rem; flex-wrap:wrap; color:var(--muted); font-size:.88rem; }
.job-meta span i { color: var(--violet); margin-right:.35rem; }

/* Forms */
.form-control, .form-select {
    border:1.5px solid var(--border); border-radius:12px; padding:.75rem 1rem; font-size:.95rem;
}
.form-control:focus, .form-select:focus { border-color: var(--violet); box-shadow: 0 0 0 .2rem rgba(18,104,196,.12); }
.form-label { font-weight:600; font-size:.9rem; color: var(--navy); margin-bottom:.4rem; }
.form-card { background:#fff;border:1px solid var(--border);border-radius:24px;padding:2.5rem;box-shadow:var(--shadow); }
.alert-soft { border-radius:12px; border:none; font-weight:500; }
.alert-soft.ok { background:#ECFDF5; color:#047857; } .alert-soft.bad { background:#FEF2F2; color:#B91C1C; }

/* Contact info cards */
.contact-info-card { display:flex; gap:1rem; align-items:flex-start; background:#fff; border:1px solid var(--border);
    border-radius:16px; padding:1.3rem; margin-bottom:1rem; }
.contact-info-card .ci-icon { width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:var(--bg-lav);color:var(--violet);font-size:1.15rem;flex:none; }
.contact-info-card h5 { margin:0 0 .2rem;font-size:1rem; } .contact-info-card p,.contact-info-card a { color:var(--muted);font-size:.9rem;margin:0; }

/* Blog detail */
.blog-hero-img { height:380px;border-radius:24px;overflow:hidden;background:var(--grad);display:grid;place-items:center;color:rgba(255,255,255,.6);font-size:4rem;margin-bottom:2rem; }
.blog-content { font-size:1.05rem; color:#3F3A66; } .blog-content p { margin-bottom:1.2rem; }
.blog-content h2,.blog-content h3 { margin:1.8rem 0 .8rem; }
.chip { display:inline-block;background:var(--bg-lav);color:var(--violet);font-size:.75rem;font-weight:600;padding:.3rem .8rem;border-radius:20px; }

/* Pagination */
.pagination .page-link { border:none; color:var(--navy); border-radius:10px !important; margin:0 .2rem; font-weight:600; }
.pagination .page-item.active .page-link { background: var(--grad); color:#fff; }

/* CTA strip reused */
.mini-cta { background: var(--grad); border-radius:24px; padding:3rem; text-align:center; color:#fff; }
.mini-cta h2 { color:#fff; } .mini-cta p { color:rgba(255,255,255,.85); }
