/*
Theme Name: Open Pattern Tech Group
Theme URI: https://openpatterntech.com
Author: Open Pattern Tech Group
Description: Modern IT Solutions & Technology Services Theme
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: open-pattern-tech
*/

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;700&family=IBM+Plex+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --green: #00FF88;
  --green-dim: #00CC6A;
  --orange: #FF6B35;
  --bg: #0A0A0A;
  --bg2: #111111;
  --bg3: #191919;
  --border: rgba(255,255,255,0.08);
  --white: #FFFFFF;
  --gray: #666666;
  --light: #CCCCCC;
  --font-mono: 'IBM Plex Mono', monospace;
  --font-sans: 'IBM Plex Sans', sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
body { font-family:var(--font-sans); background:var(--bg); color:var(--white); line-height:1.7; overflow-x:hidden; }

/* HEADER */
header { position:fixed; top:0; width:100%; z-index:1000; background:rgba(10,10,10,0.96); backdrop-filter:blur(10px); border-bottom:1px solid var(--border); padding:0 40px; }
.header-inner { display:flex; align-items:center; justify-content:space-between; max-width:1400px; margin:0 auto; height:72px; }
.logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.logo-icon { width:40px; height:40px; border:2px solid var(--green); border-radius:6px; display:flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-weight:700; font-size:14px; color:var(--green); }
.logo-text { font-family:var(--font-mono); font-weight:700; font-size:15px; color:var(--white); line-height:1.3; }
.logo-text span { display:block; font-size:9px; color:var(--green); letter-spacing:3px; font-weight:400; }
nav ul { list-style:none; display:flex; gap:4px; align-items:center; }
nav a { text-decoration:none; color:var(--light); font-size:13px; font-weight:500; padding:7px 14px; border-radius:4px; transition:all 0.2s; font-family:var(--font-mono); }
nav a:hover { color:var(--green); background:rgba(0,255,136,0.06); }
nav .cta-btn { background:var(--green); color:var(--bg) !important; padding:9px 20px; font-weight:700; }
nav .cta-btn:hover { background:var(--green-dim); transform:translateY(-1px); }

/* HERO */
.hero { min-height:100vh; display:flex; align-items:center; padding:120px 40px 80px; position:relative; overflow:hidden; }
.hero-bg { position:absolute; inset:0; background:repeating-linear-gradient(0deg, transparent, transparent 59px, rgba(0,255,136,0.04) 59px, rgba(0,255,136,0.04) 60px), repeating-linear-gradient(90deg, transparent, transparent 59px, rgba(0,255,136,0.04) 59px, rgba(0,255,136,0.04) 60px); }
.hero-content { max-width:1400px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; position:relative; z-index:1; }
.terminal-tag { font-family:var(--font-mono); font-size:13px; color:var(--green); margin-bottom:20px; background:rgba(0,255,136,0.06); border:1px solid rgba(0,255,136,0.2); padding:8px 16px; border-radius:4px; display:inline-block; }
.terminal-tag::before { content:'$ '; color:var(--gray); }
.hero h1 { font-family:var(--font-sans); font-size:clamp(36px,4.5vw,64px); font-weight:700; line-height:1.15; margin-bottom:20px; }
.hero h1 .accent { color:var(--green); }
.hero p { font-size:16px; color:var(--gray); margin-bottom:36px; max-width:520px; line-height:1.8; }
.btn-group { display:flex; gap:14px; flex-wrap:wrap; }
.btn-primary { background:var(--green); color:var(--bg); padding:13px 28px; border-radius:4px; text-decoration:none; font-weight:700; font-size:13px; font-family:var(--font-mono); letter-spacing:0.5px; transition:all 0.2s; display:inline-block; }
.btn-primary:hover { background:var(--green-dim); transform:translateY(-2px); box-shadow:0 8px 25px rgba(0,255,136,0.25); }
.btn-secondary { border:1px solid rgba(0,255,136,0.3); color:var(--green); padding:13px 28px; border-radius:4px; text-decoration:none; font-weight:500; font-size:13px; font-family:var(--font-mono); transition:all 0.2s; display:inline-block; }
.btn-secondary:hover { background:rgba(0,255,136,0.06); }

/* CODE BLOCK */
.code-block { background:var(--bg2); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.code-header { background:var(--bg3); padding:12px 20px; display:flex; gap:8px; border-bottom:1px solid var(--border); }
.code-dot { width:12px; height:12px; border-radius:50%; }
.code-dot:nth-child(1){background:#FF5F56} .code-dot:nth-child(2){background:#FFBD2E} .code-dot:nth-child(3){background:#27C93F}
.code-body { padding:24px; font-family:var(--font-mono); font-size:13px; line-height:1.8; }
.code-comment { color:#555; }
.code-keyword { color:var(--orange); }
.code-string { color:#98C379; }
.code-function { color:var(--green); }
.code-var { color:#61AFEF; }

/* SECTIONS */
section { padding:100px 40px; }
.section-inner { max-width:1400px; margin:0 auto; }
.section-label { font-family:var(--font-mono); font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--green); font-weight:500; margin-bottom:14px; }
.section-label::before { content:'// '; color:var(--gray); }
.section-title { font-family:var(--font-sans); font-size:clamp(28px,3.5vw,48px); font-weight:700; line-height:1.2; margin-bottom:16px; }
.section-subtitle { font-size:16px; color:var(--gray); max-width:580px; margin-bottom:56px; line-height:1.8; }

/* SERVICES */
.services-bg { background:var(--bg2); }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.service-card { background:var(--bg2); padding:36px 28px; transition:all 0.3s; position:relative; }
.service-card:hover { background:var(--bg3); }
.service-card::before { content:attr(data-num); position:absolute; top:16px; right:20px; font-family:var(--font-mono); font-size:11px; color:var(--gray); }
.service-icon { width:40px; height:40px; border:1px solid var(--border); border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:18px; margin-bottom:20px; }
.service-card h3 { font-family:var(--font-mono); font-size:15px; font-weight:700; margin-bottom:10px; color:var(--white); }
.service-card p { font-size:13px; color:var(--gray); line-height:1.7; }
.service-tag { display:inline-block; margin-top:14px; font-family:var(--font-mono); font-size:11px; color:var(--green); }

/* STATS */
.stats-section { background:var(--bg3); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; background:var(--border); }
.stat-item { background:var(--bg3); padding:40px; text-align:center; }
.stat-item .num { font-family:var(--font-mono); font-size:48px; font-weight:700; color:var(--green); line-height:1; }
.stat-item .lbl { font-size:13px; color:var(--gray); margin-top:8px; font-family:var(--font-mono); }

/* TECH STACK */
.tech-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:12px; }
.tech-item { background:var(--bg3); border:1px solid var(--border); border-radius:6px; padding:20px; text-align:center; transition:all 0.2s; }
.tech-item:hover { border-color:rgba(0,255,136,0.3); transform:translateY(-3px); }
.tech-item .icon { font-size:28px; margin-bottom:8px; }
.tech-item .name { font-family:var(--font-mono); font-size:11px; color:var(--gray); }

/* CONTACT */
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:80px; }
.contact-info h2 { font-size:36px; font-weight:700; margin-bottom:20px; font-family:var(--font-sans); }
.contact-detail { display:flex; gap:16px; align-items:flex-start; margin-bottom:24px; }
.contact-icon { width:40px; height:40px; background:rgba(0,255,136,0.06); border:1px solid rgba(0,255,136,0.2); border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.contact-detail h4 { font-family:var(--font-mono); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--green); margin-bottom:4px; }
.contact-detail p { color:var(--light); font-size:14px; }
.contact-form { background:var(--bg2); border:1px solid var(--border); padding:48px; border-radius:8px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-family:var(--font-mono); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--gray); margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea { width:100%; background:rgba(255,255,255,0.03); border:1px solid var(--border); color:var(--white); padding:12px 16px; border-radius:4px; font-size:13px; font-family:var(--font-mono); transition:border-color 0.2s; outline:none; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--green); }
.form-group textarea { height:110px; resize:vertical; }
.form-group select option { background:var(--bg3); }

/* PAGE BANNER */
.page-banner { background:var(--bg2); padding:160px 40px 80px; border-bottom:1px solid var(--border); position:relative; overflow:hidden; }
.page-banner::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(90deg, transparent, transparent 59px, rgba(0,255,136,0.03) 59px, rgba(0,255,136,0.03) 60px); }
.page-banner h1 { font-size:clamp(36px,5vw,64px); font-weight:700; font-family:var(--font-sans); margin-bottom:14px; position:relative; }
.breadcrumb { display:flex; gap:8px; font-family:var(--font-mono); font-size:13px; color:var(--gray); position:relative; }
.breadcrumb a { color:var(--green); text-decoration:none; }

/* FOOTER */
footer { background:var(--bg); border-top:1px solid var(--border); padding:80px 40px 40px; }
.footer-inner { max-width:1400px; margin:0 auto; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:60px; margin-bottom:60px; }
.footer-brand p { color:var(--gray); font-size:13px; line-height:1.7; margin-top:16px; margin-bottom:24px; }
.footer-col h4 { font-family:var(--font-mono); font-size:11px; text-transform:uppercase; letter-spacing:2px; color:var(--green); font-weight:500; margin-bottom:20px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:10px; }
.footer-col a { color:var(--gray); text-decoration:none; font-size:13px; transition:color 0.2s; font-family:var(--font-mono); }
.footer-col a:hover { color:var(--green); }
.footer-bottom { padding-top:40px; border-top:1px solid var(--border); display:flex; justify-content:space-between; align-items:center; }
.footer-bottom p { color:rgba(255,255,255,0.3); font-size:12px; font-family:var(--font-mono); }

/* CAREERS */
.job-listing { background:var(--bg2); border:1px solid var(--border); padding:24px 28px; border-radius:6px; display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; transition:all 0.2s; }
.job-listing:hover { border-color:rgba(0,255,136,0.3); }
.job-listing h3 { font-family:var(--font-mono); font-size:16px; margin-bottom:8px; }
.job-tags { display:flex; gap:6px; flex-wrap:wrap; }
.job-tag { background:rgba(0,255,136,0.06); color:var(--green); padding:3px 10px; border-radius:3px; font-size:10px; font-weight:500; border:1px solid rgba(0,255,136,0.15); font-family:var(--font-mono); }

/* CTA */
.cta-banner { background:var(--bg2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); padding:80px 40px; text-align:center; position:relative; overflow:hidden; }
.cta-banner::before { content:''; position:absolute; inset:0; background:radial-gradient(circle at center, rgba(0,255,136,0.05) 0%, transparent 70%); }
.cta-banner h2 { font-size:clamp(26px,4vw,48px); font-weight:700; margin-bottom:14px; position:relative; }
.cta-banner p { font-size:16px; color:var(--gray); margin-bottom:36px; max-width:560px; margin-left:auto; margin-right:auto; position:relative; }

@media(max-width:1024px) { .services-grid { grid-template-columns:1fr 1fr; } .tech-grid { grid-template-columns:repeat(3,1fr); } .hero-content,.contact-grid { grid-template-columns:1fr; gap:40px; } .stats-grid { grid-template-columns:1fr 1fr; } .footer-grid { grid-template-columns:1fr 1fr; } }
@media(max-width:768px) { section { padding:60px 20px; } .services-grid,.stats-grid,.tech-grid { grid-template-columns:1fr; } nav ul { display:none; } .footer-grid { grid-template-columns:1fr; } .contact-form { padding:24px; } .form-row { grid-template-columns:1fr; } }
