/* ============================================================
   LUMOPA — EARLY ACCESS LANDING
   Brand tokens (from Boris spec)
   ============================================================ */
:root{
  --coral:#D85A30;
  --coral-hover:#c14e28;
  --dark:#0F172A;
  --dark-2:#111827;
  --green:#22C55E;
  --light-text:#F8FAFC;
  --muted:#94A3B8;
  --light-bg:#F7F8FA;
  --dark-text:#111827;
  --radius:20px;
  --radius-pill:999px;
  --maxw:1140px;
  --pad-x:24px;
  --sec-pad:96px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--dark-text);
  background:var(--dark);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,.eyebrow{font-family:'Sora',sans-serif}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad-x)}
.section{padding:var(--sec-pad) 0}

/* sections alternate dark/light for premium rhythm */
.s-dark{background:var(--dark);color:var(--light-text)}
.s-dark-2{background:var(--dark-2);color:var(--light-text)}
.s-light{background:var(--light-bg);color:var(--dark-text)}

.eyebrow{
  display:inline-block;
  font-size:13px;font-weight:600;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--coral);margin-bottom:18px;
}
.s-light .eyebrow{color:var(--coral)}

h2.section-title{font-size:clamp(28px,4vw,42px);font-weight:700;letter-spacing:-0.02em;line-height:1.1}
.lead{font-size:18px;color:var(--muted);max-width:560px;margin-top:18px}
.s-light .lead{color:#475569}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:16px;
  padding:16px 32px;border-radius:var(--radius-pill);border:none;cursor:pointer;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 8px 24px rgba(216,90,48,.28)}
.btn-primary:hover{background:var(--coral-hover);transform:translateY(-2px);box-shadow:0 12px 30px rgba(216,90,48,.36)}
.btn-ghost{background:transparent;color:var(--light-text);border:1.5px solid rgba(248,250,252,.25)}
.btn-ghost:hover{border-color:var(--coral);color:#fff;transform:translateY(-2px)}

/* ============================================================
   HEADER / NAV
   ============================================================ */
header{
  position:sticky;top:0;z-index:50;
  background:rgba(15,23,42,.78);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(248,250,252,.06);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{display:flex;align-items:center}
.logo svg{height:34px;width:auto}
.nav-cta{font-size:15px}
.nav .btn{padding:11px 22px;font-size:15px}

/* ============================================================
   HERO
   ============================================================ */
/* HERO — full-bleed background image (Boris handoff: center 60%) */
.hero{
  position:relative;overflow:hidden;
  background-color:var(--dark);
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}
/* left-side gradient protects white text legibility WITHOUT darkening
   the runners (centre/right of the image) — no full overlay, per spec */
.hero::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(15,23,42,.84) 0%,rgba(15,23,42,.60) 34%,rgba(15,23,42,.20) 58%,rgba(15,23,42,.08) 78%,transparent 100%);
  pointer-events:none;
}
.hero .wrap{position:relative;z-index:1}
.hero-grid{display:grid;grid-template-columns:1fr;align-items:center;min-height:600px;padding:96px 0 110px}
.hero-left{max-width:580px}
.hero h1{
  font-size:clamp(40px,6vw,68px);font-weight:800;line-height:1.04;letter-spacing:-0.03em;
  color:var(--light-text);text-shadow:0 2px 24px rgba(0,0,0,.35);
}
.hero h1 .accent{color:var(--coral)}
.hero p.sub{font-size:19px;color:#e2e8f0;margin-top:22px;max-width:480px;text-shadow:0 1px 12px rgba(0,0,0,.4)}

/* email form */
.email-form{display:flex;gap:10px;margin-top:32px;max-width:460px;flex-wrap:wrap}
.email-form .ff-slot{flex:1;min-width:220px}
.mini-text{font-size:14px;color:#cbd5e1;margin-top:14px;text-shadow:0 1px 10px rgba(0,0,0,.4)}

/* ============================================================
   COMMUNITY STRIP
   ============================================================ */
.strip-title{font-size:clamp(22px,3vw,30px);font-weight:600;text-align:center;max-width:680px;margin:0 auto 44px;line-height:1.25;letter-spacing:-0.01em}
.strip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.strip-item{display:flex;align-items:center;gap:14px;justify-content:center;font-size:17px;font-weight:500;color:var(--light-text)}
.strip-item .dot{width:10px;height:10px;border-radius:50%;background:var(--coral);flex-shrink:0}
.strip-item:nth-child(2) .dot{background:var(--green)}
.strip-item:nth-child(3) .dot{background:#60a5fa}

.community-strip{position:relative;overflow:hidden}
.community-strip::before{
  content:'';position:absolute;left:50%;top:8%;transform:translateX(-50%);
  width:min(760px,85vw);height:260px;
  background:radial-gradient(circle,rgba(216,90,48,.13),transparent 70%);
  pointer-events:none;
}
.community-strip .wrap{position:relative;z-index:1}
.community-photo-grid{
  display:grid;
  grid-template-columns:.92fr .92fr 1.22fr;
  gap:22px;
  margin:0 auto 42px;
  align-items:stretch;
}
.community-photo{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  border:1px solid rgba(248,250,252,.10);
  background:rgba(255,255,255,.04);
  box-shadow:0 24px 70px rgba(0,0,0,.24);
}
.community-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,23,42,.02) 0%,rgba(15,23,42,.18) 65%,rgba(15,23,42,.42) 100%);
  pointer-events:none;
}
.community-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.01);
}
.community-photo--one,
.community-photo--two{aspect-ratio:3 / 4}
.community-photo--three{aspect-ratio:5 / 4}
.community-photo--one img{object-position:center 46%}
.community-photo--two img{object-position:center 50%}
.community-photo--three img{object-position:center 58%}

/* ============================================================
   HOW IT WORKS
   ============================================================ */
.head-center{text-align:center;max-width:620px;margin:0 auto 56px}
.head-center .lead{margin-left:auto;margin-right:auto}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{
  background:#fff;border-radius:var(--radius);padding:36px 30px;
  border:1px solid #eef0f3;
  box-shadow:0 1px 3px rgba(15,23,42,.04),0 12px 32px rgba(15,23,42,.05);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(15,23,42,.10)}
.card .ico{
  width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:rgba(216,90,48,.10);margin-bottom:22px;
}
.card .ico svg{width:28px;height:28px;stroke:var(--coral)}
.card:nth-child(3) .ico{background:rgba(34,197,94,.12)}
.card:nth-child(3) .ico svg{stroke:var(--green)}
.card h3{font-size:21px;font-weight:600;margin-bottom:10px;letter-spacing:-0.01em}
.card p{color:#64748b;font-size:16px}

/* ============================================================
   SUSTAINABILITY
   ============================================================ */
.sus{position:relative;overflow:hidden}
.sus::after{content:'';position:absolute;top:50%;right:-140px;transform:translateY(-50%);
  width:480px;height:480px;background:radial-gradient(circle,rgba(34,197,94,.16),transparent 70%);pointer-events:none}
.sus .wrap{position:relative;z-index:1}
.sus-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.sus .eyebrow{color:var(--green)}
.sus h2{color:var(--light-text)}
.sus .lead{color:#cbd5e1}
.bullets{list-style:none;margin-top:28px;display:grid;gap:14px}
.bullets li{display:flex;align-items:center;gap:12px;font-size:16px;color:var(--light-text)}
.bullets li svg{width:20px;height:20px;stroke:var(--green);flex-shrink:0}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.kpi{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);padding:30px 26px;
}
.kpi:first-child{grid-column:1/-1}
.kpi .num{font-family:'Sora',sans-serif;font-size:42px;font-weight:700;color:var(--green);line-height:1;letter-spacing:-0.02em}
.kpi .lbl{font-size:14px;color:var(--muted);margin-top:10px}

/* ============================================================
   FEATURES
   ============================================================ */
.flow-pill{
  display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:center;
  margin:0 auto 0;font-family:'Sora',sans-serif;font-weight:600;font-size:clamp(16px,2.4vw,22px);
}
.flow-pill span{color:var(--dark-text)}
.flow-pill .arr{color:var(--coral);font-weight:700}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:52px}
.feat{
  background:#fff;border:1px solid #eef0f3;border-radius:16px;padding:26px 24px;
  display:flex;align-items:center;gap:16px;transition:border-color .2s ease, transform .2s ease;
}
.feat:hover{border-color:var(--coral);transform:translateY(-3px)}
.feat .fico{width:44px;height:44px;border-radius:12px;background:var(--dark);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.feat .fico svg{width:22px;height:22px;stroke:var(--coral)}
.feat span{font-weight:600;font-size:16px;letter-spacing:-0.01em}

/* ============================================================
   APP MOCKUP PREVIEW
   ============================================================ */
.app-preview-section{position:relative;overflow:hidden}
.app-preview-section::before{
  content:'';position:absolute;inset:auto -12% 8% auto;
  width:520px;height:520px;
  background:radial-gradient(circle,rgba(216,90,48,.12),transparent 68%);
  pointer-events:none;
}
.app-preview-section .wrap{position:relative;z-index:1}
.app-preview-section h2{color:var(--light-text)}
.app-preview-section .lead{color:#cbd5e1}
.app-screens{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:28px;
  align-items:end;
  margin-top:58px;
}
.app-screen{
  position:relative;
  text-align:center;
  padding:0;
  background:transparent;
  border:none;
  box-shadow:none;
  transition:transform .2s ease;
}
.app-screen::before{
  content:'';
  position:absolute;
  left:50%;
  top:58%;
  transform:translate(-50%,-50%);
  width:78%;
  height:76%;
  border-radius:38px;
  background:radial-gradient(circle,rgba(216,90,48,.14),rgba(96,165,250,.08) 48%,transparent 72%);
  filter:blur(18px);
  pointer-events:none;
}
.app-screen:nth-child(2),
.app-screen:nth-child(4){transform:translateY(18px)}
.app-screen:hover{transform:translateY(-4px)}
.app-screen:nth-child(2):hover,
.app-screen:nth-child(4):hover{transform:translateY(10px)}
.app-screen img{
  position:relative;
  z-index:1;
  width:100%;
  max-width:250px;
  margin:0 auto;
  border-radius:34px;
  overflow:hidden;
  box-shadow:0 22px 48px rgba(0,0,0,.34), 0 0 0 1px rgba(248,250,252,.06);
}
.screen-label{
  position:relative;
  z-index:1;
  font-family:'Sora',sans-serif;
  font-size:14px;
  font-weight:700;
  color:#f8fafc;
  letter-spacing:.02em;
  margin-bottom:14px;
}
.app-screen:nth-child(2) .screen-label,
.app-screen:nth-child(4) .screen-label{color:#cbd5e1}

/* ============================================================
   EARLY ACCESS
   ============================================================ */
.ea{text-align:center}
.ea h2{color:var(--light-text);max-width:640px;margin:0 auto}
.ea .lead{margin:18px auto 0}
.benefits{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin:38px auto 40px;max-width:760px}
.benefit{
  display:inline-flex;align-items:center;gap:9px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.09);
  padding:11px 18px;border-radius:var(--radius-pill);font-size:15px;color:var(--light-text);
}
.benefit svg{width:17px;height:17px;stroke:var(--coral)}
.ea-form{max-width:480px;margin:0 auto;display:flex;gap:10px;flex-wrap:wrap}
.ea-form .ff-slot{flex:1;min-width:220px}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{
  text-align:center;
  background:linear-gradient(135deg,#D85A30 0%,#b8431f 100%);
  position:relative;overflow:hidden;
}
.final h2{color:#fff;font-size:clamp(30px,4.5vw,48px);font-weight:800;letter-spacing:-0.02em}
.final .btn{margin-top:30px;background:#0F172A;color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.25)}
.final .btn:hover{background:#000;transform:translateY(-2px)}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--dark);color:var(--muted);padding:56px 0 40px;border-top:1px solid rgba(248,250,252,.06)}
.foot-grid{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px}
.foot-logo svg{height:30px;width:auto}
.foot-links{display:flex;gap:28px;font-size:15px}
.foot-links a{color:var(--muted);transition:color .2s ease}
.foot-links a:hover{color:var(--coral)}
.foot-tag{font-family:'Sora',sans-serif;font-size:14px;color:var(--muted);margin-top:28px;text-align:center;width:100%}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease, transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE — mobile-first rules from spec
   ============================================================ */
@media(max-width:900px){
  :root{--sec-pad:64px}
  .hero-grid{min-height:520px;padding:64px 0 72px}
  /* on mobile, darken a touch more from the bottom so text over the
     lighter middle of the image stays readable */
  .hero::before{background:linear-gradient(180deg,rgba(15,23,42,.62) 0%,rgba(15,23,42,.36) 42%,rgba(15,23,42,.82) 100%)}
  .strip-grid{grid-template-columns:1fr;gap:18px}
  .community-photo-grid{grid-template-columns:1fr;gap:16px;max-width:640px}
  .community-photo--one,
  .community-photo--two,
  .community-photo--three{aspect-ratio:auto}
  .community-photo{min-height:240px}
  .app-screens{grid-template-columns:repeat(2,1fr);max-width:620px;margin-left:auto;margin-right:auto;gap:22px}
  .cards-3{grid-template-columns:1fr}
  .sus-grid{grid-template-columns:1fr;gap:40px}
  .feat-grid{grid-template-columns:1fr}
  .kpi:first-child{grid-column:auto}
  .kpi-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .nav .nav-cta{display:none}
  .foot-grid{flex-direction:column;text-align:center}
  .community-photo{min-height:220px}
  .app-screens{grid-template-columns:1fr;max-width:280px;gap:22px}
  .app-screen:nth-child(2),
  .app-screen:nth-child(4){transform:none}
  .app-screen:nth-child(2):hover,
  .app-screen:nth-child(4):hover{transform:translateY(-4px)}
}
/* ============================================================
   FORMIDABLE FORM — restyle to match Lumopa design.
   Scoped to .lumopa-form so other Formidable forms on the site
   (contact, etc.) keep their own styling.
   Layout: email input + submit button inline (pill style),
   matching the original hero/early-access form mock.
   ============================================================ */
.lumopa-form{max-width:480px;margin-top:32px}
.lumopa-form--main{margin:0 auto}

/* kill Formidable's default chrome */
.lumopa-form .frm_forms,
.lumopa-form .frm_form_fields,
.lumopa-form fieldset{border:0;margin:0;padding:0;background:none}
.lumopa-form .frm_fields_container{display:flex;gap:10px;flex-wrap:wrap;align-items:stretch}

/* the email field cell grows, submit stays auto */
.lumopa-form .frm_form_field{margin:0;flex:1;min-width:220px}
.lumopa-form .frm_form_field > label.frm_primary_label{display:none} /* no visible label */

/* email input — pill, matches design */
.lumopa-form input[type="email"],
.lumopa-form input[type="text"]{
  width:100%;
  padding:16px 20px;
  border-radius:999px;
  border:1.5px solid rgba(248,250,252,.18);
  background:rgba(15,23,42,.55);
  color:#fff;
  font-size:16px;
  font-family:'Inter',sans-serif;
  outline:none;
  -webkit-backdrop-filter:blur(4px);
  backdrop-filter:blur(4px);
  transition:border-color .2s ease, background .2s ease;
}
.lumopa-form input[type="email"]::placeholder,
.lumopa-form input[type="text"]::placeholder{color:#94A3B8}
.lumopa-form input[type="email"]:focus,
.lumopa-form input[type="text"]:focus{
  border-color:var(--coral);
  background:rgba(15,23,42,.7);
}

/* submit button — coral pill, matches .btn-primary */
.lumopa-form .frm_submit{margin:0;padding:0;flex:0 0 auto}
.lumopa-form .frm_submit button,
.lumopa-form button[type="submit"]{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Inter',sans-serif;font-weight:600;font-size:16px;
  padding:16px 32px;border-radius:999px;border:none;cursor:pointer;
  background:var(--coral);color:#fff;white-space:nowrap;
  box-shadow:0 8px 24px rgba(216,90,48,.28);
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease;
}
.lumopa-form .frm_submit button:hover,
.lumopa-form button[type="submit"]:hover{
  background:var(--coral-hover);transform:translateY(-2px);
  box-shadow:0 12px 30px rgba(216,90,48,.36);
}

/* success / confirmation message after submit */
.lumopa-form .frm_message,
.lumopa-form .frm_confirmation_msg{
  background:rgba(34,197,94,.10);
  border:1px solid rgba(34,197,94,.35);
  color:#bbf7d0;
  border-radius:16px;
  padding:18px 22px;
  font-size:16px;
  text-align:center;
  margin:0;
}

/* validation errors — subtle, on-brand */
.lumopa-form .frm_error{color:#fca5a5;font-size:13px;margin-top:6px}
.lumopa-form .frm_blank_field input{border-color:rgba(239,68,68,.6)}

/* the EARLY-ACCESS form sits on dark-2; inputs identical, but use a
   slightly different translucency for contrast */
.lumopa-form--main input[type="email"],
.lumopa-form--main input[type="text"]{background:rgba(255,255,255,.05)}
.lumopa-form--main input[type="email"]:focus,
.lumopa-form--main input[type="text"]:focus{background:rgba(255,255,255,.08)}

@media(max-width:560px){
  .lumopa-form .frm_fields_container{flex-direction:column}
  .lumopa-form .frm_submit button,
  .lumopa-form button[type="submit"]{width:100%}
}


/* ============================================================
   FINAL POLISH — Formidable button + community images
   ============================================================ */

/* Modern Lumopa form button. Overrides Formidable default blue submit. */
.lumopa-form .frm_submit button,
.lumopa-form button[type="submit"],
.lumopa-form input[type="submit"]{
  min-height:52px !important;
  padding:0 24px !important;
  border-radius:999px !important;
  border:1px solid rgba(248,250,252,.18) !important;
  background:linear-gradient(180deg,rgba(20,31,52,.92),rgba(15,23,42,.82)) !important;
  color:#F8FAFC !important;
  font-family:'Inter',sans-serif !important;
  font-size:15px !important;
  font-weight:700 !important;
  letter-spacing:-0.01em !important;
  box-shadow:0 14px 34px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.10) !important;
  -webkit-backdrop-filter:blur(10px);
  backdrop-filter:blur(10px);
}

.lumopa-form .frm_submit button:hover,
.lumopa-form button[type="submit"]:hover,
.lumopa-form input[type="submit"]:hover{
  background:linear-gradient(180deg,rgba(216,90,48,.96),rgba(191,76,38,.96)) !important;
  border-color:rgba(216,90,48,.55) !important;
  transform:translateY(-2px);
  box-shadow:0 16px 38px rgba(216,90,48,.28), inset 0 1px 0 rgba(255,255,255,.14) !important;
}

.lumopa-form input[type="email"],
.lumopa-form input[type="text"]{
  min-height:52px !important;
}

/* Community photos should feel like a design accent, not the main content. */
.community-strip{
  padding-top:82px;
  padding-bottom:82px;
}

.community-photo-grid{
  max-width:980px;
  gap:18px;
  margin-bottom:34px;
}

.community-photo{
  border-radius:26px;
}

.community-photo--one,
.community-photo--two,
.community-photo--three{
  aspect-ratio:16 / 11;
}

.community-photo--one img{object-position:center 54%}
.community-photo--two img{object-position:center 52%}
.community-photo--three img{object-position:center 66%}

.strip-grid{
  max-width:980px;
  margin:0 auto;
  align-items:center;
}

.strip-item{
  justify-content:center;
  text-align:center;
  line-height:1.25;
}

/* Less dominant app mockups; softer and cleaner. */
.app-screens{
  max-width:920px;
  margin-left:auto;
  margin-right:auto;
}

.app-screen img{
  max-width:220px;
}

@media(max-width:900px){
  .community-strip{
    padding-top:58px;
    padding-bottom:58px;
  }

  .strip-title{
    margin-bottom:28px;
  }

  .community-photo-grid{
    grid-template-columns:repeat(3,1fr);
    max-width:680px;
    gap:10px;
    margin-bottom:24px;
  }

  .community-photo--one,
  .community-photo--two,
  .community-photo--three{
    aspect-ratio:1 / 1;
  }

  .community-photo{
    min-height:0;
    border-radius:18px;
  }

  .strip-grid{
    grid-template-columns:repeat(3,1fr);
    gap:12px;
  }

  .strip-item{
    font-size:14px;
    gap:8px;
  }
}

@media(max-width:560px){
  .hero h1{
    font-size:clamp(38px,13vw,54px);
  }

  .lumopa-form .frm_fields_container{
    gap:10px;
  }

  .lumopa-form .frm_submit button,
  .lumopa-form button[type="submit"],
  .lumopa-form input[type="submit"]{
    width:100% !important;
  }

  .community-strip{
    padding-top:46px;
    padding-bottom:46px;
  }

  .strip-title{
    font-size:23px;
    max-width:360px;
    margin-bottom:22px;
  }

  .community-photo-grid{
    max-width:360px;
    gap:8px;
    margin-bottom:20px;
  }

  .community-photo{
    border-radius:14px;
  }

  .strip-grid{
    max-width:360px;
    gap:8px;
  }

  .strip-item{
    font-size:12px;
    gap:6px;
  }

  .strip-item .dot{
    width:7px;
    height:7px;
  }

  .app-screen img{
    max-width:210px;
  }
}

@media(max-width:420px){
  .community-photo-grid{
    max-width:310px;
  }

  .strip-grid{
    max-width:310px;
  }

  .strip-item{
    font-size:11px;
  }
}


/* ============================================================
   FINAL FIX 2 — form alignment, square community images, standard pages
   ============================================================ */

/* Formidable: keep email input and submit perfectly aligned */
.lumopa-form .frm_fields_container{
  display:grid !important;
  grid-template-columns:minmax(220px,1fr) auto !important;
  gap:12px !important;
  align-items:center !important;
}

.lumopa-form .frm_form_field,
.lumopa-form .frm_submit{
  margin:0 !important;
  padding:0 !important;
  align-self:center !important;
}

.lumopa-form input[type="email"],
.lumopa-form input[type="text"]{
  height:52px !important;
  min-height:52px !important;
  line-height:52px !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
}

.lumopa-form .frm_submit button,
.lumopa-form button[type="submit"],
.lumopa-form input[type="submit"]{
  height:52px !important;
  min-height:52px !important;
  line-height:1 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin:0 !important;
}

/* Community images: no overlap, same-size clean design tiles */
.community-photo-grid{
  grid-template-columns:repeat(3,1fr) !important;
  max-width:760px !important;
  gap:18px !important;
  margin:0 auto 28px !important;
}

.community-photo,
.community-photo--one,
.community-photo--two,
.community-photo--three{
  aspect-ratio:1 / 1 !important;
  min-height:0 !important;
  transform:none !important;
  border-radius:22px !important;
}

.community-photo img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center center !important;
  transform:none !important;
}

.strip-grid{
  max-width:760px !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:18px !important;
  margin:0 auto !important;
}

.strip-item{
  justify-content:center !important;
  text-align:center !important;
  font-size:15px !important;
}

/* Standard WP pages such as Privacy Policy */
.lumopa-standard-page{
  background:#0F172A;
  color:#F8FAFC;
}

.standard-page{
  padding:86px 0 96px;
  background:linear-gradient(180deg,#0F172A 0%,#111827 100%);
  min-height:60vh;
}

.standard-page-card{
  max-width:860px;
  margin:0 auto;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(248,250,252,.10);
  border-radius:28px;
  padding:52px;
  box-shadow:0 24px 70px rgba(0,0,0,.24);
}

.standard-page-card h1{
  color:#F8FAFC;
  font-size:clamp(34px,5vw,56px);
  line-height:1.05;
  letter-spacing:-0.03em;
  margin-bottom:30px;
}

.standard-page-content{
  color:#CBD5E1;
  font-size:17px;
  line-height:1.8;
}

.standard-page-content h2,
.standard-page-content h3{
  color:#F8FAFC;
  margin:34px 0 12px;
  line-height:1.2;
}

.standard-page-content p,
.standard-page-content ul,
.standard-page-content ol{
  margin-bottom:18px;
}

.standard-page-content ul,
.standard-page-content ol{
  padding-left:24px;
}

.standard-page-content a{
  color:#D85A30;
  text-decoration:underline;
  text-underline-offset:3px;
}

@media(max-width:560px){
  .lumopa-form .frm_fields_container{
    grid-template-columns:1fr !important;
  }

  .lumopa-form .frm_submit button,
  .lumopa-form button[type="submit"],
  .lumopa-form input[type="submit"]{
    width:100% !important;
  }

  .community-photo-grid{
    max-width:280px !important;
    gap:8px !important;
    margin-bottom:18px !important;
  }

  .community-photo,
  .community-photo--one,
  .community-photo--two,
  .community-photo--three{
    border-radius:12px !important;
  }

  .strip-grid{
    max-width:320px !important;
    gap:8px !important;
  }

  .strip-item{
    font-size:11px !important;
    gap:5px !important;
  }

  .standard-page{
    padding:52px 0 64px;
  }

  .standard-page-card{
    padding:30px 22px;
    border-radius:22px;
  }

  .standard-page-content{
    font-size:16px;
  }
}


/* ============================================================
   FINAL FIX 3 — desktop inline form + footer links
   ============================================================ */

/* Formidable outputs submit outside .frm_fields_container, so align at form level. */
.lumopa-form form,
.lumopa-form form.frm-show-form{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  flex-wrap:nowrap !important;
}

.lumopa-form .frm_fields_container{
  display:block !important;
  width:100% !important;
}

.lumopa-form .frm_form_field{
  width:100% !important;
  margin:0 !important;
  padding:0 !important;
}

.lumopa-form .frm_submit{
  flex:0 0 auto !important;
  width:auto !important;
  margin:0 !important;
  padding:0 !important;
  align-self:center !important;
}

.lumopa-form input[type="email"],
.lumopa-form input[type="text"]{
  width:100% !important;
  height:52px !important;
  min-height:52px !important;
  line-height:52px !important;
}

.lumopa-form .frm_submit button,
.lumopa-form button[type="submit"],
.lumopa-form input[type="submit"]{
  height:52px !important;
  min-height:52px !important;
  white-space:nowrap !important;
}

.foot-links{
  justify-content:flex-end;
}

@media(max-width:560px){
  .lumopa-form form,
  .lumopa-form form.frm-show-form{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:10px !important;
  }

  .lumopa-form .frm_submit,
  .lumopa-form .frm_submit button,
  .lumopa-form button[type="submit"],
  .lumopa-form input[type="submit"]{
    width:100% !important;
  }

  .foot-links{
    justify-content:center;
  }
}


/* ============================================================
   FINAL FIX 4 — force Formidable email + submit inline on desktop
   ============================================================ */

/* Formidable can render submit outside the fields container.
   This forces the actual <form> to be the horizontal flex wrapper. */
.lumopa-form form,
.lumopa-form form.frm-show-form{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:12px !important;
  max-width:480px !important;
  width:100% !important;
}

/* The fields container must shrink to the email field width instead of
   taking a full row and pushing Submit below. */
.lumopa-form .frm_form_fields,
.lumopa-form fieldset,
.lumopa-form .frm_fields_container{
  display:block !important;
  width:auto !important;
  flex:1 1 auto !important;
  min-width:0 !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
}

/* Any extra Formidable wrappers should not become new rows. */
.lumopa-form .frm_form_field,
.lumopa-form .frm_form_field.form-field,
.lumopa-form .frm_form_field.frm_required_field{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
  padding:0 !important;
  float:none !important;
  clear:none !important;
}

.lumopa-form .frm_submit{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  flex:0 0 auto !important;
  width:auto !important;
  min-width:auto !important;
  margin:0 !important;
  padding:0 !important;
  float:none !important;
  clear:none !important;
}

.lumopa-form input[type="email"],
.lumopa-form input[type="text"]{
  width:100% !important;
  height:52px !important;
  min-height:52px !important;
  line-height:52px !important;
  margin:0 !important;
  padding:0 20px !important;
  box-sizing:border-box !important;
}

.lumopa-form .frm_submit button,
.lumopa-form button[type="submit"],
.lumopa-form input[type="submit"]{
  width:auto !important;
  min-width:116px !important;
  height:52px !important;
  min-height:52px !important;
  margin:0 !important;
  padding:0 24px !important;
  box-sizing:border-box !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  white-space:nowrap !important;
}

/* Early-access form is centered, but still inline on desktop. */
.lumopa-form--main form,
.lumopa-form--main form.frm-show-form{
  margin-left:auto !important;
  margin-right:auto !important;
}

@media(max-width:560px){
  .lumopa-form form,
  .lumopa-form form.frm-show-form{
    flex-direction:column !important;
    align-items:stretch !important;
    max-width:100% !important;
  }

  .lumopa-form .frm_form_fields,
  .lumopa-form fieldset,
  .lumopa-form .frm_fields_container,
  .lumopa-form .frm_submit,
  .lumopa-form .frm_submit button,
  .lumopa-form button[type="submit"],
  .lumopa-form input[type="submit"]{
    width:100% !important;
  }
}


/* ============================================================
   FINAL FIX 5 — Formidable real markup layout
   Based on actual structure:
   #frm_field_7_container = email field
   #frm_field_6_container = submit field wrapper
   ============================================================ */

.lumopa-form{
  max-width:520px !important;
}

.lumopa-form form,
.lumopa-form form.frm-show-form{
  display:block !important;
  width:100% !important;
  max-width:520px !important;
}

.lumopa-form .frm_fields_container{
  display:grid !important;
  grid-template-columns:minmax(0,1fr) auto !important;
  column-gap:12px !important;
  row-gap:0 !important;
  align-items:center !important;
  width:100% !important;
  max-width:520px !important;
}

/* Email field */
.lumopa-form #frm_field_7_container{
  grid-column:1 !important;
  grid-row:1 !important;
  width:100% !important;
  min-width:0 !important;
  margin:0 !important;
  padding:0 !important;
  float:none !important;
  clear:none !important;
}

/* Submit wrapper field generated by Formidable */
.lumopa-form #frm_field_6_container{
  grid-column:2 !important;
  grid-row:1 !important;
  width:auto !important;
  min-width:0 !important;
  margin:0 !important;
  padding:0 !important;
  float:none !important;
  clear:none !important;
  align-self:center !important;
}

.lumopa-form #frm_field_6_container .frm_submit,
.lumopa-form .frm_submit.frm_flex{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  margin:0 !important;
  padding:0 !important;
}

/* Hidden fields should never influence layout */
.lumopa-form .frm_fields_container > input[type="hidden"]{
  display:none !important;
}

/* Email input and button same height */
.lumopa-form #frm_field_7_container input[type="email"],
.lumopa-form #frm_field_7_container input[type="text"]{
  width:100% !important;
  height:52px !important;
  min-height:52px !important;
  margin:0 !important;
  padding:0 20px !important;
  line-height:52px !important;
  box-sizing:border-box !important;
}

.lumopa-form #frm_field_6_container button.frm_button_submit,
.lumopa-form .frm_button_submit{
  width:auto !important;
  min-width:118px !important;
  height:52px !important;
  min-height:52px !important;
  margin:0 !important;
  padding:0 24px !important;
  line-height:1 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-sizing:border-box !important;
  white-space:nowrap !important;
}

/* Center the lower early-access form */
.lumopa-form--main,
.lumopa-form--main form,
.lumopa-form--main .frm_fields_container{
  margin-left:auto !important;
  margin-right:auto !important;
}

@media(max-width:560px){
  .lumopa-form,
  .lumopa-form form,
  .lumopa-form form.frm-show-form,
  .lumopa-form .frm_fields_container{
    max-width:100% !important;
  }

  .lumopa-form .frm_fields_container{
    grid-template-columns:1fr !important;
    row-gap:10px !important;
  }

  .lumopa-form #frm_field_7_container{
    grid-column:1 !important;
    grid-row:1 !important;
  }

  .lumopa-form #frm_field_6_container{
    grid-column:1 !important;
    grid-row:2 !important;
    width:100% !important;
  }

  .lumopa-form #frm_field_6_container .frm_submit,
  .lumopa-form #frm_field_6_container button.frm_button_submit,
  .lumopa-form .frm_button_submit{
    width:100% !important;
  }
}
