/* --- WP NAV HARD FIX (scoped, high-specificity) --- */
.cfl-embed header.cfl-header{
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
}

.cfl-embed header.cfl-header .container.nav-inner{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 18px !important;
  flex-wrap: nowrap !important;
}

.cfl-embed header.cfl-header a.brand{
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  white-space: nowrap !important;
  flex: 0 0 auto !important;
}

.cfl-embed header.cfl-header nav.cfl-nav.nav-links{
  display: inline-flex !important;
  align-items: center !important;
  gap: 18px !important;
  flex-wrap: nowrap !important;
  white-space: nowrap !important;
  margin: 0 !important;
  padding: 0 !important;
}

.cfl-embed header.cfl-header nav.cfl-nav.nav-links a{
  display: inline-flex !important;
  align-items: center !important;
  padding: 10px 10px !important;
  border-radius: 999px !important;
  line-height: 1 !important;
}

.cfl-embed header.cfl-header .nav-cta{
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex: 0 0 auto !important;
}

/* If WP theme forces nav elements to block */
.cfl-embed header.cfl-header nav,
.cfl-embed header.cfl-header nav a,
.cfl-embed header.cfl-header .nav-cta a{
  float: none !important;
}

/* Prevent theme max-width / padding oddities */
.cfl-embed header.cfl-header .container{
  width: min(1120px, calc(100% - 48px)) !important;
  margin-inline: auto !important;
}

/* On smaller screens allow horizontal scroll instead of stacking */
@media (max-width: 980px){
  .cfl-embed header.cfl-header nav.cfl-nav.nav-links{
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }
  .cfl-embed header.cfl-header nav.cfl-nav.nav-links::-webkit-scrollbar{ display:none !important; }
}

/* --- WordPress theme isolation / nav fix --- */
.cfl-embed, .cfl-embed * { box-sizing: border-box; }
.cfl-embed { font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji"; color: var(--ink); }
.cfl-embed a { text-decoration: none; color: inherit; }
.cfl-embed img { max-width: 100%; height: auto; display: block; }

.cfl-embed .nav, 
.cfl-embed header nav,
.cfl-embed .navbar,
.cfl-embed .topnav { all: unset; }

.cfl-embed .topbar,
.cfl-embed .nav-bar,
.cfl-embed .navwrap,
.cfl-embed .nav-inner,
.cfl-embed .nav__inner,
.cfl-embed .site-nav { all: unset; }

/* Force our header/nav layout */
.cfl-embed header { position: sticky; top: 0; z-index: 50; }
.cfl-embed .nav { position: relative; }
.cfl-embed .nav-inner,
.cfl-embed .topbar,
.cfl-embed .navwrap,
.cfl-embed .nav-bar { display: flex; align-items: center; justify-content: space-between; gap: 16px; }

/* Generic selectors used by the site (safe fallback) */
.cfl-embed .nav-container,
.cfl-embed .navbar,
.cfl-embed .topnav,
.cfl-embed .header-inner,
.cfl-embed .header__inner,
.cfl-embed .top {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}

/* Nav links row */
.cfl-embed .nav-links,
.cfl-embed nav ul,
.cfl-embed nav .links {
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap: nowrap;
  margin:0;
  padding:0;
  list-style:none;
}

/* Prevent WP themes from forcing vertical nav */
.cfl-embed nav ul li { margin:0; padding:0; }
.cfl-embed nav ul li a { display:inline-flex; align-items:center; padding:10px 10px; border-radius: 999px; }

/* Keep logo + title on one line */
.cfl-embed .brand,
.cfl-embed .logo-wrap,
.cfl-embed .brandmark {
  display:flex;
  align-items:center;
  gap:10px;
  flex: 0 0 auto;
  min-width: 220px;
}

@media (max-width: 820px){
  .cfl-embed .nav-links, .cfl-embed nav ul { gap: 10px; overflow-x:auto; -webkit-overflow-scrolling:touch; scrollbar-width:none; }
  .cfl-embed .nav-links::-webkit-scrollbar, .cfl-embed nav ul::-webkit-scrollbar { display:none; }
}


:root{
  --accent: #F97316;            /* orange */
  --accent-2: #FB923C;          /* lighter orange */
  --ink: #0B1220;               /* near-black */
  --muted: rgba(11,18,32,.72);
  --card: rgba(255,255,255,.78);
  --stroke: rgba(11,18,32,.10);
  --shadow: 0 20px 60px rgba(11,18,32,.12);
  --glow: 0 18px 60px rgba(249,115,22,.22);
}


:root{
  --bg1:#ffffff;
  --bg2:#f4f7ff;
  --bg3:#eef2ff;
  --text:#0b1220;
  --muted:#556176;
  --card: rgba(255,255,255,.72);
  --stroke: rgba(15,23,42,.12);
  --shadow: 0 20px 60px rgba(2,6,23,.08);
  --shadow2: 0 10px 30px rgba(2,6,23,.10);
  --accent: #F97316;
  --accent2:#F97316;
  --radius: 18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  color:var(--text);
  background:var(--bg1);
}

.bg{position:fixed; inset:0; z-index:-1}
.bg-gradient{
  position:absolute; inset:-20%;
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(37,99,235,.16), transparent 55%),
    radial-gradient(1100px 700px at 80% 25%, rgba(124,58,237,.12), transparent 60%),
    radial-gradient(900px 700px at 50% 100%, rgba(37,99,235,.10), transparent 60%),
    linear-gradient(180deg, var(--bg1), var(--bg2) 55%, var(--bg1));
  filter:saturate(1.05);
}
.bg-noise{
  position:absolute; inset:0;
  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='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.08'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
  opacity:.35;
}

.container{width:min(1120px, calc(100% - 40px)); margin:0 auto}

.nav{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: rgba(255,255,255,.65);
  border-bottom:1px solid var(--stroke);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0;
  gap:14px;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit}
.brand-dot{
  width:10px; height:10px; border-radius:999px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 0 6px rgba(37,99,235,.10);
}
.brand-text{font-weight:700; letter-spacing:-.02em}
.nav-links{display:flex; gap:18px}
.nav-links a{
  text-decoration:none; color:var(--muted); font-weight:500; font-size:14px;
  padding:8px 10px; border-radius:999px;
}
.nav-links a:hover{background: rgba(15,23,42,.06); color:var(--text)}
.nav-cta{display:flex; gap:10px; align-items:center}
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  font-weight:600; font-size:14px;
  text-decoration:none;
  border:1px solid transparent;
  transition: transform .08s ease, box-shadow .18s ease, background .18s ease;
  user-select:none;
}
.btn:active{transform: translateY(1px)}
.btn-solid{
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color:white;
  box-shadow: 0 12px 30px rgba(37,99,235,.18);
}
.btn-solid:hover{box-shadow: 0 16px 44px rgba(37,99,235,.22)}
.btn-ghost{
  background: rgba(255,255,255,.65);
  border-color: var(--stroke);
  color: var(--text);
}
.btn-ghost:hover{background: rgba(255,255,255,.9)}

.nav-burger{display:none; width:44px; height:40px; border-radius:12px; border:1px solid var(--stroke); background:rgba(255,255,255,.65)}
.nav-burger span{display:block; height:2px; background:var(--text); margin:6px 10px; border-radius:99px; opacity:.85}
.nav-mobile{border-top:1px solid var(--stroke); padding:10px 0 14px}
.nav-mobile a{display:block; padding:12px 8px; text-decoration:none; color:var(--text); font-weight:600}
.nav-mobile .btn{width:100%; margin-top:10px}

.hero{padding:64px 0 34px}
.hero-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:34px; align-items:center}
.pill{
  display:inline-flex; gap:10px; align-items:center;
  padding:10px 12px; border-radius:999px;
  background: rgba(255,255,255,.72);
  border:1px solid var(--stroke);
  box-shadow: var(--shadow2);
  color: var(--muted);
  font-size:13px; font-weight:600;
}
.pill-dot{width:8px; height:8px; border-radius:999px; background:var(--accent)}
h1{font-size:52px; line-height:1.05; margin:18px 0 14px; letter-spacing:-.03em}
.lead{font-size:17px; line-height:1.6; color:var(--muted); max-width:56ch}
.hero-actions{display:flex; gap:12px; margin-top:20px; flex-wrap:wrap}
.hero-metrics{display:flex; gap:16px; margin-top:26px; flex-wrap:wrap}
.metric{
  background: rgba(255,255,255,.65);
  border:1px solid var(--stroke);
  border-radius: 16px;
  padding:12px 14px;
  box-shadow: var(--shadow2);
  min-width: 150px;
}
.metric-num{font-weight:800; letter-spacing:-.02em}
.metric-label{color:var(--muted); font-size:13px; margin-top:4px}

.hero-media{position:relative}
.device-stack{position:relative; height:520px}
.device{
  border-radius: 26px;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.65);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.device img{display:block; width:100%; height:100%; object-fit:cover}
.device-phone{
  position:absolute; right:0; top:30px;
  width: 290px; height: 520px;
  transform: rotate(1.5deg);
}
.device-ipad{
  position:absolute; left:0; bottom:0;
  width: 520px; height: 360px;
  transform: rotate(-1.2deg);
}
.hero-note{
  margin-top:14px;
  color:var(--muted);
  font-size:13px;
}

.section{padding:56px 0}
.section-head{margin-bottom:18px}
.section-head.row{display:flex; align-items:flex-end; justify-content:space-between; gap:16px; flex-wrap:wrap}
h2{font-size:34px; margin:0 0 8px; letter-spacing:-.02em}
.section-head p{margin:0; color:var(--muted); line-height:1.6; max-width:70ch}

.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:14px;
  margin-top:20px;
}
.card{
  background: var(--card);
  border:1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding:18px 18px 16px;
}
.card h3{margin:0 0 8px; font-size:18px}
.card p{margin:0 0 12px; color:var(--muted); line-height:1.6}
.card ul{margin:0; padding-left:18px; color:var(--muted)}
.card li{margin:8px 0}

.toggle{
  display:inline-flex;
  background: rgba(255,255,255,.7);
  border:1px solid var(--stroke);
  border-radius:999px;
  padding:4px;
  box-shadow: var(--shadow2);
}
.toggle-btn{
  border:0;
  background:transparent;
  padding:10px 14px;
  border-radius:999px;
  font-weight:700;
  cursor:pointer;
  color:var(--muted);
}
.toggle-btn.is-active{
  background: rgba(15,23,42,.07);
  color:var(--text);
}

.gallery{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
  margin-top:18px;
}
.shot{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid var(--stroke);
  background: rgba(255,255,255,.6);
  box-shadow: var(--shadow2);
  cursor: zoom-in;
  min-height: 170px;
}
.shot img{width:100%; height:100%; object-fit:cover; display:block; transform:scale(1.01); transition: transform .25s ease}
.shot:hover img{transform:scale(1.05)}
.badge{
  position:absolute; left:10px; bottom:10px;
  padding:8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.82);
  border:1px solid var(--stroke);
  font-size:12px; font-weight:700;
}

.who-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
  margin-top:18px;
}
.who-card{
  background: var(--card);
  border:1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding:18px;
}
.who-card h3{margin:0 0 8px}
.who-card p{margin:0; color:var(--muted); line-height:1.6}

.steps{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:14px;
  margin-top:18px;
}
.step{
  display:flex; gap:14px;
  background: var(--card);
  border:1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding:18px;
}
.step-num{
  width:38px; height:38px; border-radius: 14px;
  display:flex; align-items:center; justify-content:center;
  background: rgba(37,99,235,.12);
  color: var(--text);
  font-weight:800;
}
.step-body h3{margin:0 0 6px}
.step-body p{margin:0; color:var(--muted); line-height:1.6}

.cta{
  border-radius: 26px;
  border:1px solid var(--stroke);
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: var(--shadow);
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}
.cta h2{margin:0 0 8px}
.cta p{margin:0; color:var(--muted); line-height:1.6}
.cta-actions{display:flex; gap:10px; flex-wrap:wrap}
.cta-fineprint{width:100%; margin-top:10px; color:var(--muted); font-size:12px}
code{background: rgba(15,23,42,.06); padding:2px 6px; border-radius:8px; border:1px solid rgba(15,23,42,.10)}

.faq{display:grid; gap:10px; margin-top:18px}
details{
  background: var(--card);
  border:1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
  padding:14px 16px;
}
summary{cursor:pointer; font-weight:800; list-style:none}
summary::-webkit-details-marker{display:none}
details p{color:var(--muted); line-height:1.6; margin:10px 0 0}

.footer{padding:28px 0 14px}
.footer-inner{display:flex; align-items:flex-start; justify-content:space-between; gap:14px; flex-wrap:wrap; border-top:1px solid var(--stroke); padding-top:18px}
.muted{color:var(--muted)}
.footer-right{display:flex; gap:14px}
.footer-right a{text-decoration:none; color:var(--muted); font-weight:600}
.footer-right a:hover{color:var(--text)}

.lightbox{
  position:fixed; inset:0;
  background: rgba(0,0,0,.72);
  display:none;
  align-items:center;
  justify-content:center;
  padding:26px;
  z-index:80;
}
.lightbox.is-open{display:flex}
.lightbox img{
  width:min(1100px, 92vw);
  height:auto;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.22);
  box-shadow: 0 30px 90px rgba(0,0,0,.45);
}
.lightbox-close{
  position:fixed; top:18px; right:18px;
  width:44px; height:44px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.14);
  color:white;
  font-size:24px;
  cursor:pointer;
}
.lightbox-caption{
  position:fixed; bottom:18px; left:50%;
  transform:translateX(-50%);
  color: rgba(255,255,255,.88);
  font-weight:700;
  font-size:13px;
  padding:10px 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
  max-width: 90vw;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr; }
  .device-stack{height:470px}
  .device-ipad{width: 520px; height: 330px; left:0}
  .device-phone{right:0; width: 260px; height: 470px}
  h1{font-size:44px}
  .cards{grid-template-columns: repeat(2, 1fr)}
  .gallery{grid-template-columns: repeat(3, 1fr)}
  .steps{grid-template-columns:1fr}
}
@media (max-width: 680px){
  .nav-links, .nav-cta{display:none}
  .nav-burger{display:block}
  h1{font-size:38px}
  .cards{grid-template-columns:1fr}
  .gallery{grid-template-columns: repeat(2, 1fr)}
  .who-grid{grid-template-columns:1fr}
  .device-ipad{width: 440px; height: 290px}
  .device-phone{width: 240px; height: 430px}
}


/* Overlay logo between iPhone and iPad screenshots */
.overlay-logo {
  position: absolute;
  width: 120px;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  background: white;
  border-radius: 50%;
  padding: 14px;
  box-shadow: 0 20px 40px rgba(0,0,0,0.25);
}
