/* assets/styles.css - TRAXCORE responsive + Google Fonts & link polish */

/* --- Import Google Fonts --- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&family=Poppins:wght@600;700;800&display=swap');

/* --- Variables --- */
:root{
  --bg:#ffffff;
  --muted:#6b7280;
  --accent:#ff6a00;
  --dark:#05263d;
  --card:#f7f9fb;
  --radius:12px;
  --container:1100px;
  --font-title:'Poppins', sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
}

/* --- Reset / base --- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--dark);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
  -webkit-text-size-adjust:100%;
  font-size:15px;
}

a{
  color:var(--accent);
  text-decoration:none;
  transition:color .2s ease;
}
a:hover{color:#ff8533}

/* Ensure container never touches the edges */
.container{
  max-width:var(--container);
  margin:0 auto;
  padding-left:max(16px, env(safe-area-inset-left));
  padding-right:max(16px, env(safe-area-inset-right));
  padding-top:8px;
  padding-bottom:8px;
}

/* --- Header --- */
.site-header{
  background:linear-gradient(90deg,#04243b 0%, #073a50 100%);
  color:#fff;
  position:sticky;
  top:0;
  z-index:100;
  box-shadow:0 2px 8px rgba(3,12,21,0.06);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px}
.logo-box{width:44px;height:44px;background:var(--card);display:flex;align-items:center;justify-content:center;border-radius:10px;color:var(--dark);font-weight:800}
.brand-title{font-family:var(--font-title);font-weight:800;font-size:16px;letter-spacing:.5px}
.brand-sub{font-size:11px;color:#b9e3ff}

/* mobile nav toggle */
.nav-toggle{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  background:transparent;
  border:0;
  color:#fff;
  font-size:20px;
  padding:8px;
  border-radius:8px;
  cursor:pointer;
  transition:background .2s ease;
}
.nav-toggle:hover{background:rgba(255,255,255,0.08)}

/* main nav (mobile slide-in) */
.main-nav{
  position:fixed;
  top:0;right:-110%;
  height:100vh;
  width:88%;
  max-width:320px;
  background:linear-gradient(180deg,#073a50,#04243b);
  color:#fff;
  display:flex;
  flex-direction:column;
  padding:72px 18px;
  gap:16px;
  transition:right .28s cubic-bezier(.2,.9,.2,1);
  z-index:200;
}
.main-nav.open{right:0}
.main-nav a{
  color:#fff;
  font-weight:700;
  padding:10px;
  border-radius:8px;
  display:block;
  transition:background .2s;
}
.main-nav a:hover{background:rgba(255,255,255,0.08)}
.main-nav .lang-links{display:flex;gap:8px;margin-top:12px}
.main-nav .lang-links a{
  background:rgba(255,255,255,0.06);
  padding:6px 10px;
  border-radius:6px;
  color:#eaf8ff;
}

/* overlay behind menu */
.nav-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.4);opacity:0;visibility:hidden;transition:opacity .2s;
}
.nav-overlay.show{opacity:1;visibility:visible}

/* --- Hero --- */
.hero{
  display:flex;
  flex-direction:column;
  gap:18px;
  padding-top:18px;
  padding-bottom:18px;
}
.hero-title{
  font-family:var(--font-title);
  font-weight:700;
  font-size:clamp(18px, 4.2vw, 22px);
  margin:0;
  line-height:1.05;
}
.lead{
  color:var(--muted);
  margin:10px 0 12px;
  font-size:clamp(13px, 3.6vw, 15px);
}
.cta{display:flex;gap:10px;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:10px;
  font-weight:700;
  text-decoration:none;
  min-height:48px;
  box-shadow:0 1px 3px rgba(2,10,20,0.04);
  cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease;
}
.btn.primary{background:var(--accent);color:#fff;border:0}
.btn.primary:hover{transform:translateY(-1px);box-shadow:0 4px 10px rgba(255,106,0,0.3)}
.btn.outline{background:transparent;border:2px solid rgba(5,38,61,0.06);color:var(--dark)}
.btn.outline:hover{background:rgba(5,38,61,0.03)}

.pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.pill{
  background:#e9f5ff;
  padding:6px 10px;
  border-radius:999px;
  font-weight:700;
  color:#055;
  font-size:13px;
  display:inline-block;
}

/* hero right */
.hero-right{
  width:100%;
  background:linear-gradient(180deg,#fff,#f6f8fb);
  padding:16px;
  border-radius:12px;
  box-shadow:0 8px 20px rgba(3,12,21,0.06);
}
.contact-links{display:flex;flex-direction:column;gap:12px}
.contact-block{display:flex;gap:12px;align-items:flex-start}
.icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:800}
.icon.tel{background:#eaf6ff;color:#042}
.icon.mail{background:#fff4e6;color:#b03f00}
.socials{display:flex;gap:8px}

/* --- Services --- */
.services-grid{display:grid;grid-template-columns:1fr;gap:14px}
.card{
  background:var(--card);
  padding:14px;
  border-radius:12px;
  box-shadow:0 1px 4px rgba(3,12,21,0.04);
}
.card h3{
  margin:6px 0 8px;
  font-size:16px;
  font-family:var(--font-title);
  font-weight:600;
}
.card p{margin:0;color:var(--muted);font-size:14px}

/* features */
.features{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.feature{background:#fff;border:1px solid #e6eef6;padding:12px;border-radius:10px}

/* --- About --- */
.about-grid{display:grid;grid-template-columns:1fr;gap:12px}
.about-card{background:var(--card);padding:12px;border-radius:10px}

/* --- Contact --- */
.contact-form{display:grid;gap:12px}
.grid-2{display:grid;grid-template-columns:1fr;gap:10px}
label{display:block;margin-top:6px;font-weight:600}
input[type=text],input[type=email],textarea{
  width:100%;
  padding:12px;
  border-radius:10px;
  border:1px solid #d9e6ef;
  font-size:15px;
}
textarea{min-height:140px;resize:vertical}
.form-actions{display:flex;flex-direction:column;gap:10px}

/* --- Footer --- */
.site-footer{
  background:#071a24;
  color:#bcd6e9;
  padding:16px 0;
  margin-top:18px;
}
.footer-inner{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.footer-right{text-align:left}

/* --- Alerts --- */
.alert{padding:12px;border-radius:8px;margin-bottom:12px}
.alert.success{background:#dff7e6;border-left:4px solid #1aa05b}
.alert.error{background:#fdecea;border-left:4px solid #d64545}

/* --- Misc --- */
.micro{font-size:13px;color:var(--muted)}

/* --- Medium / Desktop breakpoints --- */
@media (min-width:721px){
  .container{padding-left:24px;padding-right:24px}
  .nav-toggle{display:none}
  .main-nav{
    position:static;
    height:auto;width:auto;
    background:transparent;
    flex-direction:row;
    padding:0;gap:12px;
    transition:none;right:auto;top:auto;
    display:flex;
    align-items:center;
  }
  .main-nav a{color:rgba(255,255,255,0.95);padding:8px}
  .main-nav .lang-links{margin-left:8px}

  .hero{flex-direction:row;gap:28px;padding:36px 0;align-items:flex-start}
  .hero-left{flex:1}
  .hero-right{width:340px;flex:0 0 340px;padding:18px}
  .services-grid{grid-template-columns:repeat(3,1fr)}
  .about-grid{grid-template-columns:repeat(3,1fr)}
  .grid-2{grid-template-columns:1fr 1fr}
  .form-actions{flex-direction:row;align-items:center}
  .footer-inner{flex-direction:row;align-items:center}
}

/* --- Larger desktop tweaks --- */
@media (min-width:1100px){
  .hero-title{font-size:28px}
  .container{padding-left:32px;padding-right:32px}
}

/* focus outlines */
a:focus,button:focus,input:focus,textarea:focus{
  outline:3px solid rgba(255,106,0,0.16);
  outline-offset:2px;
}
