/* =========================================================
   AJMX Ventures — South Florida Web Studio
   Display: Syne · Body: Manrope
   Accent: gold metallic gradient (star) + cool violet pop
   ========================================================= */

:root {
  /* Surfaces — near-black, faintly cool */
  --bg:        #08080c;
  --bg-2:      #0d0d14;
  --surface:   #121119;
  --surface-2: #17161f;

  /* Text */
  --text:      #f4f4f7;
  --text-mut:  #9a9aab;
  --text-dim:  #6b6b7a;

  /* Gold (the star) */
  --gold-1: #fbe7b0;
  --gold-2: #e9c25e;
  --gold-3: #c8881f;
  --gold-grad: linear-gradient(100deg, #fbe7b0 0%, #e9c25e 38%, #c8881f 100%);

  /* Cool pop (used sparingly) */
  --cool-1: #8ea2ff;
  --cool-2: #6d7bff;
  --dot-grad: linear-gradient(135deg, #f6d77a 0%, #c8881f 45%, #6d7bff 100%);

  /* Lines */
  --border:   rgba(255,255,255,0.09);
  --border-2: rgba(255,255,255,0.14);

  --maxw: 1180px;
  --radius: 16px;

  --font-display: "Syne", -apple-system, BlinkMacSystemFont, sans-serif;
  --font-body: "Manrope", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono: "Space Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

.grad {
  background: var(--gold-grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.skip-link {
  position: absolute; left: 16px; top: -48px; z-index: 200;
  background: var(--gold-2); color: #000; padding: 10px 16px; border-radius: 8px;
  font-weight: 700; transition: top .2s var(--ease);
}
.skip-link:focus { top: 16px; }

/* ---------- Ambient background ---------- */
.ambient { position: fixed; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }
.orb { position: absolute; border-radius: 50%; filter: blur(90px); opacity: 0.5; will-change: transform; }
.orb-gold {
  width: 60vw; height: 60vw; top: -18vw; left: -10vw;
  background: radial-gradient(circle at 40% 40%, rgba(233,194,94,0.55), rgba(200,136,31,0.15) 55%, transparent 70%);
  animation: drift1 26s var(--ease) infinite alternate;
}
.orb-cool {
  width: 48vw; height: 48vw; bottom: -16vw; right: -12vw;
  background: radial-gradient(circle at 50% 50%, rgba(109,123,255,0.4), rgba(109,123,255,0.08) 55%, transparent 70%);
  animation: drift2 32s var(--ease) infinite alternate;
}
.grain {
  position: absolute; inset: -50%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity: 0.04;
}
@keyframes drift1 { from { transform: translate3d(0,0,0) scale(1); } to { transform: translate3d(6vw,4vw,0) scale(1.15); } }
@keyframes drift2 { from { transform: translate3d(0,0,0) scale(1.1); } to { transform: translate3d(-5vw,-3vw,0) scale(1); } }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px; border-radius: 999px;
  font-family: var(--font-body); font-weight: 700; font-size: 0.95rem;
  letter-spacing: 0.01em; cursor: pointer; border: 1px solid transparent;
  transition: transform .25s var(--ease), background .25s var(--ease),
              border-color .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
}
.btn .dot {
  width: 9px; height: 9px; border-radius: 50%; background: var(--dot-grad);
  box-shadow: 0 0 10px rgba(233,194,94,0.7);
}
.btn-primary { background: var(--gold-grad); color: #1a1206; border-color: transparent; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 34px rgba(233,194,94,0.28); }
.btn-primary .dot { background: #1a1206; box-shadow: none; }
.btn-outline { background: transparent; color: var(--text); border-color: var(--border-2); }
.btn-outline:hover { border-color: var(--gold-2); color: #fff; transform: translateY(-2px); }
.btn-ghost { background: rgba(255,255,255,0.04); color: var(--text); border-color: var(--border); }
.btn-ghost:hover { background: rgba(255,255,255,0.08); transform: translateY(-2px); }
.btn-block { width: 100%; justify-content: center; padding: 16px; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(8,8,12,0.55);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid transparent;
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.site-header.scrolled { background: rgba(8,8,12,0.85); border-bottom-color: var(--border); }
.nav { display: flex; align-items: center; gap: 28px; height: 76px; }
.brand { display: flex; align-items: center; gap: 12px; flex: none; }
.brand-logo { width: 44px; height: 44px; object-fit: contain; }
.brand-name { font-family: var(--font-display); font-weight: 800; font-size: 1.15rem; letter-spacing: 0.02em; }
.brand-name em { font-style: normal; font-weight: 600; color: var(--text-mut); }
.nav-links { display: flex; gap: 30px; margin-left: auto; }
.nav-links a { color: var(--text-mut); font-weight: 500; font-size: 0.95rem; position: relative; transition: color .2s var(--ease); }
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: -6px; width: 0; height: 2px;
  background: var(--gold-grad); transition: width .25s var(--ease);
}
.nav-links a:hover { color: var(--text); }
.nav-links a:hover::after { width: 100%; }
.nav-cta { flex: none; }

/* Mobile menu button */
.menu-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; }
.menu-toggle span { width: 24px; height: 2px; background: var(--text); transition: transform .3s var(--ease), opacity .2s var(--ease); }
.menu-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-menu { display: none; flex-direction: column; gap: 4px; padding: 12px 28px 24px; border-bottom: 1px solid var(--border); background: rgba(8,8,12,0.97); }
.mobile-menu a { padding: 14px 4px; color: var(--text-mut); font-weight: 600; border-bottom: 1px solid var(--border); }
.mobile-menu a.btn { margin-top: 12px; border-bottom: none; justify-content: center; color: var(--text); }

/* ---------- Hero ---------- */
.hero { position: relative; padding: clamp(80px, 14vh, 160px) 0 90px; }
.hero-inner { max-width: 920px; }
.eyebrow {
  text-transform: uppercase; letter-spacing: 0.22em; font-size: 0.78rem; font-weight: 700;
  color: var(--gold-2); margin-bottom: 22px;
}
.hero-title {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(2.7rem, 8vw, 6.2rem); line-height: 0.98; letter-spacing: -0.02em;
  text-transform: uppercase; margin-bottom: 28px;
}
.hero-title .line { display: block; }
.hero-title .grad { background-size: 220% auto; animation: shimmer 7s linear infinite; }
@keyframes shimmer { from { background-position: 0% center; } to { background-position: -220% center; } }

/* Cinematic blur-in for the hero entrance */
.hero .reveal { filter: blur(9px); transition: opacity .9s var(--ease), transform .9s var(--ease), filter .9s var(--ease); }
.hero .reveal.in { filter: blur(0); }
.subhead { font-size: clamp(1.05rem, 2vw, 1.3rem); color: var(--text-mut); max-width: 620px; margin-bottom: 36px; }
.subhead strong { color: var(--text); font-weight: 700; }
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 64px; }

.hero-stats { list-style: none; display: flex; gap: 56px; flex-wrap: wrap; }
.hero-stats li { display: flex; flex-direction: column; }
.stat-num { font-family: var(--font-mono); font-weight: 700; font-size: clamp(1.9rem, 3.6vw, 2.6rem); line-height: 1; letter-spacing: -0.02em; }
.stat-label { color: var(--text-dim); font-size: 0.9rem; margin-top: 6px; }

/* ---------- Sections ---------- */
.section { padding: clamp(72px, 11vh, 130px) 0; position: relative; }
.section-alt { background: linear-gradient(180deg, transparent, rgba(13,13,20,0.6) 12%, rgba(13,13,20,0.6) 88%, transparent); }
.section-head { margin-bottom: 56px; }
.section-note { color: var(--text-mut); font-size: 1.02rem; max-width: 540px; margin-top: 16px; }
.section-title {
  font-family: var(--font-display); font-weight: 800; text-transform: uppercase;
  font-size: clamp(2rem, 5vw, 3.6rem); line-height: 1; letter-spacing: -0.01em; margin-top: 12px;
}

.grid { display: grid; gap: 22px; }
.services-grid { grid-template-columns: repeat(4, 1fr); }
.work-grid { grid-template-columns: repeat(3, 1fr); }
.quotes-grid { grid-template-columns: repeat(2, 1fr); }

/* Service cards */
.card {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 34px 28px 30px; transition: transform .35s var(--ease), border-color .35s var(--ease), background .35s var(--ease);
}
.card:hover { transform: translateY(-6px); border-color: var(--border-2); background: var(--surface-2); }
.card-icon {
  display: inline-grid; place-items: center; width: 52px; height: 52px; border-radius: 13px;
  background: rgba(233,194,94,0.10); border: 1px solid rgba(233,194,94,0.22); color: var(--gold-2);
  margin-bottom: 22px;
}
.card-icon svg { width: 26px; height: 26px; }
.card h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.25rem; margin-bottom: 10px; }
.card p { color: var(--text-mut); font-size: 0.97rem; }

/* Process steps */
.steps { list-style: none; display: grid; grid-template-columns: repeat(2, 1fr); gap: 2px; border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.steps li { display: flex; gap: 22px; padding: 38px 34px; background: var(--surface); }
.step-num { font-family: var(--font-mono); font-weight: 700; font-size: 2rem; line-height: 1; letter-spacing: -0.03em; background: var(--gold-grad); -webkit-background-clip: text; background-clip: text; color: transparent; flex: none; }
.step-body h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; margin-bottom: 8px; }
.step-body p { color: var(--text-mut); }

/* Work cards */
.work-card { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--surface); transition: transform .35s var(--ease), border-color .35s var(--ease); }
.work-card:hover { transform: translateY(-6px); border-color: var(--border-2); }
.work-card:hover .mock-screen { transform: scale(1.03); }
.work-meta { padding: 22px 24px 26px; }
.work-meta h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.3rem; }
.work-cat { color: var(--gold-2); font-size: 0.72rem; margin: 5px 0 12px; text-transform: uppercase; letter-spacing: 0.14em; font-family: var(--font-mono); }
.work-result { font-size: 0.97rem; color: var(--text-mut); }

/* Browser-framed concept mockups */
.mock { aspect-ratio: 16/11; overflow: hidden; background: #d9d9e0; display: flex; flex-direction: column; border-bottom: 1px solid var(--border); }
.mock-bar { height: 24px; flex: none; display: flex; align-items: center; gap: 5px; padding: 0 11px; background: #e7e7ec; }
.mock-bar > span { width: 7px; height: 7px; border-radius: 50%; background: #c2c2cc; }
.mock-url { margin-left: 8px; font-family: var(--font-mono); font-style: normal; font-size: 9px; color: #8a8a96; background: #fff; border-radius: 5px; padding: 2px 9px; letter-spacing: 0; }
.mock-screen { flex: 1; padding: 16px 18px; display: flex; flex-direction: column; transition: transform .45s var(--ease); transform-origin: top center; }
.m-nav { display: flex; align-items: center; gap: 10px; font-size: 9px; }
.m-nav .m-logo { font-family: var(--font-display); font-weight: 800; font-size: 11px; letter-spacing: 0.04em; margin-right: auto; }
.m-nav em { font-style: normal; opacity: 0.65; }
.m-eyebrow { font-size: 8px; text-transform: uppercase; letter-spacing: 0.16em; margin-bottom: 6px; opacity: 0.7; }
.m-hero { margin-top: auto; }
.m-hero h4 { font-weight: 800; line-height: 1.04; margin-bottom: 12px; }
.m-btn { display: inline-block; font-size: 9px; font-weight: 700; padding: 6px 12px; border-radius: 999px; }

/* Restaurant — warm cream + terracotta, editorial serif */
.mock-resto .mock-screen { background: #f3ede2; color: #2c2118; }
.mock-resto .m-logo { font-family: Georgia, "Times New Roman", serif; letter-spacing: 0.06em; }
.mock-resto .m-hero h4 { font-family: Georgia, serif; font-weight: 700; font-size: 21px; }
.mock-resto .m-eyebrow { color: #b15a32; }
.mock-resto .m-btn { background: #b15a32; color: #fff; }

/* Fitness — dark + electric lime, bold */
.mock-fit .mock-screen { background: #101116; color: #ededf2; }
.mock-fit .m-logo { color: #fff; }
.mock-fit .m-hero h4 { font-size: 20px; text-transform: uppercase; }
.mock-fit .m-eyebrow { color: #c6f24e; }
.mock-fit .m-btn { background: #c6f24e; color: #11140a; }

/* Store — clean light + pink, e-commerce */
.mock-shop .mock-screen { background: #fff; color: #1b1b1f; }
.mock-shop .m-cart { opacity: 1; color: #d4537e; font-weight: 700; }
.mock-shop .m-shop-hero { margin-top: auto; display: flex; gap: 12px; align-items: flex-end; }
.mock-shop .m-shop-copy { flex: 1; }
.mock-shop .m-hero, .mock-shop .m-shop-copy h4 { margin: 0; }
.mock-shop .m-shop-copy h4 { font-size: 19px; font-weight: 800; line-height: 1.05; margin-bottom: 10px; }
.mock-shop .m-eyebrow { color: #d4537e; }
.mock-shop .m-btn { background: #1b1b1f; color: #fff; }
.mock-shop .m-shop-grid { flex: none; width: 40%; display: grid; grid-template-columns: 1fr 1fr; gap: 5px; }
.mock-shop .m-shop-grid span { aspect-ratio: 1; border-radius: 5px; background: linear-gradient(135deg, #f4c0d1, #f0e3e8); }
.mock-shop .m-shop-grid span:nth-child(2) { background: linear-gradient(135deg, #d4537e, #f4c0d1); }
.mock-shop .m-shop-grid span:nth-child(3) { background: linear-gradient(135deg, #efe7e2, #d8c7bd); }
.mock-shop .m-shop-grid span:nth-child(4) { background: linear-gradient(135deg, #bcc4e6, #e6eaf6); }

/* Testimonials */
.quote { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 38px 34px; }
.quote blockquote { font-family: var(--font-display); font-weight: 600; font-size: 1.4rem; line-height: 1.4; margin-bottom: 24px; }
.quote figcaption { display: flex; flex-direction: column; gap: 2px; }
.q-name { font-weight: 700; }
.q-role { color: var(--text-dim); font-size: 0.9rem; }

/* ---------- Contact ---------- */
.contact-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; }
.contact-lead { color: var(--text-mut); font-size: 1.1rem; margin: 18px 0 32px; max-width: 420px; }
.contact-info { list-style: none; display: flex; flex-direction: column; gap: 18px; }
.contact-info li { display: flex; flex-direction: column; gap: 2px; }
.ci-label { text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.72rem; color: var(--text-dim); }
.contact-info a:hover { color: var(--gold-2); }

.signup { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius); padding: 34px; display: flex; flex-direction: column; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field label { font-size: 0.85rem; font-weight: 600; color: var(--text-mut); }
.field input, .field select, .field textarea {
  width: 100%; padding: 13px 15px; background: var(--bg-2); border: 1px solid var(--border);
  border-radius: 10px; color: var(--text); font-family: inherit; font-size: 1rem; transition: border-color .2s var(--ease), box-shadow .2s var(--ease);
}
.field textarea { resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--gold-2); box-shadow: 0 0 0 3px rgba(233,194,94,0.16);
}
.field input.invalid, .field select.invalid { border-color: #ff6b6b; }
.field-error { color: #ff9b9b; font-size: 0.82rem; min-height: 1em; }
.form-success { color: var(--gold-1); font-weight: 600; text-align: center; }

/* ---------- Footer ---------- */
.site-footer { border-top: 1px solid var(--border); padding: 48px 0; }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.footer-brand { display: flex; align-items: center; gap: 12px; font-family: var(--font-display); font-weight: 800; }
.footer-brand em { font-style: normal; font-weight: 600; color: var(--text-mut); }
.footer-links { display: flex; gap: 24px; }
.footer-links a { color: var(--text-mut); font-size: 0.92rem; transition: color .2s var(--ease); }
.footer-links a:hover { color: var(--text); }
.footer-note { color: var(--text-dim); font-size: 0.88rem; }

/* ---------- Focus visibility ---------- */
:focus-visible { outline: 2px solid var(--gold-2); outline-offset: 3px; border-radius: 4px; }

/* ---------- Scroll reveal ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 860px) {
  .nav-links, .nav-cta { display: none; }
  .menu-toggle { display: flex; }
  .site-header.menu-open .mobile-menu { display: flex; }
  .work-grid { grid-template-columns: 1fr 1fr; }
  .contact-inner { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 620px) {
  .container { padding: 0 20px; }
  .services-grid, .steps, .work-grid, .quotes-grid { grid-template-columns: 1fr; }
  .hero-stats { gap: 32px; }
  .hero-actions { width: 100%; }
  .hero-actions .btn { flex: 1; justify-content: center; }
  .quote blockquote { font-size: 1.2rem; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal, .hero .reveal { opacity: 1; transform: none; filter: none; transition: none; }
  .orb, .hero-title .grad { animation: none; }
  * { transition-duration: 0.01ms !important; }
}
