/**
 * FilmMerge — services.css
 * Page: /services/
 * Extracted from filmmerge-services.html.
 */


/* ── Hero ───────────────────────────────────────────────── */
.fm-services-hero { padding: 100px 0 80px; position: relative; overflow: hidden; }
.fm-services-hero__bg { position: absolute; inset: 0; background: radial-gradient(ellipse 65% 60% at 50% 40%, rgba(200,151,58,.065) 0%, transparent 65%), linear-gradient(180deg, #0a0c10 0%, #0f1318 100%); }
.fm-services-hero__inner { position: relative; z-index: 2; max-width: var(--max-width); margin: 0 auto; padding: 0 28px; text-align: center; }
.fm-services-hero h1 { font-family: var(--serif); font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 700; color: var(--white); line-height: 1.0; margin-bottom: 22px; }
.fm-services-hero h1 em { font-style: italic; color: var(--gold); }
.fm-services-hero__sub { font-size: 1.05rem; color: var(--muted); max-width: 580px; margin: 0 auto 44px; line-height: 1.8; }
.fm-services-hero__stats { display: flex; justify-content: center; gap: 56px; flex-wrap: wrap; padding-top: 44px; border-top: 1px solid var(--border); max-width: 640px; margin: 0 auto; }
.fm-services-hero__stat strong { display: block; font-family: var(--serif); font-size: 2.4rem; font-weight: 700; color: var(--gold); line-height: 1; margin-bottom: 4px; }
.fm-services-hero__stat span { font-size: 0.75rem; color: var(--muted); font-weight: 500; }

/* ── Service cards ───────────────────────────────────────── */
.fm-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.fm-service-card { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 36px 30px; transition: var(--transition); position: relative; overflow: hidden; }
.fm-service-card:hover { border-color: rgba(200,151,58,.25); transform: translateY(-4px); box-shadow: 0 20px 50px rgba(0,0,0,.35); }
.fm-service-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, rgba(200,151,58,.4), transparent); opacity: 0; transition: opacity var(--transition); }
.fm-service-card:hover::before { opacity: 1; }
.fm-service-card--featured { border-color: rgba(200,151,58,.2); background: linear-gradient(145deg, rgba(200,151,58,.07), rgba(200,151,58,.02)); }
.fm-service-card--featured::before { opacity: 1; background: linear-gradient(90deg, transparent, rgba(200,151,58,.6), transparent); }
.fm-service-card__badge { display: inline-flex; align-items: center; gap: 6px; font-size: 0.62rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); background: rgba(200,151,58,.1); border: 1px solid rgba(200,151,58,.2); padding: 4px 10px; border-radius: 4px; margin-bottom: 22px; }
.fm-service-card__icon { width: 56px; height: 56px; border-radius: 14px; background: rgba(200,151,58,.1); border: 1px solid rgba(200,151,58,.18); display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1.4rem; margin-bottom: 22px; }
.fm-service-card__title { font-family: var(--serif); font-size: 1.4rem; font-weight: 700; color: var(--white); margin-bottom: 10px; line-height: 1.2; }
.fm-service-card__desc { font-size: 0.88rem; color: var(--muted); line-height: 1.8; margin-bottom: 22px; }
.fm-service-card__features { list-style: none; display: flex; flex-direction: column; gap: 8px; margin-bottom: 28px; }
.fm-service-card__feature { display: flex; align-items: flex-start; gap: 9px; font-size: 0.82rem; color: var(--muted); line-height: 1.5; }
.fm-service-card__feature i { color: var(--gold); font-size: 0.82rem; margin-top: 2px; flex-shrink: 0; }
.fm-service-card__cta { display: inline-flex; align-items: center; gap: 7px; font-size: 0.76rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); transition: gap var(--transition); }
.fm-service-card__cta:hover { gap: 10px; }

/* ── Process steps ───────────────────────────────────────── */
.fm-process-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; position: relative; }
.fm-process-line { position: absolute; top: 32px; left: 10%; right: 10%; height: 1px; background: linear-gradient(90deg, transparent, rgba(200,151,58,.2), rgba(200,151,58,.2), rgba(200,151,58,.2), transparent); pointer-events: none; }
.fm-process-card { text-align: center; position: relative; z-index: 1; }
.fm-process-card__dot { width: 64px; height: 64px; border-radius: 50%; background: var(--panel); border: 1.5px solid var(--border); display: flex; align-items: center; justify-content: center; color: var(--muted); font-size: 1.3rem; margin: 0 auto 18px; transition: var(--transition); position: relative; }
.fm-process-card:hover .fm-process-card__dot { border-color: rgba(200,151,58,.3); color: var(--gold); background: rgba(200,151,58,.07); }
.fm-process-card__num { position: absolute; top: -5px; right: -5px; width: 22px; height: 22px; border-radius: 50%; background: var(--gold); color: var(--ink); font-size: 0.6rem; font-weight: 800; display: flex; align-items: center; justify-content: center; }
.fm-process-card__title { font-family: var(--serif); font-size: 1rem; font-weight: 700; color: var(--white); margin-bottom: 7px; }
.fm-process-card__desc { font-size: 0.78rem; color: var(--muted); line-height: 1.65; }

/* ── Licensing models ────────────────────────────────────── */
.fm-licensing-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.fm-licensing-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); padding: 26px 22px; transition: var(--transition); }
.fm-licensing-card:hover { border-color: rgba(200,151,58,.2); transform: translateY(-3px); }
.fm-licensing-card__label { font-size: 0.62rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); margin-bottom: 10px; }
.fm-licensing-card__name { font-family: var(--serif); font-size: 1.3rem; font-weight: 700; color: var(--white); margin-bottom: 8px; line-height: 1.2; }
.fm-licensing-card__desc { font-size: 0.82rem; color: var(--muted); line-height: 1.7; margin-bottom: 14px; }
.fm-licensing-card__examples { font-size: 0.72rem; color: rgba(138,146,160,.6); font-style: italic; }

/* ── Comparison table ────────────────────────────────────── */
.fm-comparison { background: var(--deep); }
.fm-comparison-wrap { overflow-x: auto; }
.fm-comparison-table { width: 100%; border-collapse: collapse; min-width: 700px; }
.fm-comparison-table th { padding: 14px 20px; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); text-align: left; border-bottom: 1px solid var(--border); }
.fm-comparison-table th:first-child { color: var(--cream); font-size: 0.68rem; }
.fm-comparison-table th.highlight { color: var(--gold); background: rgba(200,151,58,.04); }
.fm-comparison-table td { padding: 16px 20px; font-size: 0.86rem; color: var(--muted); border-bottom: 1px solid rgba(30,37,48,.6); vertical-align: middle; }
.fm-comparison-table td:first-child { color: var(--cream); font-weight: 600; font-size: 0.85rem; }
.fm-comparison-table td.highlight { background: rgba(200,151,58,.035); }
.fm-comparison-table tr:last-child td { border-bottom: none; }
.fm-comparison-table tr:hover td { background: rgba(255,255,255,.02); }
.fm-comparison-table tr:hover td.highlight { background: rgba(200,151,58,.05); }
.fm-check { color: var(--gold); font-size: 1rem; }
.fm-cross { color: rgba(138,146,160,.4); font-size: 1rem; }
.fm-partial { color: var(--muted); font-size: 0.78rem; }

/* ── Requirements ────────────────────────────────────────── */
.fm-requirements-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.fm-req-list { display: flex; flex-direction: column; gap: 12px; }
.fm-req-item { display: flex; align-items: flex-start; gap: 14px; padding: 16px 18px; background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); }
.fm-req-item__icon { width: 36px; height: 36px; border-radius: 8px; background: rgba(200,151,58,.1); border: 1px solid rgba(200,151,58,.15); display: flex; align-items: center; justify-content: center; color: var(--gold); font-size: 1rem; flex-shrink: 0; }
.fm-req-item__title { font-size: 0.85rem; font-weight: 700; color: var(--cream); margin-bottom: 3px; }
.fm-req-item__desc { font-size: 0.78rem; color: var(--muted); line-height: 1.6; }
.fm-req-note { background: linear-gradient(135deg, rgba(200,151,58,.08), rgba(200,151,58,.02)); border: 1px solid rgba(200,151,58,.15); border-radius: 12px; padding: 32px; }
.fm-req-note h3 { font-family: var(--serif); font-size: 1.5rem; font-weight: 700; color: var(--white); margin-bottom: 12px; }
.fm-req-note p { font-size: 0.88rem; color: var(--muted); line-height: 1.8; margin-bottom: 12px; }
.fm-req-note a { color: var(--gold); }

/* ── Quote ───────────────────────────────────────────────── */
.fm-services-quote { padding: 80px 0; background: var(--panel); border-top: 1px solid rgba(200,151,58,.1); border-bottom: 1px solid var(--border); }
.fm-services-quote__inner { max-width: 780px; margin: 0 auto; padding: 0 28px; text-align: center; }
.fm-services-quote blockquote { font-family: var(--serif); font-size: clamp(1.4rem, 2.5vw, 2rem); font-style: italic; color: var(--cream); line-height: 1.5; margin-bottom: 20px; }
.fm-services-quote blockquote::before { content: '\201C'; font-size: 3rem; color: var(--gold); line-height: 0; vertical-align: -0.5em; margin-right: 4px; }
.fm-services-quote__cite { font-size: 0.8rem; color: var(--muted); font-weight: 600; }
.fm-services-quote__cite strong { color: var(--gold); }

/* ── CTA ─────────────────────────────────────────────────── */
.fm-services-cta { padding: 96px 0; }
.fm-services-cta__inner { max-width: var(--max-width); margin: 0 auto; padding: 0 28px; display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.fm-services-cta__left h2 { font-family: var(--serif); font-size: clamp(2.2rem, 4vw, 3.5rem); font-weight: 700; color: var(--white); line-height: 1.1; margin-bottom: 18px; }
.fm-services-cta__left h2 em { font-style: italic; color: var(--gold); }
.fm-services-cta__left p { font-size: 0.95rem; color: var(--muted); line-height: 1.8; margin-bottom: 32px; }
.fm-services-cta__left .btn { margin-right: 12px; margin-bottom: 12px; }
.fm-services-cta__right { display: flex; flex-direction: column; gap: 14px; }
.fm-services-cta__check { display: flex; align-items: flex-start; gap: 12px; padding: 18px 20px; background: var(--panel); border: 1px solid var(--border); border-radius: var(--radius); }
.fm-services-cta__check i { color: var(--gold); font-size: 1.1rem; flex-shrink: 0; margin-top: 2px; }
.fm-services-cta__check-title { font-size: 0.88rem; font-weight: 700; color: var(--white); margin-bottom: 3px; }
.fm-services-cta__check-desc { font-size: 0.8rem; color: var(--muted); line-height: 1.6; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .fm-services-grid { grid-template-columns: repeat(2, 1fr); }
  .fm-licensing-grid { grid-template-columns: repeat(2, 1fr); }
  .fm-process-grid { grid-template-columns: repeat(3, 1fr); }
  .fm-process-line { display: none; }
  .fm-services-cta__inner { grid-template-columns: 1fr; gap: 40px; }
}
@media (max-width: 768px) {
  .fm-services-grid { grid-template-columns: 1fr; }
  .fm-process-grid { grid-template-columns: repeat(2, 1fr); }
  .fm-licensing-grid { grid-template-columns: 1fr 1fr; }
  .fm-requirements-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .fm-licensing-grid { grid-template-columns: 1fr; }
  .fm-process-grid { grid-template-columns: 1fr; }
}
