/* ─────────────────────────────────────────────────────────
   FSLM Frontend UI v50 — Luxury Enterprise SaaS
   ───────────────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700;800&family=Inter:wght@400;500;600&family=DM+Mono:wght@400;500&display=swap');

/* ── Design Tokens ──────────────────────────────────────── */
:root {
  --fslm-navy:          #030d1f;
  --fslm-navy-2:        #071832;
  --fslm-blue:          #1a56ff;
  --fslm-blue-mid:      #2563eb;
  --fslm-blue-light:    #60a5fa;
  --fslm-teal:          #06b6d4;
  --fslm-green:         #10b981;
  --fslm-bg:            #0f172a;
  --fslm-card:          #ffffff;
  --fslm-soft:          #f4f8ff;
  --fslm-text:          #0d1426;
  --fslm-muted:         #5a7085;
  --fslm-primary:       #2563eb;
  --fslm-primary-dark:  #1d4ed8;
  --fslm-border:        #e1e9f5;
  --fslm-radius:        22px;
  --fslm-font:          'Sora', sans-serif;
  --fslm-body:          'Inter', sans-serif;
  --fslm-mono:          'DM Mono', monospace;
}

/* ── Base ───────────────────────────────────────────────── */
.fslm-container { width: min(1200px, calc(100% - 40px)); margin: 0 auto; }

/* ── Site Header ────────────────────────────────────────── */
.fslm-site-header {
  position: sticky; top: 0; z-index: 30;
  background: rgba(3,13,31,.88);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.fslm-site-header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 14px 0; }
.fslm-brand { display: flex; align-items: center; gap: 11px; text-decoration: none; color: #fff; }
.fslm-brand img { height: 34px; max-width: 180px; object-fit: contain; }
.fslm-brand-mark {
  width: 36px; height: 36px; border-radius: 11px;
  background: linear-gradient(135deg, var(--fslm-blue), var(--fslm-teal));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; color: #fff; font-size: 16px;
  font-family: var(--fslm-font);
  box-shadow: 0 6px 18px rgba(26,86,255,.4);
}
.fslm-brand-name { font-weight: 700; font-size: 19px; font-family: var(--fslm-font); letter-spacing: -.02em; }
.fslm-site-nav { display: flex; align-items: center; gap: 28px; }
.fslm-site-nav a { color: rgba(219,228,240,.78); text-decoration: none; font-weight: 500; font-size: 14px; font-family: var(--fslm-body); transition: color .2s ease; }
.fslm-site-nav a:hover { color: #fff; }
.fslm-header-cta { padding: 10px 18px; font-size: 14px; }

/* ── Hero ───────────────────────────────────────────────── */
.fslm-hero {
  padding: 110px 0 100px;
  background: var(--fslm-navy);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.fslm-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 900px 700px at 60% -20%, rgba(26,86,255,.2), transparent),
    radial-gradient(ellipse 600px 500px at -10% 80%, rgba(6,182,212,.12), transparent),
    radial-gradient(ellipse 400px 300px at 95% 80%, rgba(16,185,129,.1), transparent);
  pointer-events: none;
}
/* Animated grid overlay */
.fslm-hero::after {
  content: '';
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 50%, black 30%, transparent 100%);
  pointer-events: none;
}
.fslm-hero-small { padding: 80px 0 70px; }

.fslm-hero h1 {
  font-size: clamp(38px, 6.5vw, 68px);
  line-height: 1.02;
  margin: 0 0 22px;
  font-weight: 800;
  letter-spacing: -.04em;
  font-family: var(--fslm-font);
  position: relative;
}
.fslm-hero h1 em {
  font-style: normal;
  background: linear-gradient(120deg, var(--fslm-blue-light), var(--fslm-teal), var(--fslm-green));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.fslm-hero p { font-size: 18px; max-width: 680px; color: rgba(219,228,240,.8); margin: 0; font-family: var(--fslm-body); line-height: 1.7; position: relative; }

.fslm-eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  margin-bottom: 20px;
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  font-size: 13px; font-weight: 600;
  font-family: var(--fslm-body);
  position: relative;
}
.fslm-eyebrow::before {
  content: '';
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--fslm-green);
  box-shadow: 0 0 8px var(--fslm-green);
  animation: fslmPulse 2s ease infinite;
}
@keyframes fslmPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.85)} }

/* ── Hero Grid (Premium Hero with Device Mock) ─────────── */
.fslm-hero-premium { background: radial-gradient(circle at 70% 30%, rgba(26,86,255,.18), transparent 35%), linear-gradient(180deg, #030d1f, #071832 100%); color: #fff; }
.fslm-hero-grid { display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; }
.fslm-chip { display: inline-flex; padding: 10px 15px; border-radius: 999px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); font-size: 13px; font-weight: 600; margin-bottom: 20px; font-family: var(--fslm-body); }
.fslm-hero-bullets { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 20px; color: rgba(219,228,240,.75); font-size: 14px; font-family: var(--fslm-body); }
.fslm-hero-bullets span::before { content: "●"; margin-right: 7px; color: var(--fslm-green); }

/* ── Browser Frame (Device Mock) ─────────────────────────── */
.fslm-browser-frame {
  background: #fff; border-radius: 20px;
  overflow: hidden;
  display: grid; grid-template-columns: 200px 1fr;
  min-height: 400px;
  box-shadow: 0 30px 80px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.1);
}
.fslm-device-sidebar { background: #051135; color: #fff; padding: 20px; }
.fslm-device-sidebar .fslm-device-logo { font-weight: 700; margin-bottom: 20px; font-size: 14px; font-family: var(--fslm-font); }
.fslm-device-sidebar ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.fslm-device-sidebar li { padding: 10px 12px; border-radius: 10px; color: rgba(219,228,240,.65); font-size: 13px; font-family: var(--fslm-body); }
.fslm-device-sidebar li:first-child { background: var(--fslm-blue-mid); color: #fff; }
.fslm-device-main { padding: 22px; background: #f4f8ff; }
.fslm-device-kpis { display: grid; grid-template-columns: repeat(4,1fr); gap: 10px; }
.fslm-device-kpis div { background: #fff; border: 1px solid #e5e9f5; border-radius: 13px; padding: 13px; }
.fslm-device-kpis strong { display: block; font-size: 17px; font-weight: 800; color: #0d1426; font-family: var(--fslm-font); }
.fslm-device-kpis span { display: block; color: #64748b; font-size: 11px; margin-top: 3px; font-family: var(--fslm-body); }
.fslm-chart { height: 210px; margin-top: 16px; border-radius: 16px; background: #fff; border: 1px solid #e5e9f5; position: relative; overflow: hidden; }
.fslm-chart::after { content: ''; position: absolute; left: 28px; right: 28px; top: 50px; height: 110px; background: linear-gradient(180deg, rgba(26,86,255,.12), rgba(6,182,212,.06)); clip-path: path("M0,110 C80,40 130,150 220,70 C280,30 350,130 420,40 L420,110 Z"); }

/* ── Section ─────────────────────────────────────────────── */
.fslm-section { padding: 90px 0; background: var(--fslm-card); }
.fslm-section-soft { background: var(--fslm-soft); }
.fslm-section-dark { background: var(--fslm-navy); color: #fff; }
.fslm-section-head { text-align: center; max-width: 760px; margin: 0 auto 40px; }
.fslm-section-head h2 { margin: 10px 0 14px; font-size: clamp(28px, 4.5vw, 44px); line-height: 1.08; font-weight: 800; letter-spacing: -.03em; font-family: var(--fslm-font); }
.fslm-section-head p { color: var(--fslm-muted); font-size: 17px; font-family: var(--fslm-body); line-height: 1.7; }

/* ── Eyebrow Light ──────────────────────────────────────── */
.fslm-eyebrow-light { display: inline-block; margin-bottom: 14px; padding: 7px 14px; border-radius: 999px; background: #eff6ff; color: var(--fslm-primary); font-size: 13px; font-weight: 700; font-family: var(--fslm-body); }

/* ── Cards ──────────────────────────────────────────────── */
.fslm-grid-3,.fslm-grid-2,.fslm-pricing-grid { display: grid; gap: 20px; }
.fslm-grid-3 { grid-template-columns: repeat(3,1fr); }
.fslm-grid-2 { grid-template-columns: repeat(2,1fr); }
.fslm-pricing-grid { grid-template-columns: repeat(3,1fr); }
.fslm-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }

.fslm-card,
.fslm-price-card,
.fslm-faq-item,
.fslm-feature-box {
  background: var(--fslm-card);
  border: 1px solid var(--fslm-border);
  border-radius: var(--fslm-radius);
  padding: 30px;
  box-shadow: 0 6px 24px rgba(13,20,38,.05);
  transition: all .3s ease;
  position: relative;
}
.fslm-card:hover,.fslm-feature-box:hover {
  transform: translateY(-4px);
  box-shadow: 0 18px 50px rgba(13,20,38,.1);
  border-color: rgba(37,99,235,.2);
}
.fslm-card h3,.fslm-price-card h3,.fslm-faq-item h3,.fslm-feature-box h3 {
  margin: 0 0 12px; font-size: 21px; font-weight: 700;
  font-family: var(--fslm-font); letter-spacing: -.02em;
}
.fslm-card p,.fslm-faq-item p,.fslm-price-desc,.fslm-feature-box p {
  margin: 0; color: var(--fslm-muted); line-height: 1.75;
  font-family: var(--fslm-body); font-size: 15px;
}

/* ── Pricing ─────────────────────────────────────────────── */
.fslm-price-card { position: relative; }
.fslm-price-card.is-featured {
  border: 2px solid var(--fslm-primary);
  box-shadow: 0 0 0 4px rgba(37,99,235,.1), 0 20px 50px rgba(37,99,235,.18);
  transform: translateY(-6px);
}
.fslm-badge {
  position: absolute; top: 18px; right: 18px;
  background: var(--fslm-primary); color: #fff;
  padding: 6px 12px; border-radius: 999px;
  font-size: 12px; font-weight: 700;
  font-family: var(--fslm-body);
}
.fslm-price-value {
  font-size: 48px; font-weight: 800; line-height: 1;
  margin: 20px 0 8px; letter-spacing: -.04em;
  font-family: var(--fslm-font);
}
.fslm-price-value span { font-size: 15px; font-weight: 600; color: var(--fslm-muted); letter-spacing: 0; }
.fslm-meta { color: var(--fslm-muted); margin-bottom: 16px; font-size: 14px; font-family: var(--fslm-body); }
.fslm-feature-list { list-style: none; padding: 0; margin: 18px 0 28px; }
.fslm-feature-list li {
  padding: 10px 0 10px 24px;
  border-bottom: 1px solid var(--fslm-border);
  color: var(--fslm-text);
  font-family: var(--fslm-body); font-size: 14.5px;
  position: relative;
}
.fslm-feature-list li:last-child { border-bottom: none; }
.fslm-feature-list li::before { content: '✓'; position: absolute; left: 0; color: var(--fslm-green); font-weight: 800; }

/* ── Buttons ─────────────────────────────────────────────── */
.fslm-cta-row { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }
.fslm-btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 14px 26px; border-radius: 14px;
  text-decoration: none; font-weight: 700;
  font-family: var(--fslm-font); font-size: 15px;
  transition: all .25s ease; cursor: pointer;
  border: none; outline: none;
  letter-spacing: -.01em;
}
.fslm-btn-primary {
  background: linear-gradient(135deg, var(--fslm-primary), var(--fslm-primary-dark));
  color: #fff;
  box-shadow: 0 6px 22px rgba(37,99,235,.36);
}
.fslm-btn-primary:hover { color: #fff; transform: translateY(-2px); box-shadow: 0 12px 32px rgba(37,99,235,.46); }
.fslm-btn-secondary {
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(6px);
}
.fslm-btn-secondary:hover { background: rgba(255,255,255,.14); color: #fff; }
.fslm-section .fslm-btn-secondary { background: #fff; color: var(--fslm-text); border: 1.5px solid var(--fslm-border); }
.fslm-section .fslm-btn-secondary:hover { background: var(--fslm-soft); }

/* ── Steps ───────────────────────────────────────────────── */
.fslm-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.fslm-step { background: var(--fslm-card); border: 1px solid var(--fslm-border); border-radius: var(--fslm-radius); padding: 28px; text-align: center; transition: all .3s ease; }
.fslm-step:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(13,20,38,.08); }
.fslm-step span {
  display: inline-flex; width: 46px; height: 46px; border-radius: 14px;
  background: linear-gradient(135deg, var(--fslm-primary), var(--fslm-primary-dark));
  color: #fff; align-items: center; justify-content: center;
  font-weight: 800; margin-bottom: 14px;
  box-shadow: 0 6px 18px rgba(37,99,235,.3);
  font-family: var(--fslm-font);
}

/* ── Feature Strip ───────────────────────────────────────── */
.fslm-feature-strip { margin-top: -50px; position: relative; z-index: 5; }

/* ── Demo Card ───────────────────────────────────────────── */
.fslm-demo-card { background: var(--fslm-card); border: 1px solid var(--fslm-border); border-radius: 28px; padding: 28px; box-shadow: 0 20px 60px rgba(13,20,38,.08); }
.fslm-demo-screen { height: 380px; border-radius: 22px; background: linear-gradient(135deg, #030d1f, #0f2070); position: relative; overflow: hidden; }
.fslm-demo-screen::before { content: 'PromoterFlow'; position: absolute; top: 40%; left: 50%; transform: translate(-50%,-50%); font-size: 38px; font-weight: 800; color: rgba(255,255,255,.9); font-family: var(--fslm-font); letter-spacing: -.03em; }
.fslm-demo-play { position: absolute; top: 58%; left: 50%; transform: translate(-50%,-50%); width: 68px; height: 68px; border-radius: 50%; background: rgba(255,255,255,.95); color: var(--fslm-primary); display: flex; align-items: center; justify-content: center; font-size: 26px; font-weight: 700; box-shadow: 0 8px 28px rgba(0,0,0,.3); cursor: pointer; transition: transform .2s ease; }
.fslm-demo-play:hover { transform: translate(-50%,-50%) scale(1.08); }

/* ── Contact Form ─────────────────────────────────────────── */
.fslm-contact-wrap { background: var(--fslm-card); border: 1px solid var(--fslm-border); border-radius: var(--fslm-radius); padding: 32px; box-shadow: 0 8px 32px rgba(13,20,38,.06); }
.fslm-contact-form label { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; font-weight: 600; font-family: var(--fslm-font); font-size: 14px; color: var(--fslm-text); }
.fslm-contact-form input,
.fslm-contact-form textarea {
  border: 1.5px solid var(--fslm-border); border-radius: 13px;
  padding: 13px 16px; font-family: var(--fslm-body); font-size: 14.5px;
  color: var(--fslm-text); background: var(--fslm-soft);
  transition: all .2s ease; outline: none;
}
.fslm-contact-form input:focus,
.fslm-contact-form textarea:focus { border-color: var(--fslm-primary); box-shadow: 0 0 0 3px rgba(37,99,235,.14); background: #fff; }

/* ── Status Messages ─────────────────────────────────────── */
.fslm-success { padding: 14px 18px; border-radius: 13px; margin-bottom: 16px; background: rgba(16,185,129,.1); color: #065f46; border: 1px solid rgba(16,185,129,.25); font-family: var(--fslm-body); }
.fslm-error   { padding: 14px 18px; border-radius: 13px; margin-bottom: 16px; background: rgba(244,63,94,.08); color: #9f1239; border: 1px solid rgba(244,63,94,.2); font-family: var(--fslm-body); }

/* ── Prose ───────────────────────────────────────────────── */
.fslm-center { text-align: center; }
.fslm-prose { max-width: 860px; }
.fslm-prose h1,.fslm-prose h2 { font-family: var(--fslm-font); margin-top: 0; letter-spacing: -.03em; }
.fslm-prose p { line-height: 1.82; color: var(--fslm-muted); font-family: var(--fslm-body); }

/* ── Checkout Shell ──────────────────────────────────────── */
.fslm-checkout-shell { display: block; }

/* ── My Account ──────────────────────────────────────────── */
.fslm-my-account { display: block; }
.fslm-account-hero {
  background: linear-gradient(125deg, #030d1f, #0f3185);
  color: #fff; padding: 28px; border-radius: 22px; margin-bottom: 22px;
  position: relative; overflow: hidden;
  box-shadow: 0 14px 40px rgba(3,13,31,.25);
}
.fslm-account-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 500px 300px at 90% 50%, rgba(26,86,255,.25), transparent);
  pointer-events: none;
}
.fslm-account-eyebrow { display: inline-block; font-size: 12px; font-weight: 700; padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,.12); margin-bottom: 12px; font-family: var(--fslm-body); position: relative; }
.fslm-account-hero h2 { margin: 0 0 8px; color: #fff; font-family: var(--fslm-font); font-size: 24px; font-weight: 800; position: relative; }
.fslm-account-hero p { margin: 0; color: rgba(219,228,240,.8); font-family: var(--fslm-body); font-size: 14px; position: relative; }

.fslm-empty-card { background: var(--fslm-card); border: 1px solid var(--fslm-border); border-radius: 18px; padding: 28px; }
.fslm-license-card {
  background: var(--fslm-card); border: 1px solid var(--fslm-border);
  border-radius: 20px; padding: 24px; margin-bottom: 18px;
  box-shadow: 0 6px 24px rgba(13,20,38,.05);
  transition: all .3s ease;
}
.fslm-license-card:hover { box-shadow: 0 14px 40px rgba(13,20,38,.1); border-color: rgba(37,99,235,.2); }
.fslm-license-top { display: flex; justify-content: space-between; gap: 14px; align-items: flex-start; margin-bottom: 18px; }
.fslm-license-title { font-size: 22px; font-weight: 800; color: var(--fslm-text); font-family: var(--fslm-font); letter-spacing: -.02em; }
.fslm-license-sub { color: var(--fslm-muted); font-family: var(--fslm-body); font-size: 14px; }
.fslm-license-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 14px; margin-bottom: 18px; }
.fslm-label { display: block; font-size: 11px; color: var(--fslm-muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 7px; font-family: var(--fslm-body); font-weight: 600; }
.fslm-code { font-family: var(--fslm-mono); background: #eef3ff; color: var(--fslm-primary); border: 1px solid rgba(37,99,235,.18); padding: 10px 14px; border-radius: 11px; word-break: break-all; font-size: 13px; cursor: pointer; transition: all .2s ease; }
.fslm-code:hover { background: var(--fslm-primary); color: #fff; border-color: var(--fslm-primary); }
.fslm-action-row { display: flex; gap: 10px; flex-wrap: wrap; }
.fslm-pill { display: inline-flex; align-items: center; padding: 6px 13px; border-radius: 999px; font-size: 12px; font-weight: 700; font-family: var(--fslm-body); }
.fslm-pill.ok      { background: rgba(16,185,129,.12); color: #059669; }
.fslm-pill.warn    { background: rgba(245,158,11,.12);  color: #b45309; }
.fslm-pill.danger  { background: rgba(244,63,94,.1);    color: #e11d48; }
.fslm-pill.neutral { background: #f1f5f9;               color: #334155; }

.fslm-section-title { font-size: 20px; font-weight: 800; margin: 26px 0 16px; color: var(--fslm-text); font-family: var(--fslm-font); letter-spacing: -.02em; }
.fslm-download-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-bottom: 20px; }
.fslm-download-card,.fslm-panel-lite { background: var(--fslm-card); border: 1px solid var(--fslm-border); border-radius: 18px; padding: 22px; box-shadow: 0 6px 22px rgba(13,20,38,.05); }

/* ── Footer ──────────────────────────────────────────────── */
.fslm-site-footer { background: #030d1f; color: rgba(219,228,240,.7); padding: 40px 0; margin-top: 0; }
.fslm-site-footer-inner { display: flex; justify-content: space-between; gap: 32px; align-items: flex-start; }
.fslm-footer-title { font-size: 20px; font-weight: 800; color: #fff; margin-bottom: 10px; font-family: var(--fslm-font); }
.fslm-footer-links { display: grid; grid-template-columns: repeat(3, minmax(80px, auto)); gap: 10px 26px; }
.fslm-footer-links a { color: rgba(219,228,240,.65); text-decoration: none; font-size: 14px; font-family: var(--fslm-body); transition: color .2s ease; }
.fslm-footer-links a:hover { color: #fff; }

/* ── Scroll Reveal ───────────────────────────────────────── */
.fslm-card,
.fslm-feature-box,
.fslm-price-card,
.fslm-step,
.fslm-demo-card {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s ease, transform .6s ease;
}
.fslm-reveal-in {
  opacity: 1 !important;
  transform: none !important;
}

/* ── Elementor Canvas ────────────────────────────────────── */
body.page-template-elementor_canvas .site,
body.page-template-elementor_canvas { background: #fff; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1100px) {
  .fslm-hero-grid,.fslm-grid-4,.fslm-steps { grid-template-columns: 1fr; }
  .fslm-browser-frame { grid-template-columns: 1fr; }
  .fslm-device-sidebar { display: none; }
  .fslm-device-kpis { grid-template-columns: 1fr 1fr; }
  .fslm-feature-strip { margin-top: 0; }
}
@media (max-width: 980px) {
  .fslm-grid-3,.fslm-pricing-grid,.fslm-grid-2 { grid-template-columns: 1fr; }
  .fslm-hero { padding: 80px 0 70px; }
  .fslm-license-grid { grid-template-columns: 1fr 1fr; }
  .fslm-download-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .fslm-license-grid { grid-template-columns: 1fr; }
  .fslm-license-top { flex-direction: column; }
  .fslm-site-nav { display: none; }
  .fslm-site-footer-inner { flex-direction: column; }
  .fslm-hero { padding: 70px 0 60px; }
}
@media (max-width: 700px) { .fslm-device-kpis { grid-template-columns: 1fr; } }

/* v5.3.1: full-width theme-integrated public pages */
.fslm-full-bleed,
.elementor .fslm-full-bleed,
.fslm-pricing-grid,
.fslm-grid-3,
.fslm-grid-2,
.fslm-contact-wrap{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}
.fslm-section.fslm-full-bleed{padding-inline:clamp(16px,4vw,48px)}
.woocommerce-checkout #fslm_checkout_domain{
  background:#f8fafc;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:20px;
  margin:20px 0;
}
.woocommerce-checkout #fslm_checkout_domain h3{margin-top:0;color:#0f172a}
.woocommerce-checkout #fslm_checkout_domain input,
.woocommerce-checkout #fslm_checkout_domain select,
.woocommerce-checkout #fslm_checkout_domain textarea{border-radius:12px}

/* ── Promoter Flow Native WooCommerce Checkout Integration ───────────── */
.woocommerce-checkout #fslm_checkout_domain.fslm-checkout-fields-box{
  margin: 28px 0;
  padding: clamp(20px, 3vw, 32px);
  border-radius: 24px;
  border: 1px solid rgba(37, 99, 235, .16);
  background:
    radial-gradient(circle at top right, rgba(56,189,248,.16), transparent 34%),
    linear-gradient(135deg, rgba(248,250,252,.98), rgba(255,255,255,.98));
  box-shadow: 0 20px 60px rgba(15,23,42,.08);
  position: relative;
  overflow: hidden;
}
.woocommerce-checkout #fslm_checkout_domain.fslm-checkout-fields-box:before{
  content:""; position:absolute; inset:0 0 auto 0; height:4px;
  background: linear-gradient(90deg,#2563eb,#38bdf8,#10b981);
}
.woocommerce-checkout .fslm-checkout-fields-head{
  display:flex; align-items:flex-start; gap:14px; margin-bottom:16px;
}
.woocommerce-checkout .fslm-checkout-icon{
  width:44px; height:44px; flex:0 0 44px; border-radius:16px;
  background: linear-gradient(135deg,#2563eb,#38bdf8 55%,#10b981);
  box-shadow: 0 12px 28px rgba(37,99,235,.28);
  position:relative;
}
.woocommerce-checkout .fslm-checkout-icon:before{
  content:""; position:absolute; width:17px; height:12px; border-left:3px solid #fff; border-bottom:3px solid #fff; transform:rotate(-45deg); left:13px; top:14px;
}
.woocommerce-checkout #fslm_checkout_domain h3{
  margin:0 0 4px; font-size: clamp(20px, 2.2vw, 26px); line-height:1.15; color:#0f172a; letter-spacing:-.03em;
}
.woocommerce-checkout .fslm-checkout-fields-head p,
.woocommerce-checkout .fslm-checkout-help{
  margin:0 0 14px; color:#64748b; font-size:14px; line-height:1.65;
}
.woocommerce-checkout .fslm-checkout-fields-grid{
  display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:14px 16px;
}
.woocommerce-checkout #fslm_checkout_domain .form-row{ margin:0 !important; padding:0 !important; width:100% !important; float:none !important; }
.woocommerce-checkout #fslm_checkout_domain .fslm-field-wide{ grid-column:1 / -1; }
.woocommerce-checkout #fslm_checkout_domain label{ color:#0f172a; font-weight:700; font-size:13px; margin-bottom:8px; display:block; }
.woocommerce-checkout #fslm_checkout_domain .required{ color:#ef4444; text-decoration:none; }
.woocommerce-checkout #fslm_checkout_domain input.input-text,
.woocommerce-checkout #fslm_checkout_domain select,
.woocommerce-checkout #fslm_checkout_domain textarea{
  width:100%; min-height:50px; border-radius:16px; border:1px solid #dbe6f3;
  background:#fff; padding:13px 15px; color:#0f172a; outline:none;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.woocommerce-checkout #fslm_checkout_domain textarea{ min-height:96px; resize:vertical; }
.woocommerce-checkout #fslm_checkout_domain input.input-text:focus,
.woocommerce-checkout #fslm_checkout_domain select:focus,
.woocommerce-checkout #fslm_checkout_domain textarea:focus{
  border-color:#2563eb; box-shadow:0 0 0 4px rgba(37,99,235,.12); transform:translateY(-1px);
}
.woocommerce-checkout .woocommerce-checkout-review-order,
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout .woocommerce-additional-fields{
  border-radius:22px;
}
body.rtl.woocommerce-checkout .fslm-checkout-fields-head{ direction:rtl; }
body.rtl.woocommerce-checkout .fslm-checkout-icon:before{ left:auto; right:13px; }
@media (max-width: 768px){
  .woocommerce-checkout .fslm-checkout-fields-grid{ grid-template-columns:1fr; }
  .woocommerce-checkout #fslm_checkout_domain .fslm-field-half{ grid-column:1 / -1; }
}
