/* ============================================================
   Lakefly, Custom AI Systems
   B&W operator aesthetic. Monochrome-first, one warm signal accent.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --ink:#0b0b0c;
  --ink-2:#141417;
  --ink-3:#1c1c20;
  --paper:#f7f6f4;
  --paper-2:#eceae6;
  --t-hi:#ffffff;
  --t-mid:#b7b7bd;
  --t-low:#7c7c84;
  --line:rgba(255,255,255,.12);
  --line-2:rgba(255,255,255,.07);
  --line-dark:rgba(11,11,12,.14);
  --accent:#e7b24c;          /* warm signal, used sparingly */
  --accent-dim:rgba(231,178,76,.16);
  --ok:#7bbf8f;
  --maxw:1200px;
  --pad:clamp(20px,5vw,64px);
  --display:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--t-hi);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#1a1a1a}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
section{position:relative}
.section{padding:clamp(54px,7vw,96px) 0}
.section--paper{background:var(--paper);color:var(--ink)}
.section--ink2{background:var(--ink-2)}
.section--build-photo{background:#070708;color:#fff;overflow:hidden;isolation:isolate}
.section--build-photo::before{content:"";position:absolute;inset:-28px;background:url("img/op7.jpg") center/cover no-repeat;filter:blur(10px) grayscale(100%) contrast(112%) brightness(.56);transform:scale(1.03);z-index:-2}
.section--build-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,7,8,.92) 0%,rgba(7,7,8,.78) 46%,rgba(7,7,8,.66) 100%);z-index:-1}
.section--build-photo .wrap{position:relative;z-index:1}
.section--build-photo .lead{color:rgba(255,255,255,.76)}
.section--build-photo .step{border-top-color:rgba(255,255,255,.18)}
.section--build-photo .step p{color:rgba(255,255,255,.62)}
.divider{height:1px;background:var(--line);border:0}

/* ---------- type ---------- */
h1,h2,h3{font-family:var(--display);font-weight:700;line-height:1.04;letter-spacing:-.02em}
.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--t-low);
  display:inline-flex;align-items:center;gap:12px;margin-bottom:22px;
}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--accent);display:inline-block}
.section--paper .eyebrow{color:#6a6a6a}
.h-xl{font-size:clamp(38px,6.4vw,76px)}
.h-lg{font-size:clamp(30px,4.6vw,52px)}
.h-md{font-size:clamp(23px,2.8vw,34px)}
.lead{font-size:clamp(17px,1.5vw,21px);color:var(--t-mid);line-height:1.6;max-width:62ch}
.section--paper .lead{color:#4a4a4a}
.dim{color:var(--t-low)}
.section--paper .dim{color:#9a9a9a}
.muted{color:var(--t-mid)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:0;
  font-family:var(--body);font-weight:600;font-size:16px;letter-spacing:-.01em;
  padding:16px 26px;border-radius:3px;transition:transform .15s ease,background .2s ease,color .2s ease;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--t-hi);color:var(--ink)}
.btn--primary:hover{background:var(--accent)}
.btn--ghost{background:transparent;color:var(--t-hi);border:1px solid var(--line)}
.btn--ghost:hover{border-color:var(--t-hi)}
.section--paper .btn--primary{background:var(--ink);color:#fff}
.section--paper .btn--primary:hover{background:var(--accent);color:var(--ink)}
.section--paper .btn--ghost{color:var(--ink);border-color:var(--line-dark)}
.section--paper .btn--ghost:hover{border-color:var(--ink)}
.btn--lg{font-size:17px;padding:19px 32px}
.arrow{transition:transform .18s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--pad);
  background:rgba(11,11,12,.55);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-2);transition:background .3s ease;
}
.nav.solid{background:rgba(11,11,12,.92)}
.brand{display:flex;align-items:center;gap:7px}
.brand__logo{height:27px;width:auto;display:block;flex-shrink:0}
.brand__mark{font-family:var(--display);font-weight:700;font-size:23px;letter-spacing:-.03em;color:#fff}
.brand__cat{font-family:var(--mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--t-mid);margin-left:11px}
.nav__links{display:flex;align-items:center;gap:34px}
.nav__links a{font-size:15px;color:var(--t-mid);transition:color .18s ease}
.nav__links a:hover{color:#fff}
.nav__cta{font-size:14px!important;color:#fff!important;border:1px solid var(--line);padding:10px 18px;border-radius:3px}
.nav__cta:hover{border-color:#fff;background:#fff;color:var(--ink)!important}
.nav__burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.nav__burger span{width:24px;height:2px;background:#fff;display:block}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:#000 center/cover no-repeat;filter:grayscale(100%) contrast(106%) brightness(.82)}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(95deg,rgba(8,8,9,.94) 0%,rgba(8,8,9,.78) 38%,rgba(8,8,9,.35) 72%,rgba(8,8,9,.2) 100%)}
.hero__grain{position:absolute;inset:0;opacity:.05;pointer-events:none;
  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='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 var(--pad)}
.hero__content{max-width:780px;padding-top:90px}
/* two-column integrated hero: copy + compact form on the left, live demo/result on the right */
.hero__cols{display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(26px,3.6vw,54px);align-items:center}
.hero__left{text-align:left;min-width:0}
.hero__left .hero__sub{max-width:54ch;margin-left:0;margin-right:0}
.hero__form{max-width:560px;margin:0}
.hero__right{min-width:0}
.hero__stage{max-width:none;margin:0;width:100%}
/* compact inline input row: field + button on one line */
.bw-inrow{display:flex;gap:10px;align-items:stretch}
.bw-inrow .bw-web{flex:1 1 auto;min-width:0;margin-bottom:0}
.bw-inrow .bw-go{flex:0 0 auto;width:auto;margin-top:0;white-space:nowrap}
@media(max-width:480px){.bw-inrow{flex-direction:column}.bw-inrow .bw-go{width:100%}}
/* make the hero input clearly visible on the dark photo (placeholder was gray-on-charcoal) */
.hero__form .bw-web{background:rgba(16,18,22,.86);border:1.5px solid rgba(255,255,255,.26);color:#fff;box-shadow:0 6px 22px rgba(0,0,0,.3)}
.hero__form .bw-web::placeholder{color:rgba(255,255,255,.6)}
.hero__form .bw-web:focus{border-color:var(--accent);background:rgba(16,18,22,.94)}
/* staged sample on the right before a real build runs */
.bw-stage{position:relative}
.bw-stage-cap{font-size:13px;color:var(--t-mid);margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
/* once a site is entered: drop the left column entirely and let the result go centered + full-width
   (wider, so the live mockup has room to breathe on desktop) */
body.bw-built .hero__cols{display:block}
body.bw-built .hero__left{display:none}
body.bw-built .hero__right{max-width:860px;margin:0 auto;width:100%}
body.bw-built .hero__stage{max-width:none}
@media(max-width:920px){.hero__cols{grid-template-columns:1fr;gap:26px}.hero__form{max-width:none}.hero__left .hero__sub{max-width:none}}
.hero__split{display:grid;grid-template-columns:1.02fr 1.2fr;gap:clamp(26px,4vw,54px);align-items:center}
.hero__split .hero__content{max-width:560px;padding-top:0}
.hero__gallery{min-width:0}
.eb-short{display:none}
@media(max-width:920px){.hero__split{grid-template-columns:1fr;gap:30px}.hero__split .hero__content{max-width:none}}
.hero h1{font-size:clamp(40px,6.7vw,82px);margin-bottom:26px}
.hero h1 .b2{color:var(--accent)}
.hero__sub{font-size:clamp(17px,1.6vw,21px);color:var(--t-mid);max-width:60ch;margin-bottom:36px;line-height:1.6}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero__proof{margin-top:46px;display:flex;gap:14px 24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:13.5px;letter-spacing:.03em;color:#d6d6db}
.hero__proof span{background:rgba(255,255,255,.05);border:1px solid var(--line);border-radius:99px;padding:7px 14px}
.hero__proof span{display:flex;align-items:center;gap:9px}
.hero__proof span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}

/* ---------- why-price (pricing trust-builder) ---------- */
.why-price__intro{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);margin-top:18px}
.why-price__intro .lead{margin:0}
.pricetiers{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px);margin-top:44px}
.pricetier{border:1px solid var(--line-dark);border-radius:11px;padding:clamp(22px,2.6vw,30px);background:#fff;display:flex;flex-direction:column;gap:9px}
.pricetier__n{font-family:var(--mono);font-size:12px;letter-spacing:.12em;color:var(--accent)}
.pricetier h4{font-family:var(--display);font-size:19px;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin:0}
.pricetier p{font-size:15px;line-height:1.5;color:#5a5a5a;margin:0}
.why-price__close{margin-top:36px;max-width:820px;font-size:17px;line-height:1.58;color:#3a3a3a;border-left:3px solid var(--accent);padding-left:20px}
/* offer section: copy left, stock photo panel right (fills the blank void) */
.offer__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,72px);align-items:center}
.offer__copy{min-width:0}
.offer__photo{align-self:stretch;min-height:440px;border-radius:12px;background-size:cover;background-position:center;position:relative;filter:grayscale(100%) contrast(1.04);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.offer__photo::after{content:"";position:absolute;inset:0;border-radius:12px;background:linear-gradient(160deg,rgba(8,10,14,.12),rgba(8,10,14,.5))}
@media(max-width:860px){.offer__grid{grid-template-columns:1fr}.offer__photo{min-height:240px}}
@media(max-width:760px){.why-price__intro{grid-template-columns:1fr;gap:14px}.pricetiers{grid-template-columns:1fr}}

/* ---------- problem ---------- */
.problem__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.leaklist{list-style:none;margin-top:30px;display:flex;flex-direction:column;gap:0}
.leaklist li{display:flex;gap:18px;padding:20px 0;border-top:1px solid var(--line-dark);font-size:17px;color:#3a3a3a}
.leaklist li:last-child{border-bottom:1px solid var(--line-dark)}
.leaklist .lk{font-family:var(--mono);font-size:12px;color:var(--accent);padding-top:4px;min-width:26px}
.statcard{background:var(--ink);color:#fff;padding:clamp(28px,4vw,42px);border-radius:6px}
.statcard .big{font-family:var(--display);font-size:clamp(44px,6vw,68px);font-weight:700;letter-spacing:-.03em;line-height:1}
.statcard .big .accent{color:var(--accent)}
.statcard p{color:var(--t-mid);margin-top:16px;font-size:15.5px}
.statcard hr{border:0;border-top:1px solid var(--line);margin:26px 0}

/* ---------- lead magnet band ---------- */
.magnet{background:var(--ink-2);border:1px solid var(--line);border-radius:10px;
  padding:clamp(34px,5vw,64px);display:grid;grid-template-columns:1.3fr .9fr;gap:clamp(30px,5vw,60px);align-items:center}
.magnet__badge{font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.magnet__panel{background:linear-gradient(180deg,var(--ink-3),var(--ink));border:1px solid var(--line);border-radius:8px;padding:30px}
.gauge{display:flex;align-items:flex-end;gap:14px;margin-bottom:6px}
.gauge__num{font-family:var(--display);font-size:64px;font-weight:700;line-height:.9;color:#fff}
.gauge__den{font-family:var(--mono);color:var(--t-low);font-size:15px;padding-bottom:8px}
.gauge__label{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--t-low);margin-bottom:18px}
.meter{height:8px;border-radius:99px;background:var(--ink-3);overflow:hidden;border:1px solid var(--line)}
.meter__fill{height:100%;width:74%;background:linear-gradient(90deg,#5a5a5a,var(--accent))}
.minirow{display:flex;justify-content:space-between;font-size:13px;color:var(--t-mid);margin-top:16px;font-family:var(--mono)}

/* ---------- steps ---------- */
.steps{counter-reset:s;display:grid;grid-template-columns:repeat(5,1fr);gap:24px;margin-top:54px}
.step{border-top:1px solid var(--line);padding-top:22px}
.section--paper .step{border-top-color:var(--line-dark)}
.step__n{counter-increment:s;font-family:var(--mono);font-size:13px;color:var(--accent);margin-bottom:14px}
.step__n::before{content:"Day " counter(s)}
.step h4{font-family:var(--display);font-size:18px;font-weight:600;margin-bottom:8px;letter-spacing:-.01em}
.step p{font-size:14.5px;color:var(--t-low)}
.section--paper .step p{color:#6a6a6a}

/* ---------- jobs menu ---------- */
.jobs{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:52px}
.job{background:var(--ink-2);border:1px solid var(--line);border-radius:7px;padding:24px;transition:border-color .2s ease,transform .2s ease}
.job:hover{border-color:var(--accent);transform:translateY(-3px)}
.job h4{font-family:var(--display);font-size:17px;font-weight:600;margin-bottom:14px}
.job .row{font-size:13px;line-height:1.5;margin-bottom:9px;color:var(--t-mid)}
.job .row b{color:#fff;font-weight:600;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;display:block;margin-bottom:2px;color:var(--t-low)}
.job .bar{font-family:var(--mono);font-size:12px;color:var(--accent);margin-top:14px;padding-top:12px;border-top:1px solid var(--line)}

/* ---------- guarantee ---------- */
.guards{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:48px}
.guard{display:flex;gap:18px;padding:26px;background:var(--paper-2);border-radius:7px}
.guard .chk{font-family:var(--mono);color:var(--ink);background:var(--accent);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700}
.guard p{font-size:15.5px;color:#333;line-height:1.5}
.guard p b{color:#0b0b0c;font-weight:600}

/* ---------- why now ---------- */
.why{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(30px,5vw,70px);align-items:center}
.why__big{font-family:var(--display);font-size:clamp(28px,3.6vw,44px);font-weight:700;letter-spacing:-.02em;line-height:1.1}
.why__big em{font-style:normal;color:var(--accent)}

/* ---------- final cta ---------- */
.finalcta{text-align:center;padding:clamp(58px,7vw,100px) 0}
.finalcta h2{font-size:clamp(32px,5vw,60px);margin-bottom:22px}
.finalcta .lead{margin:0 auto 38px}

/* ---------- footer ---------- */
.foot{background:#070708;border-top:1px solid var(--line-2);padding:64px 0 40px}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.foot__brand .brand__mark{font-size:26px}
.foot__brand p{color:var(--t-low);font-size:14px;margin-top:16px;max-width:34ch;line-height:1.6}
.foot h5{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--t-low);margin-bottom:16px}
.foot__col a{display:block;color:var(--t-mid);font-size:14.5px;margin-bottom:11px;transition:color .15s}
.foot__col a:hover{color:#fff}
.foot__bot{display:flex;justify-content:space-between;align-items:center;padding-top:26px;border-top:1px solid var(--line-2);
  font-family:var(--mono);font-size:12px;color:var(--t-low);flex-wrap:wrap;gap:12px}

/* ---------- reveal anim ---------- */
/* content is always visible, no fragile scroll-hide (screenshot-clean, SEO-clean, robust) */
.reveal,.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media(max-width:900px){
  /* drop backdrop-filter on mobile: it makes .nav the containing block for the
     fixed drawer, confining it to the nav bar. Solid bg instead. */
  .nav{backdrop-filter:none;background:rgba(11,11,12,.94)}
  .brand{position:relative;z-index:60}
  .nav__links{position:fixed;inset:0;width:100%;flex-direction:column;align-items:flex-start;
    justify-content:center;gap:28px;background:rgba(11,11,12,.98);backdrop-filter:blur(12px);padding:48px 40px;transform:translateX(100%);transition:transform .3s ease;z-index:55}
  .nav__links.open{transform:none}
  .nav__links a{font-size:20px}
  .nav__burger{display:flex;z-index:60}
  .problem__grid,.magnet,.why{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr;gap:20px}
  .jobs{grid-template-columns:1fr 1fr}
  .guards{grid-template-columns:1fr}
  .foot__top{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .jobs,.steps{grid-template-columns:1fr}
  .foot__top{grid-template-columns:1fr}
  .hero__proof{gap:14px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{justify-content:center}
  .brand__cat{display:inline-block;font-size:10.5px;letter-spacing:.05em;margin-left:8px;line-height:1;white-space:nowrap}
  .hero__inner{padding-top:88px!important;padding-bottom:48px!important}
  .foot__col a{font-size:15.5px}
  .foot__brand p{font-size:15px}
  .foot__bot{font-size:12.5px}
  .eb-full{display:none}
  .eb-short{display:inline}
}

/* phone: very evident, real human in Oshkosh (Daniel 2026-06-04) */
.nav__phone{font-family:inherit;font-size:14px;letter-spacing:0;color:var(--accent);font-weight:500;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.nav__phone::before{content:"\260E";font-size:13px}
.nav__phone:hover{color:#fff}
.hero-call{margin-top:18px;font-size:15px;color:var(--t-mid);line-height:1.55;max-width:50ch}
.hero-call a{color:var(--accent);text-decoration:underline;font-weight:600}
.hero-call a:hover{color:#fff}
