/* ═══════════════════════════════════════════════
   M GLOBAL INFOTECH — SHARED DESIGN SYSTEM
   Used by all pages
═══════════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  --bg-base:    #0e0f11;
  --bg-raised:  #141618;
  --bg-card:    #1a1c1f;
  --bg-inset:   #111315;
  --bg-hover:   #1f2124;
  --border:       rgba(255,255,255,0.07);
  --border-light: rgba(255,255,255,0.12);
  --border-focus: rgba(79,142,247,0.5);
  --text-primary:   #f0f0ee;
  --text-secondary: #9a9b9d;
  --text-tertiary:  #5a5b5d;
  --accent:       #4f8ef7;
  --accent-light: #7aaaf9;
  --accent-glow:  rgba(79,142,247,0.15);
  --accent-dim:   rgba(79,142,247,0.08);
  --green:      #34c97a;
  --green-dim:  rgba(52,201,122,0.1);
  --font-display: 'Bricolage Grotesque', sans-serif;
  --font-body:    'Instrument Sans', sans-serif;
  --nav-h:   68px;
  --max-w:   1200px;
  --section: 96px;
  --gutter:  64px;
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px; --r-xl: 24px;
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);font-size:16px;line-height:1.6;background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:rgba(79,142,247,0.25)}

/* ── LAYOUT ── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter)}
.section-wrap{padding:var(--section) 0}

/* ── TYPOGRAPHY ── */
.eyebrow{font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-light);display:inline-block;margin-bottom:16px}
h1,h2,h3,h4{font-family:var(--font-display);letter-spacing:-.02em;line-height:1.08;color:var(--text-primary)}
.display-xl{font-size:clamp(44px,5.5vw,80px);font-weight:800;letter-spacing:-.03em;line-height:1.02}
.display-lg{font-size:clamp(36px,4vw,60px);font-weight:700;letter-spacing:-.025em;line-height:1.06}
.display-md{font-size:clamp(26px,2.5vw,38px);font-weight:700;letter-spacing:-.02em}
.display-sm{font-size:clamp(20px,2vw,26px);font-weight:700;letter-spacing:-.015em}
.body-lg{font-family:var(--font-body);font-size:18px;font-weight:400;line-height:1.75;color:var(--text-secondary)}
.body-md{font-family:var(--font-body);font-size:15px;font-weight:400;line-height:1.7;color:var(--text-secondary)}
.body-sm{font-family:var(--font-body);font-size:14px;line-height:1.65;color:var(--text-secondary)}
.label{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-tertiary);letter-spacing:.04em}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-size:14px;font-weight:600;padding:13px 26px;border-radius:var(--r-md);border:none;transition:all .18s ease;white-space:nowrap;text-decoration:none;cursor:pointer;line-height:1}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3),0 0 0 1px rgba(79,142,247,.3)}
.btn-primary:hover{background:var(--accent-light);box-shadow:0 4px 16px rgba(79,142,247,.35);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:var(--text-primary);border:1px solid var(--border-light)}
.btn-secondary:hover{background:var(--bg-hover);border-color:rgba(255,255,255,.2)}
.btn-lg{font-size:15px;padding:15px 32px}
.btn-sm{font-size:13px;padding:9px 20px}
.btn .arrow{transition:transform .18s ease;display:inline-block}
.btn:hover .arrow{transform:translateX(3px)}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:900;background:rgba(14,15,17,.88);backdrop-filter:blur(20px) saturate(1.4);-webkit-backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid var(--border);transition:border-color .2s}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--gutter);height:100%;display:flex;align-items:center;justify-content:space-between;gap:40px}
.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.nav-logo-mark{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:16px;font-weight:800;color:#fff;flex-shrink:0}
.nav-logo-text{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}
.nav-logo-text span{color:var(--accent-light)}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none;flex:1;justify-content:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--text-secondary);padding:7px 14px;border-radius:var(--r-sm);transition:color .15s,background .15s;text-decoration:none}
.nav-links a:hover,.nav-links a.active{color:var(--text-primary);background:var(--bg-hover)}
.nav-right{display:flex;align-items:center;gap:12px;flex-shrink:0}
.nav-mobile-btn{display:none;background:none;border:none;color:var(--text-secondary);padding:6px;cursor:pointer}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--bg-raised);border-bottom:1px solid var(--border);padding:16px 24px;z-index:899;flex-direction:column;gap:4px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:15px;font-weight:500;color:var(--text-secondary);padding:12px 16px;border-radius:var(--r-md);display:block;text-decoration:none;transition:background .15s,color .15s}
.mobile-menu a:hover{background:var(--bg-hover);color:var(--text-primary)}
.mobile-menu-divider{height:1px;background:var(--border);margin:8px 0}

/* ── PAGE HERO (inner pages) ── */
.page-hero{padding:calc(var(--nav-h) + 72px) 0 72px;background:var(--bg-raised);border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:900px;height:600px;background:radial-gradient(ellipse at center,rgba(79,142,247,.06) 0%,transparent 65%);pointer-events:none}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-tertiary);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:var(--text-tertiary);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:var(--text-secondary)}
.breadcrumb-sep{color:var(--text-tertiary);opacity:.4}

/* ── SECTION HEADERS ── */
.section-header{margin-bottom:52px}
.section-header.centered{text-align:center}
.section-header.split{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end}
.section-header .section-lead{font-size:17px;line-height:1.7;color:var(--text-secondary);max-width:480px}
.section-header.centered .section-lead{margin:0 auto}

/* ── CARDS ── */
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 26px;transition:border-color .2s,background .2s}
.card:hover{border-color:var(--border-light);background:var(--bg-hover)}
.card-top-accent{position:relative;overflow:hidden}
.card-top-accent::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s ease}
.card-top-accent:hover::before{transform:scaleX(1)}

/* ── TAGS / PILLS ── */
.tag{font-size:11px;font-weight:500;color:var(--text-tertiary);background:var(--bg-inset);border:1px solid var(--border);padding:4px 10px;border-radius:100px;letter-spacing:.02em}
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;border-radius:100px;padding:4px 12px}
.badge-blue{color:var(--accent-light);background:var(--accent-dim);border:1px solid rgba(79,142,247,.15)}
.badge-green{color:var(--green);background:var(--green-dim);border:1px solid rgba(52,201,122,.15)}

/* ── FORM ELEMENTS ── */
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-label{font-size:13px;font-weight:600;color:var(--text-secondary)}
.form-input,.form-select,.form-textarea{width:100%;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);font-family:var(--font-body);font-size:15px;padding:12px 16px;outline:none;transition:border-color .15s,box-shadow .15s;appearance:none}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px rgba(99,179,237,.08)}
.form-select{cursor:pointer}
.form-select option{background:var(--bg-card);color:var(--text-primary)}
.form-textarea{resize:vertical;min-height:110px;line-height:1.6}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-error{font-size:12px;color:#f87171;margin-top:4px;display:none}
.form-error.show{display:block}
.form-success{background:var(--green-dim);border:1px solid rgba(52,201,122,.3);border-radius:var(--r-md);padding:16px 20px;font-size:15px;color:var(--green);display:none;align-items:center;gap:10px;margin-top:16px}
.form-success.show{display:flex}

/* ── CTA BANNER ── */
.cta-banner{background:var(--bg-raised);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:72px 0;text-align:center}
.cta-banner h2{margin-bottom:16px}
.cta-banner p{color:var(--text-secondary);font-size:17px;max-width:520px;margin:0 auto 32px}
.cta-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── FOOTER ── */
.footer{background:var(--bg-inset);border-top:1px solid var(--border)}
.footer-main{padding:56px 0 48px;display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px}
.footer-logo-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-tagline{font-size:14px;line-height:1.7;color:var(--text-tertiary);max-width:280px;margin-bottom:24px}
.footer-col-title{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-links a{font-size:14px;color:var(--text-tertiary);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:var(--text-primary)}
.footer-bottom{border-top:1px solid var(--border);padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.footer-copy{font-size:13px;color:var(--text-tertiary)}
.footer-badge{font-size:12px;font-weight:600;color:var(--accent-light);background:var(--accent-dim);border:1px solid rgba(79,142,247,.15);border-radius:100px;padding:5px 14px}

/* ── CHAT WIDGET ── */
.chat-widget{position:fixed;bottom:28px;right:28px;z-index:800;display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.chat-fab{width:52px;height:52px;background:var(--accent);border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 16px rgba(79,142,247,.4),0 1px 4px rgba(0,0,0,.3);transition:transform .18s,box-shadow .18s;flex-shrink:0}
.chat-fab:hover{transform:scale(1.07);box-shadow:0 6px 24px rgba(79,142,247,.5)}
.chat-fab.open{background:var(--bg-hover);box-shadow:none}
.chat-window{display:none;flex-direction:column;width:360px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.chat-window.open{display:flex}
.chat-head{background:var(--bg-raised);padding:16px 18px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.chat-head-left{display:flex;align-items:center;gap:12px}
.chat-avatar{width:36px;height:36px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:15px;font-weight:800;color:#fff}
.chat-agent-name{font-size:14px;font-weight:600;color:var(--text-primary)}
.chat-agent-status{font-size:12px;color:var(--green);display:flex;align-items:center;gap:5px}
.chat-close-btn{background:none;border:none;color:var(--text-tertiary);font-size:18px;cursor:pointer;padding:4px;border-radius:var(--r-sm);transition:color .15s,background .15s;line-height:1}
.chat-close-btn:hover{color:var(--text-primary);background:var(--bg-hover)}
.chat-messages{padding:16px;height:260px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth}
.chat-msg{max-width:82%}
.chat-msg.bot{align-self:flex-start}.chat-msg.user{align-self:flex-end}
.chat-bubble{padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.55;font-family:var(--font-body)}
.chat-msg.bot .chat-bubble{background:var(--bg-raised);color:var(--text-secondary);border:1px solid var(--border);border-bottom-left-radius:4px}
.chat-msg.user .chat-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.chat-typing{align-self:flex-start;background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;border-bottom-left-radius:4px;padding:12px 16px;display:none}
.chat-typing.show{display:flex;gap:4px;align-items:center}
.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);animation:typingBounce 1.2s infinite}
.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
.quick-replies{padding:0 16px 12px;display:flex;flex-wrap:wrap;gap:7px}
.quick-btn{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--accent-light);border:1px solid rgba(79,142,247,.25);background:var(--accent-dim);border-radius:100px;padding:6px 14px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.quick-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.chat-input-row{border-top:1px solid var(--border);display:flex;padding:10px 12px;gap:8px;align-items:center;background:var(--bg-raised)}
.chat-text-input{flex:1;border:none;outline:none;background:transparent;font-family:var(--font-body);font-size:14px;color:var(--text-primary)}
.chat-text-input::placeholder{color:var(--text-tertiary)}
.chat-send-btn{width:32px;height:32px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
.chat-send-btn:hover{background:var(--accent-light)}
.live-dot{width:5px;height:5px;border-radius:50%;background:var(--green);animation:dotPulse 2s infinite;flex-shrink:0}
@keyframes dotPulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}.reveal-d5{transition-delay:.4s}

/* ── TICKER ── */
.ticker-bar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:16px 0;overflow:hidden;background:var(--bg-raised)}
.ticker-wrap{display:flex;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,black 8%,black 92%,transparent 100%)}
.ticker-track{display:flex;gap:48px;animation:ticker 28s linear infinite;white-space:nowrap;align-items:center}
.ticker-item{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;color:var(--text-tertiary);flex-shrink:0}
.ticker-item::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--text-tertiary);opacity:.5;flex-shrink:0}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  :root{--gutter:40px}
  .nav-links{display:none}
  .nav-mobile-btn{display:flex;align-items:center;justify-content:center}
  .footer-main{grid-template-columns:1fr 1fr;gap:32px}
  .section-header.split{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
}
@media(max-width:720px){
  :root{--gutter:20px;--section:64px}
  .footer-main{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .chat-widget{right:16px;bottom:16px}
  .chat-window{width:calc(100vw - 32px)}
  .cta-actions{flex-direction:column;align-items:center}
}
