@font-face {
  font-family: "Oceanwide";
  src: url("../fonts/Oceanwide-Semibold.otf") format("opentype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Oceanwide";
  src: url("../fonts/Oceanwide-SemiboldOblique.otf") format("opentype");
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}

:root{
  /* Bright laboratory palette */
  --fl-bg: #FFF9F2;
  --fl-ink: rgba(20, 21, 26, .92);
  --fl-muted: rgba(20, 21, 26, .72);
  --fl-dim: rgba(20, 21, 26, .56);

  --fl-card: rgba(255,255,255,.74);
  --fl-stroke: rgba(20, 21, 26, .12);
  --fl-shadow: 0 24px 70px rgba(20, 21, 26, .12);

  --fl-lime: #2EE78D;
  --fl-orange: #FF8A2A;
  --fl-lemon: #FFD23D;
  --fl-berry: #7C4DFF;
  --fl-sky: #2BB8FF;

  --fl-radius: 26px;
  --fl-radius-sm: 16px;
  --fl-container: 1160px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  color: var(--fl-ink);
  background:
    radial-gradient(900px 520px at 12% -10%, rgba(46,231,141,.22), transparent 60%),
    radial-gradient(860px 540px at 88% 0%, rgba(255,138,42,.20), transparent 58%),
    radial-gradient(920px 580px at 50% 110%, rgba(43,184,255,.18), transparent 60%),
    var(--fl-bg);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  line-height: 1.45;
}

a{ color: inherit; text-decoration:none; }
a:hover{ text-decoration: underline; }
img{ max-width:100%; height:auto; display:block; }

.fl-container{
  max-width: var(--fl-container);
  margin: 0 auto;
  padding: 0 18px;
}

/* Top announcement bar */
.fl-ribbon{
  background: linear-gradient(90deg, rgba(255,210,61,.55), rgba(46,231,141,.35), rgba(43,184,255,.35));
  border-bottom: 1px solid rgba(20,21,26,.10);
}
.fl-ribbon__in{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 12px;
  padding: 10px 0;
  font-size: 12px;
  color: var(--fl-muted);
}
.fl-ribbon__pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.60);
  border: 1px solid rgba(20,21,26,.10);
}
.fl-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--fl-orange), var(--fl-berry));
  box-shadow: 0 0 0 4px rgba(255,138,42,.15);
}

/* Header */
.fl-header{
  position: sticky;
  top: 0;
  z-index: 60;
  background: rgba(255,249,242,.72);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(20,21,26,.10);
}
.fl-top{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap: 12px;
  padding: 12px 0;
}
.fl-brand{
  display:flex;
  align-items:center;
  gap: 10px;
  justify-content:center;
}
.fl-brand__logo{
  width: 36px;
  height: 36px;
  padding: 6px;
  border-radius: 14px;
  background: rgba(255,255,255,.70);
  border: 1px solid rgba(20,21,26,.12);
  box-shadow: 0 14px 30px rgba(20,21,26,.12);
}
.fl-brand__name{
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: .2px;
  font-size: 14px;
  line-height: 1.05;
}
.fl-brand__tag{
  display:block;
  font-size: 12px;
  color: var(--fl-dim);
  margin-top: 3px;
}

.fl-nav{
  display:flex;
  gap: 8px;
  align-items:center;
}
.fl-nav a{
  font-size: 13px;
  color: var(--fl-muted);
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid transparent;
}
.fl-nav a:hover{
  background: rgba(255,255,255,.60);
  border-color: rgba(20,21,26,.10);
  text-decoration:none;
  color: var(--fl-ink);
}

.fl-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: 10px;
}
.fl-btn{
  appearance:none;
  border: 1px solid rgba(20,21,26,.12);
  background: rgba(255,255,255,.65);
  border-radius: 999px;
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1;
  cursor:pointer;
  box-shadow: 0 16px 36px rgba(20,21,26,.10);
}
.fl-btn:hover{ background: rgba(255,255,255,.92); }
.fl-btn--prime{
  border-color: rgba(46,231,141,.35);
  background: linear-gradient(180deg, rgba(46,231,141,.26), rgba(46,231,141,.12));
}
.fl-btn--prime:hover{
  background: linear-gradient(180deg, rgba(46,231,141,.34), rgba(46,231,141,.16));
}
.fl-btn--ghost{
  background: transparent;
  box-shadow: none;
}

.fl-burger{
  display:none;
  width: 44px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(20,21,26,.12);
  background: rgba(255,255,255,.65);
}
.fl-burger span{
  display:block;
  width: 18px;
  height: 2px;
  background: rgba(20,21,26,.78);
  margin: 4px auto;
  border-radius: 2px;
}

/* Offcanvas menu */
.fl-scrim{
  position: fixed;
  inset: 0;
  background: rgba(20,21,26,.36);
  display:none;
  z-index: 80;
}
.fl-scrim[data-open="1"]{ display:block; }
.fl-drawer{
  position: fixed;
  top: 0;
  right: 0;
  width: min(92vw, 420px);
  height: 100vh;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(12px);
  border-left: 1px solid rgba(20,21,26,.10);
  box-shadow: -18px 0 60px rgba(20,21,26,.20);
  transform: translateX(104%);
  transition: transform .22s ease;
  z-index: 90;
  padding: 14px;
}
.fl-drawer[data-open="1"]{ transform: translateX(0); }
.fl-drawer__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 10px;
}
.fl-drawer__title{
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-size: 16px;
  margin: 0;
}
.fl-drawer__links{
  margin-top: 12px;
  display:flex;
  flex-direction:column;
  gap: 8px;
}
.fl-drawer__links a{
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.70);
  color: var(--fl-muted);
}
.fl-drawer__links a:hover{
  color: var(--fl-ink);
  text-decoration:none;
  background: rgba(255,255,255,.95);
}

/* Layout blocks */
.fl-hero{
  padding: 26px 0 14px;
}
.fl-hero__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 14px;
  align-items: stretch;
}
.fl-panel{
  border: 1px solid var(--fl-stroke);
  border-radius: var(--fl-radius);
  background:
    radial-gradient(680px 320px at 15% 0%, rgba(255,138,42,.18), transparent 60%),
    radial-gradient(640px 320px at 100% 10%, rgba(124,77,255,.14), transparent 58%),
    rgba(255,255,255,.72);
  box-shadow: var(--fl-shadow);
}
.fl-hero__copy{ padding: 20px; }
.fl-kicker{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(20,21,26,.10);
  font-size: 12px;
  color: var(--fl-muted);
}
.fl-kicker b{
  font-weight: 600;
  color: var(--fl-ink);
}
.fl-h1{
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-weight: 600;
  font-size: 46px;
  line-height: 1.03;
  margin: 12px 0 8px;
}
.fl-h1 em{
  font-style: italic;
  background: linear-gradient(90deg, var(--fl-orange), var(--fl-berry));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.fl-lead{
  margin: 0;
  color: var(--fl-muted);
  max-width: 62ch;
}
.fl-cta{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 14px;
}

.fl-hero__mix{
  padding: 16px;
  background:
    radial-gradient(720px 360px at 20% -10%, rgba(46,231,141,.18), transparent 60%),
    radial-gradient(640px 360px at 110% 10%, rgba(43,184,255,.18), transparent 60%),
    rgba(255,255,255,.72);
}
.fl-meter{
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.fl-meter__row{
  border-radius: 18px;
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.70);
  padding: 12px;
}
.fl-meter__t{
  margin:0;
  font-size: 12px;
  color: var(--fl-dim);
}
.fl-meter__v{
  margin: 4px 0 0;
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-size: 15px;
}
.fl-scale{
  height: 10px;
  border-radius: 999px;
  background: rgba(20,21,26,.08);
  margin-top: 10px;
  overflow:hidden;
}
.fl-scale > i{
  display:block;
  height: 100%;
  width: 60%;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--fl-lime), var(--fl-lemon), var(--fl-orange));
}

.fl-section{ padding: 22px 0; }
.fl-head{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap: 14px;
  margin-bottom: 12px;
}
.fl-h2{
  margin:0;
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-size: 26px;
}
.fl-sub{
  margin:0;
  color: var(--fl-dim);
  max-width: 74ch;
  font-size: 13px;
}

.fl-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 12px;
}
.fl-card{
  grid-column: span 4;
  padding: 14px;
  border-radius: var(--fl-radius);
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.72);
  box-shadow: 0 16px 44px rgba(20,21,26,.10);
}
.fl-card--wide{ grid-column: span 6; }
.fl-card--tall{ grid-column: span 4; }
.fl-card__h{
  margin: 0 0 6px;
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-size: 16px;
}
.fl-card__p{
  margin: 0;
  color: var(--fl-muted);
  font-size: 13px;
}
.fl-tags{ margin-top: 10px; display:flex; flex-wrap:wrap; gap: 8px; }
.fl-tag{
  font-size: 12px;
  color: var(--fl-muted);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.70);
}

.fl-recipes{
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
}
.fl-recipe{
  padding: 14px;
  border-radius: var(--fl-radius);
  border: 1px solid rgba(20,21,26,.10);
  background:
    radial-gradient(640px 260px at 20% 0%, rgba(255,210,61,.22), transparent 60%),
    rgba(255,255,255,.74);
  box-shadow: 0 18px 50px rgba(20,21,26,.10);
}
.fl-recipe__name{
  margin: 0;
  font-family: Oceanwide, ui-sans-serif, system-ui, sans-serif;
  font-size: 16px;
}
.fl-recipe__mix{
  margin: 6px 0 0;
  color: var(--fl-muted);
  font-size: 13px;
}
.fl-recipe details{ margin-top: 10px; }
.fl-recipe summary{
  cursor:pointer;
  font-size: 13px;
  color: var(--fl-ink);
  list-style:none;
}
.fl-recipe summary::-webkit-details-marker{ display:none; }
.fl-recipe__steps{
  margin: 8px 0 0;
  padding-left: 18px;
  color: var(--fl-muted);
  font-size: 13px;
}

.fl-split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items:start;
}

.fl-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 12px;
}
.fl-field{ display:flex; flex-direction:column; gap: 6px; }
.fl-label{ font-size: 12px; color: var(--fl-dim); }
.fl-input, .fl-select, .fl-textarea{
  width:100%;
  border-radius: 16px;
  border: 1px solid rgba(20,21,26,.12);
  background: rgba(255,255,255,.82);
  color: var(--fl-ink);
  padding: 10px 12px;
  font-size: 13px;
}
.fl-textarea{ min-height: 110px; resize: vertical; }
.fl-form__actions{
  grid-column: 1 / -1;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  align-items:center;
}
.fl-note{ margin:0; font-size: 12px; color: var(--fl-dim); }

.fl-map{
  border-radius: var(--fl-radius);
  overflow:hidden;
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.72);
  min-height: 360px;
  box-shadow: 0 18px 52px rgba(20,21,26,.10);
}
.fl-map iframe{ width:100%; height:100%; border:0; display:block; min-height: 360px; }

.fl-faq{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.fl-faq__item{
  border-radius: var(--fl-radius);
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.74);
  padding: 12px;
}
.fl-faq__btn{
  width:100%;
  display:flex;
  justify-content:space-between;
  gap: 10px;
  align-items:center;
  border:0;
  background: transparent;
  color: var(--fl-ink);
  padding: 0;
  cursor:pointer;
  text-align:left;
  font-size: 13px;
}
.fl-faq__ans{
  margin-top: 10px;
  color: var(--fl-muted);
  font-size: 13px;
  display:none;
}
.fl-faq__item[data-open="1"] .fl-faq__ans{ display:block; }
.fl-faq__icon{
  width: 28px;
  height: 28px;
  border-radius: 12px;
  border: 1px solid rgba(20,21,26,.10);
  background: rgba(255,255,255,.78);
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  color: var(--fl-muted);
}

.fl-footer{
  border-top: 1px solid rgba(20,21,26,.10);
  margin-top: 26px;
  padding: 18px 0 24px;
  color: var(--fl-dim);
  font-size: 12px;
}
.fl-footer__in{
  display:flex;
  justify-content:space-between;
  gap: 14px;
  align-items:flex-start;
  flex-wrap:wrap;
}
.fl-links{ display:flex; gap: 12px; flex-wrap:wrap; }
.fl-links a{ color: var(--fl-dim); }
.fl-links a:hover{ color: var(--fl-ink); text-decoration:underline; }

@media (max-width: 980px){
  .fl-top{ grid-template-columns: 1fr auto 1fr; }
  .fl-nav{ display:none; }
  .fl-burger{ display:inline-block; }
  .fl-hero__grid{ grid-template-columns: 1fr; }
  .fl-recipes{ grid-template-columns: 1fr; }
  .fl-split{ grid-template-columns: 1fr; }
  .fl-faq{ grid-template-columns: 1fr; }
  .fl-card{ grid-column: span 6; }
  .fl-card--wide{ grid-column: span 12; }
}

@media (max-width: 560px){
  .fl-h1{ font-size: 34px; }
  .fl-form{ grid-template-columns: 1fr; }
  .fl-card{ grid-column: span 12; }
  .fl-top{ grid-template-columns: 1fr auto; }
  .fl-brand{ justify-content:flex-start; }
  .fl-actions{ justify-content:flex-end; }
}

