/* =========================================
   7DEGREE MARKETING PRO — v2
   Dark Corporate Editorial — Mobile First
   ========================================= */

:root {
  --black:    #080A0F;
  --dark:     #0D1018;
  --dark2:    #131720;
  --dark3:    #1A1F2E;
  --dark4:    #222838;
  --white:    #FFFFFF;
  --off:      #E8E4DC;
  --gold:     #D4A843;
  --gold2:    #F0C96A;
  --gold-bg:  rgba(212,168,67,0.08);
  --gold-br:  rgba(212,168,67,0.25);
  --muted:    #6B7280;
  --muted2:   #9CA3AF;
  --border:   rgba(255,255,255,0.06);
  --border2:  rgba(255,255,255,0.1);
  --red:      #E84040;
  --ff-head:  'Syne', sans-serif;
  --ff-body:  'Inter', sans-serif;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  background: var(--black);
  color: var(--off);
  font-family: var(--ff-body);
  font-size: 15px;
  line-height: 1.75;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; transition:color .2s; }
ul { list-style:none; }
button { cursor:pointer; border:none; background:none; font-family:var(--ff-body); }

/* ---- TYPOGRAPHY ---- */
h1,h2,h3,h4 { font-family:var(--ff-head); line-height:1.1; color:var(--white); }
h1 { font-size:clamp(36px,6.5vw,76px); font-weight:800; letter-spacing:-1.5px; }
h2 { font-size:clamp(28px,4.5vw,56px); font-weight:700; letter-spacing:-1px; }
h3 { font-size:clamp(18px,2.5vw,26px); font-weight:600; letter-spacing:-.3px; }
h4 { font-size:15px; font-weight:600; letter-spacing:.5px; }
.eyebrow {
  font-family: var(--ff-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 16px;
  display: block;
}
.lead { font-size:17px; font-weight:300; color:var(--muted2); line-height:1.8; }

/* ---- LAYOUT ---- */
.wrap { width:100%; max-width:1280px; margin:0 auto; padding:0 24px; }
@media(min-width:768px){ .wrap{ padding:0 48px; } }
@media(min-width:1100px){ .wrap{ padding:0 64px; } }

/* ---- BUTTONS ---- */
.btn {
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--ff-body); font-size:13px; font-weight:500;
  letter-spacing:.5px; padding:14px 28px; transition:all .25s;
  white-space:nowrap;
}
.btn-primary { background:var(--gold); color:#080A0F; }
.btn-primary:hover { background:var(--gold2); color:#080A0F; }
.btn-primary .arr { transition:transform .2s; }
.btn-primary:hover .arr { transform:translateX(4px); }
.btn-ghost { background:transparent; color:var(--white); border:1px solid var(--border2); }
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); }
.btn-lg { padding:17px 36px; font-size:14px; }
.btn-full { width:100%; justify-content:center; }

/* ============================
   HEADER
   ============================ */
#hdr {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  transition: background .3s, border-color .3s;
}
#hdr.scrolled {
  background: rgba(8,10,15,0.96);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
}
.hdr-inner {
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.logo {
  font-family:var(--ff-head); font-size:22px; font-weight:800;
  color:var(--white); letter-spacing:-0.5px;
}
.logo span { color:var(--gold); }
.logo sub {
  display:block; font-family:var(--ff-body); font-size:9px;
  font-weight:400; letter-spacing:3.5px; text-transform:uppercase;
  color:var(--muted); margin-top:2px; vertical-align:baseline;
}
.nav-links {
  display:none; align-items:center; gap:40px;
}
@media(min-width:960px){ .nav-links{ display:flex; } }
.nav-links a {
  font-size:13px; font-weight:400; letter-spacing:.3px;
  color:var(--muted2); transition:color .2s;
}
.nav-links a:hover { color:var(--white); }
.nav-right { display:flex; align-items:center; gap:16px; }
.nav-right .btn { display:none; }
@media(min-width:960px){ .nav-right .btn{ display:inline-flex; } }
.hbg {
  display:flex; flex-direction:column; gap:5px; padding:6px;
}
@media(min-width:960px){ .hbg{ display:none; } }
.hbg span { display:block; width:22px; height:1.5px; background:var(--white); transition:all .3s; }
.hbg.on span:nth-child(1){ transform:rotate(45deg) translate(4.5px,4.5px); }
.hbg.on span:nth-child(2){ opacity:0; transform:scaleX(0); }
.hbg.on span:nth-child(3){ transform:rotate(-45deg) translate(4.5px,-4.5px); }
.mob-nav {
  display:none; flex-direction:column;
  background:var(--dark); border-top:1px solid var(--border);
  padding:24px;
}
.mob-nav.on { display:flex; }
.mob-nav a {
  font-size:15px; color:var(--muted2); padding:14px 0;
  border-bottom:1px solid var(--border); transition:color .2s;
}
.mob-nav a:hover { color:var(--gold); }
.mob-nav .btn { margin-top:20px; text-align:center; justify-content:center; }

/* ============================
   HERO
   ============================ */
.hero {
  padding: 160px 0 100px;
  position:relative; overflow:hidden;
  min-height: 100vh;
  display:flex; align-items:center;
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background: linear-gradient(135deg, #080A0F 0%, #0D1220 50%, #080A0F 100%);
}
.hero-bg::before {
  content:''; position:absolute;
  top:-20%; right:-10%; width:70vw; height:70vw; max-width:900px; max-height:900px;
  background: radial-gradient(ellipse at center, rgba(212,168,67,0.07) 0%, transparent 60%);
}
.hero-bg::after {
  content:''; position:absolute;
  bottom:-20%; left:-10%; width:50vw; height:50vw; max-width:700px; max-height:700px;
  background: radial-gradient(ellipse at center, rgba(100,140,255,0.04) 0%, transparent 60%);
}
/* Animated grid lines */
.hero-grid {
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
}
.hero-content { position:relative; z-index:1; max-width:900px; }
.hero-badge {
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold-br);
  padding:8px 18px; margin-bottom:32px;
}
.hero-badge::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--gold); animation:blink 2s infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.hero h1 { margin-bottom:28px; }
.hero h1 .line2 { color:var(--gold); display:block; }
.hero .lead { max-width:580px; margin-bottom:44px; }
.hero-btns { display:flex; flex-wrap:wrap; gap:14px; margin-bottom:72px; }
.hero-clients {
  display:flex; align-items:center; gap:20px; flex-wrap:wrap;
}
.hero-clients span { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); }
.client-logos { display:flex; align-items:center; gap:28px; flex-wrap:wrap; }
.client-logo {
  font-family:var(--ff-head); font-size:13px; font-weight:700;
  color:var(--muted); letter-spacing:.5px; opacity:.5;
  transition:opacity .2s;
}
.client-logo:hover { opacity:.9; }

/* ============================
   NUMBERS / STATS
   ============================ */
.stats-strip {
  background:var(--dark2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.stats-inner {
  display:grid;
  grid-template-columns: repeat(2,1fr);
  gap:1px; background:var(--border);
}
@media(min-width:640px){ .stats-inner{ grid-template-columns:repeat(4,1fr); } }
.stat-cell {
  background:var(--dark2); padding:44px 32px;
  position:relative; overflow:hidden;
  transition: background .25s;
}
.stat-cell:hover { background:var(--dark3); }
.stat-cell::before {
  content:''; position:absolute; top:0; left:0;
  width:2px; height:0; background:var(--gold);
  transition:height .4s;
}
.stat-cell:hover::before { height:100%; }
.stat-n {
  font-family:var(--ff-head); font-size:clamp(36px,4vw,52px);
  font-weight:800; color:var(--white); line-height:1;
  margin-bottom:8px; letter-spacing:-1px;
}
.stat-n span { color:var(--gold); }
.stat-l {
  font-size:12px; letter-spacing:2px; text-transform:uppercase;
  color:var(--muted); font-weight:400;
}

/* ============================
   SERVICES
   ============================ */
.services-sec { padding:120px 0; }
.sec-head {
  display:flex; flex-direction:column; gap:24px;
  margin-bottom:64px;
}
@media(min-width:768px){
  .sec-head{ flex-direction:row; align-items:flex-end; justify-content:space-between; }
}
.sec-head h2 { max-width:500px; }
.sec-head p { max-width:360px; color:var(--muted2); font-weight:300; font-size:15px; line-height:1.8; }
.services-grid {
  display:grid;
  grid-template-columns:1fr;
  gap:1px; background:var(--border);
}
@media(min-width:640px){ .services-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .services-grid{ grid-template-columns:repeat(3,1fr); } }
.srv-card {
  background:var(--dark); padding:44px 36px;
  position:relative; overflow:hidden;
  transition: background .3s;
  cursor:pointer;
}
.srv-card:hover { background:var(--dark2); }
.srv-card::after {
  content:''; position:absolute;
  bottom:0; left:0; right:0; height:2px;
  background:var(--gold); transform:scaleX(0); transform-origin:left;
  transition:transform .35s ease;
}
.srv-card:hover::after { transform:scaleX(1); }
.srv-num {
  font-family:var(--ff-head); font-size:11px; font-weight:700;
  letter-spacing:3px; color:var(--muted); margin-bottom:32px;
}
.srv-icon {
  width:56px; height:56px; margin-bottom:28px;
  border:1px solid var(--border2); display:flex; align-items:center; justify-content:center;
  font-size:24px; color:var(--gold); transition:border-color .25s, background .25s;
}
.srv-card:hover .srv-icon { border-color:var(--gold-br); background:var(--gold-bg); }
.srv-card h3 { font-size:20px; margin-bottom:14px; }
.srv-card p { font-size:14px; color:var(--muted2); font-weight:300; line-height:1.8; margin-bottom:28px; }
.srv-arr {
  font-size:20px; color:var(--gold); display:inline-block;
  transition:transform .25s;
}
.srv-card:hover .srv-arr { transform:translate(6px,-6px); }

/* ============================
   MARQUEE / TICKER
   ============================ */
.ticker {
  background:var(--gold); padding:14px 0; overflow:hidden;
  white-space:nowrap;
}
.ticker-inner {
  display:inline-flex; gap:0; animation:tick 30s linear infinite;
}
@keyframes tick { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.ticker-item {
  font-family:var(--ff-head); font-size:13px; font-weight:700;
  letter-spacing:1px; text-transform:uppercase; color:#080A0F;
  padding:0 32px; display:inline-flex; align-items:center; gap:16px;
}
.ticker-item::after { content:'◆'; font-size:8px; }

/* ============================
   ABOUT / WHY
   ============================ */
.about-sec {
  padding:120px 0;
  background:var(--dark2);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.about-grid {
  display:grid; grid-template-columns:1fr; gap:64px;
}
@media(min-width:900px){ .about-grid{ grid-template-columns:1fr 1fr; align-items:start; } }
.about-left h2 { margin-bottom:24px; }
.about-left p { color:var(--muted2); font-weight:300; font-size:15px; line-height:1.85; margin-bottom:16px; }
.about-left .btn { margin-top:20px; }
.about-right {}
.why-list { display:flex; flex-direction:column; gap:0; }
.why-row {
  display:flex; gap:24px; padding:28px 0;
  border-bottom:1px solid var(--border);
  align-items:flex-start;
}
.why-row:first-child { border-top:1px solid var(--border); }
.why-icon {
  width:44px; height:44px; flex-shrink:0;
  border:1px solid var(--border2); display:flex;
  align-items:center; justify-content:center;
  font-size:18px; color:var(--gold); margin-top:2px;
}
.why-row h4 { margin-bottom:6px; color:var(--white); font-size:15px; }
.why-row p { font-size:13px; color:var(--muted); font-weight:300; line-height:1.75; margin:0; }

/* ============================
   PROCESS
   ============================ */
.process-sec { padding:120px 0; }
.process-grid {
  display:grid; grid-template-columns:1fr; gap:0;
  margin-top:64px; background:var(--border);
}
@media(min-width:768px){ .process-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .process-grid{ grid-template-columns:repeat(4,1fr); } }
.p-step {
  background:var(--dark); padding:48px 36px;
  border:1px solid transparent; transition:background .25s;
}
.p-step:hover { background:var(--dark2); }
.p-step-n {
  font-family:var(--ff-head); font-size:64px; font-weight:800;
  color:rgba(212,168,67,0.08); line-height:1; margin-bottom:24px;
  letter-spacing:-2px;
}
.p-step h4 { font-size:16px; margin-bottom:10px; color:var(--white); }
.p-step p { font-size:13px; color:var(--muted); font-weight:300; line-height:1.8; margin:0; }

/* ============================
   TESTIMONIALS
   ============================ */
.testi-sec {
  padding:120px 0;
  background:var(--dark2);
  border-top:1px solid var(--border);
}
.testi-grid {
  display:grid; grid-template-columns:1fr; gap:20px; margin-top:64px;
}
@media(min-width:768px){ .testi-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1100px){ .testi-grid{ grid-template-columns:repeat(3,1fr); } }
.testi-card {
  background:var(--dark3); border:1px solid var(--border);
  padding:40px; transition:border-color .25s;
}
.testi-card:hover { border-color:var(--gold-br); }
.testi-stars { color:var(--gold); font-size:13px; letter-spacing:3px; margin-bottom:20px; }
.testi-q {
  font-size:14px; color:var(--muted2); font-weight:300;
  line-height:1.9; font-style:italic; margin-bottom:28px;
}
.testi-q::before { content:'\201C'; color:var(--gold); font-size:28px; line-height:0; vertical-align:-10px; margin-right:4px; }
.testi-author { display:flex; align-items:center; gap:14px; }
.t-avatar {
  width:44px; height:44px; border-radius:50%;
  background:var(--gold-bg); border:1px solid var(--gold-br);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--ff-head); font-size:14px; font-weight:700; color:var(--gold);
  flex-shrink:0;
}
.t-name { font-size:13px; font-weight:500; color:var(--white); margin-bottom:2px; }
.t-role { font-size:11px; color:var(--muted); font-weight:300; }

/* ============================
   CTA BAND
   ============================ */
.cta-band {
  padding:120px 0;
  background:var(--dark3);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  position:relative; overflow:hidden;
  text-align:center;
}
.cta-band::before {
  content:''; position:absolute;
  top:50%; left:50%; transform:translate(-50%,-50%);
  width:800px; height:400px;
  background:radial-gradient(ellipse, rgba(212,168,67,0.06) 0%, transparent 65%);
  pointer-events:none;
}
.cta-band h2 { max-width:700px; margin:0 auto 20px; }
.cta-band p { color:var(--muted2); max-width:500px; margin:0 auto 44px; font-size:16px; font-weight:300; }
.cta-band .btn-row { display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* ============================
   CONTACT FORM
   ============================ */
.contact-sec { padding:120px 0; }
.contact-grid {
  display:grid; grid-template-columns:1fr; gap:80px;
}
@media(min-width:900px){ .contact-grid{ grid-template-columns:1fr 1fr; align-items:start; } }
.contact-left h2 { margin-bottom:20px; }
.contact-left p { color:var(--muted2); font-weight:300; line-height:1.85; margin-bottom:40px; }
.contact-info { display:flex; flex-direction:column; gap:20px; }
.ci-row { display:flex; align-items:center; gap:16px; }
.ci-icon {
  width:40px; height:40px; border:1px solid var(--border2);
  display:flex; align-items:center; justify-content:center;
  font-size:16px; color:var(--gold); flex-shrink:0;
}
.ci-label { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--muted); margin-bottom:2px; }
.ci-val { font-size:14px; color:var(--muted2); font-weight:300; }
.cf { display:flex; flex-direction:column; gap:14px; }
.cf-row { display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:480px){ .cf-row{ grid-template-columns:1fr 1fr; } }
.cf input, .cf textarea, .cf select {
  width:100%; background:var(--dark2); border:1px solid var(--border);
  color:var(--off); padding:14px 18px; font-size:14px; font-family:var(--ff-body);
  font-weight:300; outline:none; transition:border .2s; appearance:none;
  -webkit-appearance:none;
}
.cf input:focus, .cf textarea:focus, .cf select:focus { border-color:var(--gold); }
.cf input::placeholder, .cf textarea::placeholder { color:var(--muted); }
.cf textarea { resize:vertical; min-height:120px; }

/* ============================
   BLOG
   ============================ */
.blog-sec { padding:120px 0; background:var(--dark2); border-top:1px solid var(--border); }
.blog-grid {
  display:grid; grid-template-columns:1fr; gap:20px; margin-top:64px;
}
@media(min-width:640px){ .blog-grid{ grid-template-columns:repeat(2,1fr); } }
@media(min-width:1024px){ .blog-grid{ grid-template-columns:repeat(3,1fr); } }
.blog-card {
  background:var(--dark3); border:1px solid var(--border);
  overflow:hidden; transition:border-color .25s;
}
.blog-card:hover { border-color:var(--border2); }
.blog-img { height:220px; overflow:hidden; background:var(--dark4); }
.blog-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s; }
.blog-card:hover .blog-img img { transform:scale(1.04); }
.blog-body { padding:32px 28px; }
.blog-meta { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.blog-body h3 { font-size:18px; margin-bottom:10px; }
.blog-body h3 a { color:var(--white); transition:color .2s; }
.blog-body h3 a:hover { color:var(--gold); }
.blog-body p { font-size:13px; color:var(--muted); font-weight:300; line-height:1.8; margin-bottom:20px; }
.read-more {
  font-size:11px; letter-spacing:2px; text-transform:uppercase;
  color:var(--gold); font-weight:500; display:inline-flex; align-items:center; gap:8px;
}
.read-more::after { content:'→'; transition:transform .2s; }
.blog-card:hover .read-more::after { transform:translateX(4px); }

/* ============================
   FOOTER
   ============================ */
#footer {
  background:var(--dark); border-top:1px solid var(--border);
  padding:80px 0 0;
}
.footer-grid {
  display:grid; grid-template-columns:1fr; gap:48px;
  padding-bottom:64px; border-bottom:1px solid var(--border);
}
@media(min-width:768px){ .footer-grid{ grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; } }
.footer-brand .logo { display:block; margin-bottom:18px; font-size:20px; }
.footer-brand p { font-size:13px; color:var(--muted); font-weight:300; line-height:1.8; max-width:280px; margin-bottom:24px; }
.socials { display:flex; gap:10px; }
.soc {
  width:36px; height:36px; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; font-weight:600; color:var(--muted);
  transition:all .2s;
}
.soc:hover { border-color:var(--gold); color:var(--gold); }
.fc h5 {
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:var(--muted); margin-bottom:20px; font-family:var(--ff-body); font-weight:400;
}
.fc ul li { margin-bottom:10px; }
.fc ul li a { font-size:13px; color:var(--muted); font-weight:300; transition:color .2s; }
.fc ul li a:hover { color:var(--off); }
.footer-btm {
  display:flex; flex-direction:column; gap:12px;
  padding:24px 0; text-align:center;
}
@media(min-width:768px){ .footer-btm{ flex-direction:row; justify-content:space-between; text-align:left; } }
.footer-btm p, .footer-btm a { font-size:12px; color:var(--muted); font-weight:300; }
.footer-btm a:hover { color:var(--gold); }
.footer-btm-links { display:flex; gap:24px; justify-content:center; }
@media(min-width:768px){ .footer-btm-links{ justify-content:flex-start; } }

/* ============================
   SINGLE / PAGE
   ============================ */
.page-hero-sec {
  padding:160px 0 80px;
  background:var(--dark2); border-bottom:1px solid var(--border);
}
.content-wrap {
  max-width:800px; margin:0 auto; padding:80px 24px;
}
.content-wrap p { color:var(--muted2); font-weight:300; line-height:1.9; margin-bottom:1.5rem; }
.content-wrap h2 { margin:2.5rem 0 1rem; }
.content-wrap h3 { margin:2rem 0 .75rem; font-size:20px; }
.content-wrap ul, .content-wrap ol { padding-left:20px; color:var(--muted2); font-weight:300; line-height:1.9; margin-bottom:1.5rem; }
.content-wrap li { margin-bottom:.5rem; }
.content-wrap blockquote { border-left:2px solid var(--gold); padding:16px 24px; margin:2rem 0; background:var(--dark2); font-style:italic; color:var(--muted2); }

/* ============================
   UTILITIES
   ============================ */
.text-gold { color:var(--gold) !important; }
.text-center { text-align:center; }
.sr-only { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); }

/* ============================
   ANIMATIONS
   ============================ */
.reveal { opacity:0; transform:translateY(30px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-2 { transition-delay:.15s; }
.reveal-3 { transition-delay:.3s; }
.reveal-4 { transition-delay:.45s; }

/* ============================
   RESPONSIVE EXTRAS
   ============================ */
@media(max-width:480px){
  .hero { padding:130px 0 80px; }
  .hero-btns .btn { width:100%; justify-content:center; }
  .btn-lg { padding:15px 24px; }
}
