
@import url('https://fonts.googleapis.com/css2?family=Fira+Code:wght@400;600&display=swap');

:root{
  --primary:#0A6FB7;
  --green:#22B573;
  --ink:#0E2A3B;
  --muted:#5a6b7b;
  --bg:#f8f9fa;
  --card:#ffffff;
  --border:#e6eef5;
  --heroA:#e6f4ff;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{background-color:var(--bg);color:#333;line-height:1.6;font-family:'Fira Code',ui-monospace,Menlo,Consolas,monospace}
img{max-width:100%;height:auto;display:block}
a{color:var(--primary);text-decoration:none}
a:hover{color:#085a95}
a:focus{outline:2px solid var(--green);outline-offset:2px}
.container{max-width:1200px;margin:0 auto;padding:0 16px}
header{background:#fff;color:#000;padding:12px 0;box-shadow:0 4px 6px rgba(0,0,0,.08);position:sticky;top:0;z-index:10}
.header-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px}
header h1{font-size:24px}
.menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;border:1px solid var(--border);background:#fff}
.menu-toggle span{display:block;width:18px;height:2px;background:#0a0f24;position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:#0a0f24}
.menu-toggle span::before{top:-6px}.menu-toggle span::after{top:6px}
nav.nav{display:none;flex-direction:column;gap:8px;padding:8px 0}
nav.nav a{color:var(--primary);margin:0 10px;font-weight:600;display:inline-block;transition:color .2s}
nav.nav a:hover{color:#085a95}
nav.nav.open{display:flex}
@media (min-width:768px){.menu-toggle{display:none} nav.nav{display:flex !important;flex-direction:row;gap:16px;padding:0}}
.hero{padding:clamp(40px,6vw,88px) 20px;background:linear-gradient(135deg,var(--heroA),#fff);text-align:center;color:#0a0f24}
.hero h1,.hero h2{font-size:clamp(24px,5vw,40px);margin-bottom:16px}
.typed-text{color:var(--primary);border-right:2px solid rgba(0,0,0,.75);white-space:nowrap;overflow:hidden;display:inline-block;animation:typing 4s steps(40,end),blink .75s step-end infinite}
@keyframes typing{from{width:0}to{width:100%}} @keyframes blink{50%{border-color:transparent}}
.hero p{font-size:clamp(16px,2.4vw,20px);max-width:800px;margin:0 auto 30px}
.btn{padding:12px 24px;background:linear-gradient(90deg,var(--primary),var(--green));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:800;display:inline-block;transition:filter .2s,transform .06s;box-shadow:0 6px 16px rgba(16,118,190,.18)}
.btn:hover{filter:brightness(.98)} .btn:active{transform:translateY(1px)}
section{scroll-margin-top:80px}
.py-section{padding:40px 0}
.section-title{color:var(--primary);font-weight:800;text-align:center;margin:0 0 20px;font-size:clamp(20px,3.5vw,28px)}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;background:rgba(34,181,115,.1);color:var(--green);font-weight:700;font-size:12px;margin-bottom:8px}
.bg-blue-50{background:#e9f5ff} .bg-slate-50{background:#f0f4f8} .bg-blue-100{background:#d2e7f6}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.card h3{color:var(--primary);margin:0 0 8px}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
section.features{padding:40px 20px}
.feature-box{flex:1 1 280px;margin:10px;text-align:center;background:#fff;padding:20px;border-radius:8px;border:1px solid var(--border);box-shadow:0 0 10px rgba(0,0,0,.05);transition:transform .2s,box-shadow .2s}
.feature-box:hover{transform:translateY(-5px);box-shadow:0 10px 24px rgba(0,0,0,.08)}
.feature-box h3{color:var(--primary);margin-bottom:10px}
.feature-box h3 span{display:inline-block;white-space:nowrap;overflow:hidden}
@media (min-width:1024px){.features-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.contact-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media (min-width:768px){.contact-grid{grid-template-columns:1fr 1.2fr}}
iframe.map{width:100%;height:380px;border:0;border-radius:10px}
footer{background:#fff;color:#333;text-align:center;padding:20px;margin-top:40px;font-size:14px;box-shadow:0 -2px 6px rgba(0,0,0,.05)}
.portfolio{max-width:1000px;margin:40px auto;padding:20px}
.project{background:#fff;margin-bottom:20px;padding:20px;border-left:4px solid var(--primary);transition:background-color .2s;cursor:pointer;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.project:hover{background:#f0f4f8} .project h2{color:var(--primary);font-size:20px;margin-bottom:8px} .project p{color:#444}
.tag{display:inline-block;margin:0 8px 8px 0;padding:3px 10px;border-radius:999px;background:rgba(34,181,115,.1);color:var(--green);font-weight:700;font-size:12px}
.modal{display:none;position:fixed;z-index:999;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,.8)}
.modal-content{background:#fff;color:#333;max-width:800px;margin:60px auto;padding:30px;border:1px solid #ccc;position:relative;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.2)}
.modal-content h2{color:var(--primary);margin-bottom:15px} .modal-content p{line-height:1.6}
.close{position:absolute;top:10px;right:20px;font-size:28px;color:#f85149;cursor:pointer}
@media (max-width:600px){.modal-content{width:90%}}
.terminal-section{padding:40px 20px;text-align:center} .terminal-section .terminal-line{opacity:0}
@media (max-width:1024px){.hero h1,.hero h2{font-size:28px} .btn{padding:10px 20px;font-size:14px}}
@media (max-width:768px){
  .header-inner{align-items:center;text-align:center}
  nav.nav a{display:block;margin:8px 0}
  .hero h1,.hero h2{font-size:24px}
  .hero p{font-size:16px;padding:0 10px}
  .features{flex-direction:column;align-items:center}
  .feature-box{width:90%;margin-bottom:20px}
  section#projects div{flex-direction:column;align-items:center}
  section#projects div > div{width:90%;margin-bottom:20px}
}
@media (max-width:480px){
  header h1{font-size:20px}
  .hero{padding:40px 10px}
  .btn{width:100%;display:block}
  .feature-box{padding:15px}
  footer{font-size:12px}
}


/* === Our Services grid: always 3 × 2 on desktop === */
.features-grid{
  display: grid;
  grid-template-columns: 1fr;              /* phones: 1 per row */
  gap: 16px;
  align-items: stretch;
}
@media (min-width: 640px){                 /* tablets: 2 per row */
  .features-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px){                /* desktop: 3 per row */
  .features-grid{ grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* Make each service card stretch to equal height */
.features-grid > .card,
.features-grid > .feature-box{
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}


/* ===== Force exactly 3 cards per row in Our Services on desktop ===== */
@media (min-width: 1024px){
  /* New markup */
  #services .features-grid{
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 20px !important;
    justify-content: initial !important;
  }
  /* Legacy markup that used flex with inline styles */
  #services .features{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 20px !important;
    justify-content: initial !important;
  }
  #services .feature-box{ margin: 0 !important; }
}
/* Tablet = 2 per row, Mobile = 1 per row */
@media (min-width: 640px) and (max-width: 1023.98px){
  #services .features-grid, #services .features{ grid-template-columns: repeat(2, minmax(0,1fr)) !important; }
}
@media (max-width: 639.98px){
  #services .features-grid, #services .features{ grid-template-columns: 1fr !important; }
}

.contact-card .kv{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap: 8px 12px;
}
.contact-card .k{ font-weight:700; color: var(--primary); }
.contact-card .v a{ color: var(--primary); font-weight:700; text-decoration:none; }
@media (max-width: 480px){
  .contact-card .kv{ grid-template-columns: 1fr; }
}



