/* =====================================================================
   FocusFlow — cinematic landing page  ·  pure CSS, no build step
   Tokens from FOCUSFLOW_BUILD_SPEC.md + sampled /Assets
   ===================================================================== */
:root{
  --lime:#6BFF11; --emerald:#00FF89; --yellow:#FFD900; --green:#009636; --action:#078D35;
  --grad:linear-gradient(135deg,#00FF89 0%,#6BFF11 55%,#FFD900 100%);
  --c-progress:#314EC1;
  --bg:#070908; --bg-2:#0C0C0C; --green-black:#101B14;
  --s1:#1A1C1A; --s2:#242624; --s3:#343634;
  --hi:#FFFFFF; --mid:#E7E7E7; --lo:#9C9C9C; --faint:#6f726f;
  --glass:rgba(255,255,255,.045);
  --glass-bd:rgba(255,255,255,.085);
  --r:20px;
  --pad:clamp(64px,9.8vh,135px);
  --gut:clamp(20px,5vw,40px);
  --maxw:1280px;
  --font:"Manrope","Inter",system-ui,-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);background:var(--bg);color:var(--mid);
  line-height:1.18;letter-spacing:-.011em;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:rgba(107,255,17,.25);color:#fff}
:focus-visible{outline:2px solid var(--lime);outline-offset:3px;border-radius:6px}

/* ---------- scroll progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:100;
  background:var(--grad);box-shadow:0 0 12px rgba(107,255,17,.6)}

/* ---------- atmosphere ---------- */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.glow{position:absolute;border-radius:50%;filter:blur(150px)}
.glow-a{width:640px;height:640px;top:-170px;left:-130px;background:radial-gradient(circle,#0e6b39,transparent 70%);opacity:.5}
.glow-b{width:740px;height:740px;top:36%;right:-240px;background:radial-gradient(circle,#0a5230,transparent 70%);opacity:.4}
.glow-c{width:560px;height:560px;bottom:-190px;left:30%;background:radial-gradient(circle,#12502b,transparent 70%);opacity:.35}
.grain{position:absolute;inset:0;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%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)'/%3E%3C/svg%3E")}

/* ---------- glass + gradient hairline (premium edge) ---------- */
.glass{position:relative;background:rgba(255,255,255,.05);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-radius:var(--r);
  box-shadow:0 24px 70px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05)}
.glass::after{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;
  background:linear-gradient(160deg,rgba(255,255,255,.22),rgba(255,255,255,.02) 40%,rgba(107,255,17,.08));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* ---------- typography helpers ---------- */
.kicker{display:inline-flex;align-items:center;gap:12px;color:var(--emerald);
  text-transform:uppercase;letter-spacing:.26em;font-size:12px;font-weight:600;margin-bottom:24px}
.kicker.center{justify-content:center}
.kicker-line{width:34px;height:1px;background:linear-gradient(90deg,transparent,var(--emerald))}
.kicker.center .kicker-line:last-child{background:linear-gradient(90deg,var(--emerald),transparent)}
.sec-no{display:inline-block;color:var(--emerald);text-transform:uppercase;letter-spacing:.24em;
  font-size:12px;font-weight:600;margin-bottom:24px}
.section-head{max-width:760px}
.section-head.center{margin:0 auto;text-align:center}
.section-title{font-weight:200;color:var(--hi);line-height:1.03;
  font-size:clamp(34px,5.2vw,68px);letter-spacing:-.035em}
.section-lede{margin-top:22px;color:var(--lo);font-size:clamp(16px,1.4vw,19px);max-width:54ch;font-weight:300}
.section-head.center .section-lede{margin-left:auto;margin-right:auto}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.section-pad{padding-top:var(--pad);padding-bottom:var(--pad);
  padding-left:var(--gut);padding-right:var(--gut)}
#home,#dash,#app,#teams,#footer{scroll-margin-top:96px}

/* ---------- logomark ---------- */
.logomark{width:30px;height:30px;filter:drop-shadow(0 0 14px rgba(107,255,17,.45))}
.logomark.sm{width:22px;height:22px}

/* ---------- buttons — one consistent system, clear hierarchy ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 26px;border-radius:999px;font-family:inherit;font-size:15px;font-weight:600;letter-spacing:-.01em;
  cursor:pointer;border:1px solid transparent;overflow:hidden;white-space:nowrap;
  transition:transform .3s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s,border-color .3s;will-change:transform}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn.small{padding:11px 20px;font-size:14px}
.btn-arrow{font-size:1.05em;transition:transform .35s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(4px)}

/* PRIMARY — the single Flow action */
.btn-flow{background:var(--grad);color:#06210f;font-weight:700;
  box-shadow:0 8px 26px rgba(107,255,17,.28),inset 0 1px 0 rgba(255,255,255,.35)}
.btn-flow::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-18deg);transition:left .6s var(--ease)}
.btn-flow:hover{box-shadow:0 16px 44px rgba(107,255,17,.45),inset 0 1px 0 rgba(255,255,255,.4)}
.btn-flow:hover::before{left:130%}

/* SECONDARY — quiet, glassy */
.btn-ghost{background:rgba(255,255,255,.04);color:var(--mid);border-color:var(--glass-bd);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.08);color:var(--hi);border-color:rgba(255,255,255,.18)}

/* ---------- NAVBAR ---------- */
.nav{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:80;
  width:min(var(--maxw),calc(100% - 36px));display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:11px 13px 11px 22px;border-radius:999px;
  background:rgba(9,11,9,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--glass-bd);box-shadow:0 10px 40px rgba(0,0,0,.4);
  transition:padding .4s var(--ease),background .4s,box-shadow .4s,width .4s}
.nav.shrunk{padding-top:8px;padding-bottom:8px;width:min(1120px,calc(100% - 36px));
  background:rgba(7,9,8,.78);box-shadow:0 8px 30px rgba(0,0,0,.55),0 0 0 1px rgba(107,255,17,.07)}
.nav-brand{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--hi);font-size:17px}
.nav-center{display:flex;gap:4px;background:rgba(255,255,255,.03);padding:5px;border-radius:999px;border:1px solid rgba(255,255,255,.05)}
.nav-link{position:relative;padding:8px 18px;border-radius:999px;color:var(--lo);font-size:14px;font-weight:500;
  transition:color .25s,background .25s}
.nav-link:hover{color:var(--mid)}
.nav-link.active{color:#06210f;background:var(--grad);font-weight:600}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-burger span{width:22px;height:2px;background:var(--mid);border-radius:2px;transition:.3s}

/* ---------- avatars / pills ---------- */
.avatar{width:38px;height:38px;border-radius:50%;flex:0 0 38px;overflow:hidden;
  display:inline-block;background:#0d110d;box-shadow:0 0 0 2px rgba(7,9,8,.7)}
.ill{width:100%;height:100%;display:block}
.roster-avatars .avatar{margin-left:-10px}
.roster-avatars .avatar:first-child{margin-left:0}
.pill{display:inline-flex;align-items:center;gap:5px;padding:6px 13px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.05em;white-space:nowrap}
.pill-assigned{background:rgba(255,255,255,.08);color:var(--mid)}
.pill-accepted{background:var(--grad);color:#06210f}
.pill-progress{background:rgba(49,78,193,.22);color:#9db0ff}

/* ---------- HERO ---------- */
.hero{position:relative;z-index:2;min-height:100vh;
  display:grid;grid-template-columns:1.02fr .98fr;gap:48px;align-items:center;
  max-width:var(--maxw);margin:0 auto;padding:172px var(--gut) 110px}
.hero-title{font-weight:200;color:var(--hi);font-size:clamp(42px,6.6vw,90px);
  line-height:.98;letter-spacing:-.04em;margin-bottom:26px}
.hero-sub{color:var(--lo);font-size:clamp(16px,1.5vw,19px);max-width:44ch;font-weight:300}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-meta{display:flex;align-items:center;gap:16px;margin-top:42px;color:var(--lo);font-size:14px;flex-wrap:wrap}
.hero-meta strong{color:var(--hi);font-weight:700}
.dot-sep{width:4px;height:4px;border-radius:50%;background:var(--faint)}

.hero-stage{position:relative;height:540px}
.hero-glow{position:absolute;inset:4%;border-radius:46px;
  background:radial-gradient(circle at 60% 40%,rgba(0,255,137,.28),transparent 64%);filter:blur(44px)}
.hero-device-wrap{position:absolute;top:50%;left:50%;width:106%;transform:translate(-50%,-50%);transition:transform .25s var(--ease)}
.hero-device{width:100%;border-radius:18px;box-shadow:0 44px 100px rgba(0,0,0,.62),0 0 0 1px rgba(255,255,255,.04)}
.hero-reflection{position:absolute;left:6%;right:6%;bottom:-12%;height:24%;border-radius:50%;
  background:radial-gradient(ellipse at center,rgba(107,255,17,.22),transparent 70%);filter:blur(26px)}

.float-card{position:absolute;padding:16px;border-radius:20px;
  background:rgba(17,19,17,.94);
  border:1px solid var(--glass-bd);box-shadow:0 26px 64px rgba(0,0,0,.55);width:300px;will-change:transform}
.card-accepted{top:5%;right:-1%;border-color:rgba(107,255,17,.3);
  background:linear-gradient(135deg,rgba(10,74,40,.96),rgba(17,19,17,.96))}
.card-mini{bottom:7%;left:-3%;width:278px}
.fc-head{display:flex;align-items:center;gap:11px}
.fc-name{color:var(--hi);font-size:14px;font-weight:600}
.fc-name em{color:var(--lo);font-style:normal;font-weight:400}
.fc-time{color:var(--lo);font-size:12px;margin-top:2px}
.fc-flow{display:flex;align-items:center;gap:8px;margin-top:14px}
.fc-arrow{color:var(--lo);font-size:13px}
.card-mini .pill{margin-top:12px}
.stat-chip{position:absolute;top:42%;left:-4%;display:inline-flex;align-items:center;gap:9px;
  padding:10px 16px;border-radius:999px;font-size:13px;font-weight:600;color:var(--hi);
  background:rgba(17,19,17,.94);border:1px solid var(--glass-bd);box-shadow:0 18px 44px rgba(0,0,0,.5);will-change:transform}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(107,255,17,.6);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(107,255,17,.5)}70%{box-shadow:0 0 0 8px rgba(107,255,17,0)}100%{box-shadow:0 0 0 0 rgba(107,255,17,0)}}

.scroll-cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--faint);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  animation:cueBob 2.6s ease-in-out infinite;transition:color .25s,opacity .25s}
.scroll-cue:hover{color:var(--lo)}
@keyframes cueBob{0%,100%{transform:translate(-50%,0);opacity:.65}50%{transform:translate(-50%,6px);opacity:1}}
.scroll-track{width:20px;height:32px;border:1px solid var(--glass-bd);border-radius:999px;display:flex;justify-content:center;padding-top:6px}
.scroll-thumb{width:3px;height:7px;border-radius:3px;background:var(--lime);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{transform:translateY(0);opacity:1}80%{transform:translateY(10px);opacity:0}100%{opacity:0}}

/* ---------- MARQUEE ---------- */
.marquee{position:relative;z-index:2;overflow:hidden;padding:26px 0;
  border-top:1px solid var(--glass-bd);border-bottom:1px solid var(--glass-bd);
  -webkit-mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;align-items:center;gap:38px;white-space:nowrap;width:max-content;animation:marquee 44s linear infinite}
.marquee-track span{color:var(--lo);font-size:clamp(16px,2vw,22px);font-weight:300;letter-spacing:-.01em}
.marquee-track .m-dot{color:var(--lime);font-size:12px}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- DASH ---------- */
.dash{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto}
.dash-stage{display:grid;grid-template-columns:7fr 3fr;gap:24px;margin-top:54px;align-items:stretch}
.dash-frame{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--glass-bd);
  box-shadow:0 44px 110px rgba(0,0,0,.55);transition:transform .3s var(--ease)}
.dash-frame img{width:100%;height:100%;object-fit:cover}
.dash-frame .ffui{height:100%}
.frame-sheen{position:absolute;inset:0;pointer-events:none;background:linear-gradient(120deg,rgba(255,255,255,.07),transparent 38%)}
.dash-side{display:flex;flex-direction:column;gap:14px}
.feat{padding:18px 20px;flex:1;display:flex;flex-direction:column;justify-content:center;transition:transform .3s var(--ease)}
.feat-ic{font-size:18px;color:var(--lime);margin-bottom:8px}
.feat h3{color:var(--hi);font-size:17px;font-weight:600;margin-bottom:5px}
.feat p{color:var(--lo);font-size:13.5px;font-weight:300;line-height:1.5}
.dash-strip{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:24px}
.dash-shot{border-radius:22px;overflow:hidden;border:1px solid var(--glass-bd);box-shadow:0 30px 70px rgba(0,0,0,.5)}
.dash-shot img{width:100%;height:100%;object-fit:cover;max-height:560px;transition:transform .8s var(--ease)}
.dash-shot.tall img{max-height:720px}
.dash-shot:hover img{transform:scale(1.03)}

/* ---------- APP ---------- */
.app{position:relative;z-index:2;overflow:hidden}
.app-bg{position:absolute;inset:0;z-index:-1;background:radial-gradient(circle at 50% 118%,rgba(0,150,54,.22),transparent 58%)}
.metrics{max-width:var(--maxw);margin:56px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.metric{text-align:center;padding:27px 16px;transition:transform .3s var(--ease)}
.metric-num{display:block;font-size:clamp(48px,6vw,86px);font-weight:200;letter-spacing:-.04em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.metric-label{display:block;margin-top:10px;color:var(--lo);font-size:14px}
.app-grid{max-width:var(--maxw);margin:24px auto 0;display:grid;grid-template-columns:3fr 2fr;gap:24px}
.app-card{padding:30px;overflow:hidden;transition:transform .35s var(--ease)}
.app-card h3{color:var(--hi);font-size:22px;font-weight:600;margin-bottom:10px}
.app-card p{color:var(--lo);font-size:15px;font-weight:300;line-height:1.55;max-width:42ch}
.app-card.wide{display:flex;flex-direction:column;justify-content:space-between;min-height:260px}
.spark{width:100%;height:120px;margin-top:20px}
.spark-line{stroke-dasharray:1000;stroke-dashoffset:1000;filter:drop-shadow(0 0 6px rgba(107,255,17,.5))}
.spark-line.draw{animation:sparkdraw 1.5s ease forwards}
@keyframes sparkdraw{to{stroke-dashoffset:0}}
.app-card.studio .brand-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid var(--glass-bd);font-size:13px;font-weight:600;color:var(--hi);margin-bottom:18px}
.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.mini-chip{padding:7px 13px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--glass-bd);font-size:13px;color:var(--lo)}
.mini-chip.on{background:var(--grad);color:#06210f;border-color:transparent;font-weight:600}
.app-card.showcase{grid-column:1 / -1;padding:26px;display:grid;grid-template-columns:1fr 1fr;gap:26px}
.show-col{display:flex;flex-direction:column;gap:12px}
.show-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.show-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--emerald);font-weight:700}
.show-meta{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--lo)}
.show-meta .live-dot{width:7px;height:7px}
.show-step,.show-row{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:14px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);transition:transform .3s var(--ease),background .3s}
.show-step:hover,.show-row:hover{transform:translateX(3px);background:rgba(255,255,255,.05)}
.show-step p,.show-row p{color:var(--hi);font-size:14px;font-weight:500}
.show-step span:not(.ffui-check):not(.pill),.show-row span:not(.avatar){color:var(--lo);font-size:12px}
.show-step>div,.show-row>div{flex:1;min-width:0}
.show-step .pill.sm,.pill.sm{margin-left:auto;padding:4px 9px;font-size:10px}
.show-step.done .ffui-check{background:var(--grad);color:#06210f;border-color:transparent}
.avatar.sm{width:32px;height:32px;flex:0 0 32px}

/* ---------- TEAMS ---------- */
.teams{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding-bottom:clamp(22px,3.4vh,44px)}
.teams-board{margin-top:34px;columns:3;column-gap:22px}
.tcard{break-inside:avoid;margin-bottom:22px;padding:22px;display:inline-block;width:100%;
  transition:transform .35s var(--ease)}
.tcard:hover{transform:translateY(-5px)}
.tcard-tag{display:inline-block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--emerald);font-weight:700;margin-bottom:16px}
.tcard-body{color:var(--mid);font-size:14px;font-weight:300;line-height:1.55;margin-top:14px}
.tcard-body strong{color:var(--hi);font-weight:700}
.tcard .fc-flow{margin-top:16px}
.react-row{display:flex;gap:8px;margin-top:14px}
.react{padding:5px 11px;border-radius:999px;background:rgba(255,255,255,.05);border:1px solid var(--glass-bd);font-size:13px;color:var(--mid)}
.fc-name.lead{font-size:16px;margin-bottom:4px}
.wf-list{list-style:none;margin-top:14px;display:flex;flex-direction:column;gap:12px}
.wf-list li{display:flex;align-items:center;gap:10px;color:var(--mid);font-size:14px;font-weight:300}
.wf-dot{width:9px;height:9px;border-radius:50%;flex:0 0 9px}
.wf-owner{margin-left:auto;font-size:11px;font-weight:700;color:#06210f;background:var(--grad);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.roster-avatars{display:flex;margin-bottom:12px}
.roster .roster-avatars .avatar{width:46px;height:46px;flex:0 0 46px;margin-left:-12px;box-shadow:0 0 0 2px rgba(7,9,8,.85)}
.roster .roster-avatars .avatar:first-child{margin-left:0}
.avatar.more{display:flex;align-items:center;justify-content:center;background:var(--grad);
  color:#06210f;font-size:13px;font-weight:700}
.cta-card{background:linear-gradient(150deg,rgba(7,141,53,.28),var(--glass))}
.cta-card .btn{margin-top:18px}
.live-card{background:linear-gradient(150deg,rgba(7,141,53,.22),var(--glass))}
.live-card .tcard-tag{display:inline-flex;align-items:center;gap:7px}
.live-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:4px 0 4px}
.live-stat{display:flex;flex-direction:column;gap:4px;padding:13px 10px;border-radius:14px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.live-num{font-size:26px;font-weight:200;letter-spacing:-.03em;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.live-cap{font-size:10.5px;color:var(--lo);line-height:1.25}
.live-card .fc-flow{margin-top:16px}

/* ---------- FOOTER ---------- */
/* sits tight under Teams so it reads as a continuation; small breathing room before the base bar */
.footer{position:relative;z-index:2;margin-top:0}
.footer-cta{position:relative;text-align:center;padding:0 20px 30px}
.footer-title{font-weight:200;color:var(--hi);font-size:clamp(18px,3.3vw,42px);line-height:1.04;
  letter-spacing:-.035em;margin-bottom:0;white-space:nowrap}
.footer-title .ff-deep{color:#0a8f43}
/* split billboard → two clean glass frames with a gap + slight glow on hover */
.footer-frames{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:1667fr 1855fr;gap:clamp(16px,2vw,28px);align-items:stretch}
.footer-frame{margin:0;overflow:hidden;border-radius:22px}
.footer-frame img{width:100%;height:auto;display:block}
.footer-base{max-width:var(--maxw);margin:54px auto 0;padding:30px var(--gut) 56px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;border-top:1px solid var(--glass-bd)}
.footer-links{display:flex;gap:24px}
.footer-links a{color:var(--lo);font-size:14px;transition:color .25s}
.footer-links a:hover{color:var(--hi)}
.footer-meta{color:var(--faint);font-size:13px}

/* ---------- NATIVE DASHBOARD SURFACE (no raster faces) ---------- */
.device-frame{border-radius:20px;padding:7px;
  background:linear-gradient(160deg,#2c2f2c,#0d110d);
  box-shadow:0 44px 100px rgba(0,0,0,.62),0 0 0 1px rgba(255,255,255,.05),inset 0 1px 0 rgba(255,255,255,.08)}
.ffui{display:grid;grid-template-columns:172px 1fr 196px;
  background:var(--green-black);border-radius:14px;overflow:hidden;
  font-size:12px;line-height:1.3;color:var(--mid);border:1px solid rgba(255,255,255,.06)}
.ffui.compact{grid-template-columns:128px 1fr}
.ffui.compact .ffui-right{display:none}

.ffui-side{padding:14px 9px;display:flex;flex-direction:column;gap:2px;
  background:rgba(255,255,255,.015);border-right:1px solid rgba(255,255,255,.06)}
.ffui-brand{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--hi);
  font-size:13px;margin-bottom:14px;padding:0 6px}
.ffui-brand svg{width:17px;height:17px}
.ffui-nav{display:flex;align-items:center;gap:7px;padding:7px 9px;border-radius:9px;color:var(--lo);white-space:nowrap;overflow:hidden}
.ffui-nav i{margin-left:auto;font-style:normal;background:rgba(255,255,255,.08);padding:1px 7px;border-radius:99px;font-size:10px}
.ffui-nav.sub{padding-left:18px;font-size:11px}
.ffui-nav.active{background:var(--grad);color:#06210f;font-weight:600}
.ffui-nav.active i{background:rgba(6,33,15,.22);color:#06210f}
.ffui-nav.on i{background:rgba(107,255,17,.2);color:var(--lime)}

.ffui-main{padding:14px;display:flex;flex-direction:column;gap:10px;min-width:0}
.ffui-search{padding:9px 12px;border-radius:9px;background:rgba(255,255,255,.04);
  border:1px solid var(--glass-bd);color:var(--lo);font-size:11.5px}
.ffui-tabs{display:flex;gap:5px;flex-wrap:wrap}
.ffui-tabs span{padding:5px 11px;border-radius:99px;color:var(--lo);font-size:11px}
.ffui-tabs .on{background:rgba(255,255,255,.08);color:var(--hi)}
.ffui-feed{display:flex;flex-direction:column;gap:8px}
.ffui-act{display:flex;align-items:center;gap:9px;padding:10px;border-radius:11px;
  background:rgba(255,255,255,.025);border:1px solid rgba(255,255,255,.05)}
.ffui-act.on{background:linear-gradient(135deg,rgba(7,141,53,.4),rgba(107,255,17,.08));border-color:rgba(107,255,17,.32)}
.ffui-av{width:27px;height:27px;border-radius:50%;flex:0 0 27px;overflow:hidden;
  background:#0d110d;display:inline-block}
.ffui-act .who{color:var(--hi);font-weight:600;font-size:11.5px}
.ffui-act .who em{color:var(--lo);font-style:normal;font-weight:400}
.ffui-act .meta{color:var(--lo);font-size:10px;margin-top:1px}
.ffui-pill{margin-left:auto;padding:3px 8px;border-radius:99px;font-size:9px;font-weight:700;letter-spacing:.04em;white-space:nowrap}
.p-acc{background:var(--grad);color:#06210f}
.p-new{background:rgba(255,255,255,.08);color:var(--mid)}
.p-prog{background:rgba(49,78,193,.24);color:#9db0ff}
.p-rev{background:rgba(255,217,0,.16);color:var(--yellow)}
.p-done{background:rgba(107,255,17,.16);color:var(--lime)}

.ffui-right{padding:14px 12px;background:rgba(255,255,255,.015);border-left:1px solid rgba(255,255,255,.06)}
.ffui-rhead{display:flex;align-items:center;justify-content:space-between;color:var(--hi);font-weight:600;font-size:11.5px;margin-bottom:10px}
.ffui-rhead button{font-size:10px;padding:4px 9px;border-radius:99px;background:var(--grad);color:#06210f;border:none;font-weight:700;cursor:default}
.ffui-branch{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:11px;color:var(--mid)}
.ffui-branch:last-child{border-bottom:none}
.ffui-check{width:15px;height:15px;border-radius:4px;border:1px solid var(--s3);flex:0 0 15px;
  display:flex;align-items:center;justify-content:center;font-size:9px;color:transparent}
.ffui-branch.done .ffui-check{background:var(--grad);color:#06210f;border-color:transparent}
.ffui-branch.done span{color:var(--lo);text-decoration:line-through}

/* native info panels (replace strip images) */
.info-panel{padding:24px}
.ip-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.ip-head h3{color:var(--hi);font-size:17px;font-weight:600}
.ip-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--lo);background:rgba(255,255,255,.05);padding:4px 10px;border-radius:99px;border:1px solid var(--glass-bd)}
.ip-tag.up{color:var(--lime);background:rgba(107,255,17,.12);border-color:rgba(107,255,17,.2)}
.ip-tag .live-dot{width:7px;height:7px}
.ip-sub{color:var(--lo);font-size:12px;margin-bottom:14px;font-weight:300}
.ip-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.ip-stat{display:flex;flex-direction:column;gap:4px;padding:14px 12px;border-radius:14px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.ip-num{font-size:28px;font-weight:200;letter-spacing:-.03em;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1}
.ip-cap{font-size:11px;color:var(--lo)}
.ip-days{display:flex;gap:10px;margin-top:10px}
.ip-days span{flex:1;text-align:center;font-size:11px;color:var(--faint)}
.ip-list{list-style:none;display:flex;flex-direction:column}
.ip-list li{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.ip-list li:last-child{border-bottom:none}
.ip-list p{color:var(--mid);font-size:14px;font-weight:400}
.ip-list span:not(.ffui-check){color:var(--lo);font-size:12px}
.ip-done p{color:var(--lo)}
.ip-av{font-style:normal;margin-left:auto;width:28px;height:28px;flex:0 0 28px;border-radius:50%;
  background:var(--grad);color:#06210f;font-weight:700;font-size:10px;display:flex;align-items:center;justify-content:center}
.ip-bars{display:flex;align-items:flex-end;gap:10px;height:120px;margin-bottom:8px}
.ip-bars span{flex:1;border-radius:6px 6px 0 0;background:rgba(255,255,255,.1)}
.ip-bars .hot{background:var(--grad);box-shadow:0 0 16px rgba(107,255,17,.4)}
.ip-rows{display:flex;flex-direction:column;gap:12px}
.ip-row{display:flex;align-items:center;gap:11px}
.ip-row p{color:var(--mid);font-size:13px;font-weight:300}
.ip-row strong{color:var(--hi);font-weight:700}

/* ---------- motion helpers ---------- */
/* idle float — pure CSS, GPU transform only (no JS, no backdrop-filter) */
@keyframes floatY{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(0,-12px,0)}}
@keyframes floatYr{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(0,11px,0)}}
.float-a{animation:floatY 5s ease-in-out infinite}
.float-b{animation:floatYr 4.6s ease-in-out infinite}
.float-c{animation:floatY 3.8s ease-in-out infinite}
.float-slow{animation:floatY 6s ease-in-out infinite}
/* when JS cursor-parallax is active it drives the float transforms instead */
.parallax-on .float-a,.parallax-on .float-b,.parallax-on .float-c,
.parallax-on .hero-device-wrap{animation:none;will-change:transform}

/* reveal: enabled only when JS adds .reveal-on (offline => visible) */
.reveal-on [data-reveal]{opacity:0;transform:translate3d(0,24px,0);
  transition:opacity .65s var(--ease),transform .65s var(--ease)}
.reveal-on [data-reveal].in{opacity:1;transform:none}

/* staggered reveal — siblings cascade in (PulseFlow-style) */
.dash-side .feat:nth-child(2),.metrics .metric:nth-child(2),
.app-grid .app-card:nth-child(2),.dash-strip .info-panel:nth-child(2){transition-delay:.09s}
.dash-side .feat:nth-child(3),.metrics .metric:nth-child(3),
.app-grid .app-card:nth-child(3){transition-delay:.18s}

/* hover — every glass box comes ALIVE (lift + depth + lime edge).
   inset top-highlight matches the base glass so no stray line flickers in on hover. */
.feat,.metric,.app-card,.info-panel,.tcard,.dash-frame,.footer-frame{
  transition:transform .42s var(--ease),box-shadow .42s var(--ease)}
.feat:hover,.metric:hover,.app-card:hover,.info-panel:hover,.tcard:hover,
.dash-frame:hover,.footer-frame:hover{
  transform:translateY(-5px);
  box-shadow:0 38px 96px rgba(0,0,0,.5),0 0 0 1px rgba(107,255,17,.18),
    inset 0 1px 0 rgba(255,255,255,.06)}
/* green glow only where it reads well — small/medium cards, not the big product surfaces */
.feat:hover,.metric:hover,.info-panel:hover,.tcard:hover,
.app-card.studio:hover,.footer-frame:hover{
  box-shadow:0 38px 96px rgba(0,0,0,.5),0 0 0 1px rgba(107,255,17,.20),
    0 0 60px rgba(107,255,17,.12),inset 0 1px 0 rgba(255,255,255,.06)}
/* pause marquee on hover for a tactile beat */
.marquee:hover .marquee-track{animation-play-state:paused}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .app-grid{grid-template-columns:1fr}
  .teams-board{columns:2}
}
@media (max-width:860px){
  .nav-center{display:none}
  .nav-burger{display:flex}
  .nav>.btn-flow{display:none}
  .nav.open .nav-center{display:flex;position:absolute;top:60px;left:0;right:0;flex-direction:column;
    background:rgba(9,11,9,.96);backdrop-filter:blur(22px);border:1px solid var(--glass-bd);border-radius:20px;padding:12px;gap:6px}
  body{overflow-x:hidden}
  .hero{grid-template-columns:1fr;padding-top:130px;padding-bottom:90px}
  .hero-stage{height:430px;margin-top:14px}
  /* keep the dashboard preview fully on-screen once the hero stacks */
  .hero-device-wrap{width:100%}
  .scroll-cue{display:none}
  .dash-stage{grid-template-columns:1fr}
  .dash-strip{grid-template-columns:1fr}
  .metrics{grid-template-columns:1fr;gap:16px}
  .teams-board{columns:1}
  .footer-frames{grid-template-columns:1fr}
  .card-accepted{right:0}
  .card-mini{left:0}
  .stat-chip{left:0}
  .ffui{grid-template-columns:120px 1fr;font-size:11px}
  .ffui-right{display:none}
}
@media (max-width:520px){
  .hero-stage{height:370px}
  .float-card{width:236px;padding:13px}
  .card-mini{width:216px}
  .footer-cta{margin-top:-50px}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal-on [data-reveal]{opacity:1;transform:none}
  .float-slow,.float-a,.float-b,.float-c,.marquee-track,.live-dot,.scroll-thumb,.scroll-cue{animation:none!important}
}

/* ===================== START FLOW · CREATE FLOW MODAL ===================== */
.ff-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(2,4,3,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
.ff-modal.show{opacity:1;pointer-events:auto}
.ff-modal-card{position:relative;width:min(540px,94vw);max-height:92vh;overflow:auto;
  background:linear-gradient(180deg,#0e1310 0%,#0a0d0b 38%);border:1px solid var(--glass-bd);
  border-radius:26px;box-shadow:0 50px 130px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.06);
  transform:translateY(16px) scale(.97);transition:transform .34s var(--ease)}
.ff-modal.show .ff-modal-card{transform:none}

/* visual header — gradient glow band + logomark badge (not a plain title box) */
.ff-modal-head{position:relative;padding:30px 30px 8px;overflow:hidden}
.ff-modal-head::before{content:"";position:absolute;top:-60%;left:-10%;width:60%;height:160%;
  background:radial-gradient(circle,rgba(0,255,137,.20),transparent 70%);filter:blur(34px);pointer-events:none}
.ff-modal-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;
  width:48px;height:48px;border-radius:15px;margin-bottom:18px;
  background:radial-gradient(circle at 35% 25%,rgba(107,255,17,.20),rgba(255,255,255,.03));
  border:1px solid rgba(107,255,17,.28);box-shadow:0 10px 30px rgba(107,255,17,.18)}
.ff-modal-badge svg{width:26px;height:26px;filter:drop-shadow(0 0 10px rgba(107,255,17,.5))}
.ff-modal-head .kicker{margin-bottom:12px}
.ff-modal-head h3{font-weight:200;color:var(--hi);font-size:30px;letter-spacing:-.035em}
.ff-modal-head p{margin-top:12px;color:var(--lo);font-size:14px;font-weight:300;line-height:1.55;max-width:42ch}
.ff-modal-head p strong{color:var(--lime);font-weight:600}
.ff-modal-x{position:absolute;top:22px;right:22px;z-index:2;width:36px;height:36px;border-radius:11px;cursor:pointer;
  background:rgba(255,255,255,.05);border:1px solid var(--glass-bd);color:var(--mid);font-size:15px;
  display:flex;align-items:center;justify-content:center;transition:.2s}
.ff-modal-x:hover{background:rgba(255,255,255,.1);color:var(--hi);transform:rotate(90deg)}

.ff-modal-body{padding:14px 30px 4px;display:flex;flex-direction:column;gap:15px}
.ff-row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ff-field{display:flex;flex-direction:column;gap:7px}
.ff-field>span{font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:600}
/* softer, lighter fields — less hard-boxed, lit underline on focus */
.ff-field input,.ff-field select,.ff-field textarea{font-family:inherit;font-size:14px;color:var(--hi);
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:13px;padding:13px 15px;outline:none;
  transition:border-color .25s,background .25s,box-shadow .25s}
.ff-field input::placeholder,.ff-field textarea::placeholder{color:var(--faint)}
.ff-field textarea{min-height:74px;resize:none}
.ff-field input:focus,.ff-field select:focus,.ff-field textarea:focus{
  border-color:rgba(107,255,17,.5);background:rgba(255,255,255,.05);box-shadow:0 0 0 3px rgba(107,255,17,.12)}
.ff-field select{appearance:none;-webkit-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%239C9C9C' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center}
.ff-field select option{background:#0c0f0d;color:var(--mid)}

/* live preview — the form rendered as a real Flow card */
.ff-preview{margin-top:4px}
.ff-preview-label{display:block;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);font-weight:600;margin-bottom:9px}
.ff-preview-card{position:relative;border-radius:16px;padding:16px 17px;
  background:linear-gradient(150deg,rgba(10,74,40,.30),rgba(17,19,17,.6));
  border:1px solid rgba(107,255,17,.18);box-shadow:0 14px 40px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.05)}
.ffp-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.ffp-cat{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--lime)}
.pill.ffp-pill{padding:4px 9px;font-size:10px}
.ffp-name{font-size:17px;font-weight:500;color:var(--hi);letter-spacing:-.02em;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ffp-foot{display:flex;align-items:center;gap:9px;margin-top:13px}
.ffp-av{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  font-size:10px;font-weight:700;color:#06210f;background:var(--grad);flex:none}
.ffp-owner{font-size:13px;color:var(--mid);font-weight:500}

.ff-modal-foot{padding:18px 30px 28px;display:flex;gap:12px;flex-wrap:wrap}
@media (max-width:520px){.ff-row2{grid-template-columns:1fr}.ff-modal-head h3{font-size:25px}}
