@charset "UTF-8";
/* _sass/_variables.scss */
/** Reset some basic elements */
body, h1, h2, h3, h4, h5, h6, p, blockquote, pre, hr, dl, dd, ol, ul, figure { margin: 0; padding: 0; }

/** Basic styling */
body { font: 400 16px/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"; color: #333; background-color: #fdfdfd; -webkit-text-size-adjust: 100%; -webkit-font-feature-settings: "kern" 1; -moz-font-feature-settings: "kern" 1; -o-font-feature-settings: "kern" 1; font-feature-settings: "kern" 1; font-kerning: normal; display: flex; min-height: 100vh; flex-direction: column; }

/** Set `margin-bottom` to maintain vertical rhythm */
h1, h2, h3, h4, h5, h6, p, blockquote, pre, ul, ol, dl, figure, .highlight { margin-bottom: 15px; }

/** `main` element */
main { display: block; /* Default value of `display` of `main` element is 'inline' in IE 11. */ }

/** Images */
img { max-width: 100%; vertical-align: middle; }

/** Figures */
figure > img { display: block; }

figcaption { font-size: 14px; }

/** Lists */
ul, ol { margin-left: 30px; }

li > ul, li > ol { margin-bottom: 0; }

/** Headings */
h1, h2, h3, h4, h5, h6 { font-weight: 400; }

/** Links */
a { color: #2a7ae2; text-decoration: none; }

a:visited { color: #1756a9; }

a:hover { color: #333; text-decoration: underline; }

.social-media-list a:hover { text-decoration: none; }

.social-media-list a:hover .username { text-decoration: underline; }

/** Blockquotes */
blockquote { color: #828282; border-left: 4px solid #e8e8e8; padding-left: 15px; font-size: 18px; letter-spacing: -1px; font-style: italic; }

blockquote > :last-child { margin-bottom: 0; }

/** Code formatting */
pre, code { font-size: 15px; border: 1px solid #e8e8e8; border-radius: 3px; background-color: #eef; }

code { padding: 1px 5px; }

pre { padding: 8px 12px; overflow-x: auto; }

pre > code { border: 0; padding-right: 0; padding-left: 0; }

/** Wrapper */
.wrapper { max-width: -webkit-calc(800px - (30px * 2)); max-width: calc(800px - (30px * 2)); margin-right: auto; margin-left: auto; padding-right: 30px; padding-left: 30px; }

@media screen and (max-width: 800px) { .wrapper { max-width: -webkit-calc(800px - (30px)); max-width: calc(800px - (30px)); padding-right: 15px; padding-left: 15px; } }

/** Clearfix */
.footer-col-wrapper:after, .wrapper:after { content: ""; display: table; clear: both; }

/** Icons */
.svg-icon { width: 16px; height: 16px; display: inline-block; fill: #828282; padding-right: 5px; vertical-align: text-top; }

.social-media-list li + li { padding-top: 5px; }

/** Tables */
table { margin-bottom: 30px; width: 100%; text-align: left; color: #616161; border-collapse: collapse; border: 1px solid #e8e8e8; }

table tr:nth-child(even) { background-color: #f7f7f7; }

table th, table td { padding: 9.999999999px 15px; }

table th { background-color: #f0f0f0; border: 1px solid #dedede; border-bottom-color: #c9c9c9; }

table td { border: 1px solid #e8e8e8; }

/** Site header */
.site-header { border-top: 5px solid #424242; border-bottom: 1px solid #e8e8e8; min-height: 55.95px; position: relative; }

.site-title { font-size: 26px; font-weight: 300; line-height: 54px; letter-spacing: -1px; margin-bottom: 0; float: left; }

.site-title, .site-title:visited { color: #424242; }

.site-nav { float: right; line-height: 54px; }

.site-nav .nav-trigger { display: none; }

.site-nav .menu-icon { display: none; }

.site-nav .page-link { color: #333; line-height: 1.5; }

.site-nav .page-link:not(:last-child) { margin-right: 20px; }

@media screen and (max-width: 600px) { .site-nav { position: absolute; top: 9px; right: 15px; background-color: #fdfdfd; border: 1px solid #e8e8e8; border-radius: 5px; text-align: right; } .site-nav label[for="nav-trigger"] { display: block; float: right; width: 36px; height: 36px; z-index: 2; cursor: pointer; } .site-nav .menu-icon { display: block; float: right; width: 36px; height: 26px; line-height: 0; padding-top: 10px; text-align: center; } .site-nav .menu-icon > svg { fill: #424242; } .site-nav input ~ .trigger { clear: both; display: none; } .site-nav input:checked ~ .trigger { display: block; padding-bottom: 5px; } .site-nav .page-link { display: block; margin-left: 20px; padding: 5px 10px; } .site-nav .page-link:not(:last-child) { margin-right: 0; } }

/** Site footer */
.site-footer { border-top: 1px solid #e8e8e8; padding: 30px 0; }

.footer-heading { font-size: 18px; margin-bottom: 15px; }

.contact-list, .social-media-list { list-style: none; margin-left: 0; }

.footer-col-wrapper { font-size: 15px; color: #828282; margin-left: -15px; }

.footer-col { float: left; margin-bottom: 15px; padding-left: 15px; }

.footer-col-1 { width: -webkit-calc(35% - (30px / 2)); width: calc(35% - (30px / 2)); }

.footer-col-2 { width: -webkit-calc(20% - (30px / 2)); width: calc(20% - (30px / 2)); }

.footer-col-3 { width: -webkit-calc(45% - (30px / 2)); width: calc(45% - (30px / 2)); }

@media screen and (max-width: 800px) { .footer-col-1, .footer-col-2 { width: -webkit-calc(50% - (30px / 2)); width: calc(50% - (30px / 2)); } .footer-col-3 { width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }

@media screen and (max-width: 600px) { .footer-col { float: none; width: -webkit-calc(100% - (30px / 2)); width: calc(100% - (30px / 2)); } }

/** Page content */
.page-content { padding: 30px 0; flex: 1; }

.page-heading { font-size: 32px; }

.post-list-heading { font-size: 28px; }

.post-list { margin-left: 0; list-style: none; }

.post-list > li { margin-bottom: 30px; }

.post-meta { font-size: 14px; color: #828282; }

.post-link { display: block; font-size: 24px; }

/** Posts */
.post-header { margin-bottom: 30px; }

.post-title { font-size: 42px; letter-spacing: -1px; line-height: 1; }

@media screen and (max-width: 800px) { .post-title { font-size: 36px; } }

.post-content { margin-bottom: 30px; }

.post-content h2 { font-size: 32px; }

@media screen and (max-width: 800px) { .post-content h2 { font-size: 28px; } }

.post-content h3 { font-size: 26px; }

@media screen and (max-width: 800px) { .post-content h3 { font-size: 22px; } }

.post-content h4 { font-size: 20px; }

@media screen and (max-width: 800px) { .post-content h4 { font-size: 18px; } }

/** Syntax highlighting styles */
.highlight { background: #fff; }

.highlighter-rouge .highlight { background: #eef; }

.highlight .c { color: #998; font-style: italic; }

.highlight .err { color: #a61717; background-color: #e3d2d2; }

.highlight .k { font-weight: bold; }

.highlight .o { font-weight: bold; }

.highlight .cm { color: #998; font-style: italic; }

.highlight .cp { color: #999; font-weight: bold; }

.highlight .c1 { color: #998; font-style: italic; }

.highlight .cs { color: #999; font-weight: bold; font-style: italic; }

.highlight .gd { color: #000; background-color: #fdd; }

.highlight .gd .x { color: #000; background-color: #faa; }

.highlight .ge { font-style: italic; }

.highlight .gr { color: #a00; }

.highlight .gh { color: #999; }

.highlight .gi { color: #000; background-color: #dfd; }

.highlight .gi .x { color: #000; background-color: #afa; }

.highlight .go { color: #888; }

.highlight .gp { color: #555; }

.highlight .gs { font-weight: bold; }

.highlight .gu { color: #aaa; }

.highlight .gt { color: #a00; }

.highlight .kc { font-weight: bold; }

.highlight .kd { font-weight: bold; }

.highlight .kp { font-weight: bold; }

.highlight .kr { font-weight: bold; }

.highlight .kt { color: #458; font-weight: bold; }

.highlight .m { color: #099; }

.highlight .s { color: #d14; }

.highlight .na { color: #008080; }

.highlight .nb { color: #0086B3; }

.highlight .nc { color: #458; font-weight: bold; }

.highlight .no { color: #008080; }

.highlight .ni { color: #800080; }

.highlight .ne { color: #900; font-weight: bold; }

.highlight .nf { color: #900; font-weight: bold; }

.highlight .nn { color: #555; }

.highlight .nt { color: #000080; }

.highlight .nv { color: #008080; }

.highlight .ow { font-weight: bold; }

.highlight .w { color: #bbb; }

.highlight .mf { color: #099; }

.highlight .mh { color: #099; }

.highlight .mi { color: #099; }

.highlight .mo { color: #099; }

.highlight .sb { color: #d14; }

.highlight .sc { color: #d14; }

.highlight .sd { color: #d14; }

.highlight .s2 { color: #d14; }

.highlight .se { color: #d14; }

.highlight .sh { color: #d14; }

.highlight .si { color: #d14; }

.highlight .sx { color: #d14; }

.highlight .sr { color: #009926; }

.highlight .s1 { color: #d14; }

.highlight .ss { color: #990073; }

.highlight .bp { color: #999; }

.highlight .vc { color: #008080; }

.highlight .vg { color: #008080; }

.highlight .vi { color: #008080; }

.highlight .il { color: #099; }

/* _sass/_base.scss */
body { font-family: 'Poppins', sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

/* _sass/_client-logos.scss */
/* ========================================================================== Client Logos Section Styles ========================================================================== */
.client-logos { padding: 4rem 0; text-align: center; background-color: #f9f9f9; /* A light gray background for the whole section */ border-top: 1px solid #eee; }

/* --- The responsive grid container --- */
.logo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 2rem; /* Space between logos */ align-items: center; margin-top: 3rem; }

/* --- Individual logo item styling --- */
.logo-item { display: flex; /* Use flexbox to easily center the image */ align-items: center; justify-content: center; height: 120px; /* Give all boxes a consistent height for a uniform grid */ padding: 1.5rem; /* Adds space between the logo and the edge of the box */ background-color: #dfdfdf; /* A clean, white background for all logos */ border-radius: 8px; /* Soft, rounded corners for a modern look */ box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05); /* A subtle shadow to lift it off the page */ transition: box-shadow 0.3s ease, transform 0.3s ease; /* Smooth transition for the hover effect */ }

/* --- A more engaging hover effect for the entire box --- */
.logo-item:hover { transform: translateY(-5px); /* Lifts the box on hover */ box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1); /* A more prominent shadow on hover */ }

.logo-item img { max-width: 100%; /* Ensures the logo fits within the padded box */ max-height: 60px; /* Controls the max height of the logo itself */ width: auto; /* Maintains aspect ratio */ }

/* This class is no longer needed as all items have a background */
/* .logo-bg--dark { background-color: #545454; } */
/* _sass/_contact-form.scss */
.contact-form-section { padding: 4rem 0; background-color: #f9f9f9; }

.contact-form { max-width: 700px; margin: 2rem auto 0 auto; }

.form-group { margin-bottom: 1.5rem; }

.form-group label { display: block; font-weight: 700; margin-bottom: 0.5rem; color: #333; }

.form-group input, .form-group textarea { width: 95%; padding: 0.75rem 1rem; border: 1px solid #e0e0e0; border-radius: 5px; font-family: inherit; /* Inherit the Poppins font */ font-size: 1rem; transition: border-color 0.3s ease, box-shadow 0.3s ease; }

.form-group input:focus, .form-group textarea:focus { outline: none; border-color: #007bff; box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.2); }

/* --- The Honeypot: Hide it from humans --- */
.form-group.honeypot { opacity: 0; position: absolute; top: 0; left: 0; height: 0; width: 0; z-index: -1; }

/* --- Button Styling --- */
.cta-button { display: inline-block; padding: 0.75rem 2rem; border-radius: 5px; border: none; background-color: #007bff; color: #ffffff; font-size: 1rem; font-weight: 600; text-decoration: none; cursor: pointer; transition: background-color 0.3s ease, transform 0.3s ease; }

.cta-button:hover { background-color: #0056b3; transform: translateY(-2px); }

/* _sass/_divider.scss */
.section-divider { border: 0; /* Remove the default border */ height: 1px; /* Make it a thin line */ background-color: #efefef; /* A soft, neutral color */ /* Make it a short, centered line for a modern look */ max-width: 150px; margin: 1rem auto; /* Center it and give it plenty of vertical space */ }

/* _sass/_footer.scss */
.footer-col-wrapper { display: flex; justify-content: center; align-items: flex-start; gap: 4rem; margin-left: 0; }

.footer-col { float: none; width: auto; padding-left: 0; }

@media screen and (max-width: 600px) { .footer-col-wrapper { flex-direction: column; align-items: center; gap: 2rem; } .footer-col { text-align: center; } }

.copyright-notice { text-align: center; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid #e0e0e0; font-size: 0.9rem; color: #555; }

/* _sass/_header.scss */
.site-title { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 24px; letter-spacing: -0.5px; }

/* ========================================================================== Hero Section Styles ========================================================================== */
/* --- Hero Container --- */
.hero { /* Flexbox helps center the content vertically and horizontally */ display: flex; align-items: center; justify-content: center; text-align: center; /* Sizing and Spacing */ min-height: 60vh; /* Makes the hero section 60% of the viewport height */ padding: 4rem 2rem; /* Generous padding for a spacious feel */ /* Background Image */ /* Replace with your own image URL */ /*background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url('/assets/images/hero/stock-photo-abstract-network-geometrical-shapes-connection-concept-digital-communication-and-technology-1478967707.jpg');*/ background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url("/assets/images/hero/hero-yellow-stripe-2.jpeg"); background-size: cover; /* Ensures the image covers the entire section */ background-position: center; /* Centers the image */ background-repeat: no-repeat; /* Text Color */ color: #ffffff; /* White text provides good contrast on a dark background */ }

/* --- Hero Content Wrapper --- */
.hero-content { max-width: 800px; /* Prevents text from becoming too wide on large screens */ }

/* --- Headline --- */
.hero-headline { font-size: 3.5rem; /* Large, impactful font size */ font-weight: 700; margin: 0 0 1rem; line-height: 1.2; }

/* --- Sub-headline --- */
.hero-subheadline { font-size: 1.25rem; font-weight: 300; margin: 0 0 2rem; opacity: 0.9; /* Slightly transparent to de-emphasize it from the headline */ }

/* --- Call-to-Action (CTA) Button --- */
.hero-cta-button { display: inline-block; padding: 0.75rem 2rem; border-radius: 5px; background-color: #007bff; /* A bright, attention-grabbing color */ color: #ffffff; font-size: 1rem; font-weight: 600; text-decoration: none; transition: background-color 0.3s ease, transform 0.3s ease; }

.hero-cta-button:hover { background-color: #0056b3; /* Darker shade on hover */ transform: translateY(-2px); /* Slight lift effect on hover */ text-decoration: none; color: #ffffff; }

/* ========================================================================== Responsive Adjustments for Mobile ========================================================================== */
@media (max-width: 768px) { .hero { min-height: 50vh; /* Slightly shorter on mobile */ padding: 3rem 1rem; } .hero-headline { font-size: 2.5rem; /* Smaller font size for smaller screens */ } .hero-subheadline { font-size: 1.1rem; } }

/* ========================================================================== Services Overview Section Styles ========================================================================== */
.services-overview { padding: 4rem 0; /* Adds vertical spacing above and below the section */ background-color: #f9f9f9; /* A light background to separate it from other content */ border-top: 1px solid #eee; border-bottom: 1px solid #eee; }

/* --- Shared styles for section headlines and intros --- */
.section-headline { text-align: center; font-size: 2.25rem; margin-bottom: 1rem; }

.section-intro { text-align: center; font-size: 1.1rem; max-width: 750px; /* Keeps the intro text from being too wide */ margin: 0 auto 3rem auto; /* Centers the intro text block */ color: #555; }

/* --- Two-column layout for the services --- */
.services-columns { display: flex; gap: 3rem; /* Creates space between the columns */ align-items: flex-start; }

.service-column { flex: 1; /* Each column will take up equal space */ }

.service-column h3 { font-size: 1.5rem; margin-bottom: 1rem; border-bottom: 2px solid #007bff; /* Adds a colored accent under the heading */ padding-bottom: 0.5rem; }

/* --- Styling for the "What We Do" list --- */
.service-column ul { list-style: none; padding: 0; margin: 0 0 1rem 0; }

.service-column li { padding: 0.5rem 0 0.5rem 2rem; /* Indents the text to make room for an icon */ position: relative; line-height: 1.6; }

/* Adds a checkmark icon before each list item for a professional look */
.service-column li::before { content: '✔'; /* You can use any character or an SVG icon here */ position: absolute; left: 0; top: 0.5rem; color: #007bff; /* Matches the heading accent color */ font-weight: bold; }

/* --- Responsive adjustments for mobile --- */
@media (max-width: 768px) { .services-columns { flex-direction: column; /* Stacks the columns on top of each other */ gap: 2rem; } .section-headline { font-size: 2rem; } }

/*# sourceMappingURL=main.css.map */