

:root {
  --ff-ink:        #1A202C;
  --ff-ink-2:      #2D3748;
  --ff-muted:      #5A6473;
  --ff-faint:      #8A93A2;
  --ff-accent:     #E53E3E;
  --ff-accent-d:   #C53030;
  --ff-surface:    #FFFFFF;
  --ff-surface-2:  #F7F9FB;
  --ff-surface-3:  #EEF2F6;
  --ff-line:       #E3E8EF;
  --ff-line-2:     #D5DCE4;
  --ff-radius:     12px;
  --ff-radius-sm:  8px;
  --ff-shadow:     0 1px 2px rgba(16,24,40,.04), 0 1px 3px rgba(16,24,40,.06);
  --ff-shadow-lg:  0 10px 30px rgba(16,24,40,.08);
  --ff-display:    'Manrope', system-ui, -apple-system, sans-serif;
  --ff-body:       'Inter', system-ui, -apple-system, sans-serif;

  --brand-primary: var(--ff-ink);
  --brand-accent:  var(--ff-accent);
  --paper:         var(--ff-surface);
  --paper-card:    var(--ff-surface);
  --ink:           var(--ff-ink);
  --ink-soft:      var(--ff-muted);
  --line:          var(--ff-line);
  --line-strong:   var(--ff-line-2);
  --font-display:  var(--ff-display);
  --font-body:     var(--ff-body);
}

html, body {
  background: var(--ff-surface);
  color: var(--ff-ink);
  font-family: var(--ff-body);
  -webkit-font-smoothing: antialiased;
}

body.page, body { line-height: 1.6; }

a { color: var(--ff-accent); }
a:hover { color: var(--ff-accent-d); }

h1,h2,h3,h4,h5 { font-family: var(--ff-display); color: var(--ff-ink); letter-spacing: -0.02em; }

.skip-link {
  position:absolute; left:-9999px; top:0; z-index:1000;
  background: var(--ff-ink); color:#fff; padding:.6rem 1rem; border-radius:0 0 var(--ff-radius-sm) 0;
}
.skip-link:focus { left:0; }

.ff-topbar {
  background: var(--ff-surface-2);
  border-bottom: 1px solid var(--ff-line);
  font-size: .82rem;
  color: var(--ff-muted);
}
.ff-topbar__inner {
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
  min-height:36px; padding:.35rem 0; flex-wrap:wrap;
}
.ff-topbar__hours { letter-spacing:.01em; }
.ff-topbar__links { display:flex; gap:.9rem; align-items:center; }
.ff-topbar__links a { color: var(--ff-ink-2); text-decoration:none; white-space:nowrap; font-weight:600; }
.ff-topbar__links a:hover { color: var(--ff-accent); }
@media (max-width:560px){ .ff-topbar__inner{justify-content:center;} .ff-topbar__hours{display:none;} }

.ff-header {
  background: var(--ff-surface);
  border-bottom: 1px solid var(--ff-line);
  position: sticky; top:0; z-index:50;
}
.ff-header__inner {
  display:flex; align-items:center; justify-content:space-between; gap:1.5rem;
  min-height:70px; padding:.65rem 0;
}
.ff-brand { display:inline-flex; align-items:center; gap:.7rem; text-decoration:none; }
.ff-brand__mark { display:inline-flex; color: var(--ff-ink); }
.ff-brand__name {
  font-family: var(--ff-display); font-weight:800; font-size:1.18rem;
  color: var(--ff-ink); letter-spacing:-.02em; line-height:1;
}
.ff-brand__accent { color: var(--ff-accent); }

.ff-nav { display:flex; align-items:center; }
.ff-nav__list { display:flex; align-items:center; gap:.35rem; list-style:none; margin:0; padding:0; }
.ff-nav__link {
  display:inline-flex; align-items:center; text-decoration:none;
  color: var(--ff-ink-2); font-family: var(--ff-body); font-weight:600; font-size:.95rem;
  padding:.5rem .85rem; border-radius: var(--ff-radius-sm);
}
.ff-nav__link:hover { color: var(--ff-ink); background: var(--ff-surface-2); }
.ff-nav__link--cta {
  background: var(--ff-accent); color:#fff; padding:.6rem 1.2rem; box-shadow: var(--ff-shadow);
}
.ff-nav__link--cta:hover { background: var(--ff-accent-d); color:#fff; }
.ff-nav__link--ghost { color: var(--ff-muted); }

.ff-nav__toggle {
  display:none; background:none; border:1px solid var(--ff-line-2); border-radius: var(--ff-radius-sm);
  width:44px; height:44px; align-items:center; justify-content:center; cursor:pointer; color: var(--ff-ink);
}
.ff-nav__toggle svg { width:22px; height:22px; }

@media (max-width: 860px) {
  .ff-nav__toggle { display:inline-flex; }
  .ff-nav { position:absolute; top:100%; left:0; right:0; background: var(--ff-surface);
    border-bottom:1px solid var(--ff-line); box-shadow: var(--ff-shadow-lg);
    max-height:0; overflow:hidden; transition:max-height .25s ease; }
  .ff-nav.is-open { max-height:520px; }
  .ff-header__inner { position:relative; flex-wrap:wrap; }
  .ff-nav__list { flex-direction:column; align-items:stretch; padding:.75rem 1rem 1.1rem; gap:.25rem; width:100%; }
  .ff-nav__link { padding:.7rem .5rem; }
  .ff-nav__link--cta { justify-content:center; margin-top:.4rem; }
}

.ffbtn, .button.is-primary, .btn-primary {
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  font-family: var(--ff-body); font-weight:700; font-size:1rem; line-height:1;
  padding:.95rem 1.6rem; border-radius: var(--ff-radius-sm); border:1px solid transparent;
  text-decoration:none; cursor:pointer; transition: background .15s ease, transform .05s ease;
}
.ffbtn--primary, .button.is-primary, .btn-primary {
  background: var(--ff-accent); color:#fff !important; box-shadow: var(--ff-shadow);
}
.ffbtn--primary:hover, .button.is-primary:hover, .btn-primary:hover { background: var(--ff-accent-d); color:#fff; }
.ffbtn--ghost {
  background: var(--ff-surface); color: var(--ff-ink) !important; border:1px solid var(--ff-line-2);
}
.ffbtn--ghost:hover { background: var(--ff-surface-2); border-color: var(--ff-ink); }
.ffbtn--dark { background: var(--ff-ink); color:#fff !important; }
.ffbtn--dark:hover { background:#000; color:#fff; }
.ffbtn--lg { padding:1.05rem 1.9rem; font-size:1.05rem; }
.ffbtn--block { width:100%; }

.ff-wrap { max-width:1120px; margin:0 auto; padding:0 1.5rem; }
.ff-eyebrow {
  display:inline-block; font-family: var(--ff-body); font-weight:700; font-size:.78rem;
  letter-spacing:.14em; text-transform:uppercase; color: var(--ff-accent); margin:0 0 .9rem;
}
.ff-dot { color: var(--ff-accent); }
.ff-section { padding: clamp(3.5rem, 7vw, 6rem) 0; }
.ff-section--alt { background: var(--ff-surface-2); }
.ff-section__head { max-width:680px; margin:0 auto clamp(2.5rem,5vw,3.5rem); text-align:center; }
.ff-section__title { font-size: clamp(1.9rem, 1.3rem + 2.4vw, 2.9rem); font-weight:800; margin:0 0 1rem; line-height:1.1; }
.ff-section__lede { font-size:1.12rem; color: var(--ff-muted); margin:0; line-height:1.65; }

.ff-hero { padding: clamp(4rem, 8vw, 7rem) 0 clamp(2.5rem, 5vw, 4rem); text-align:center; }
.ff-hero__inner { max-width:780px; margin:0 auto; }
.ff-hero__title { font-size: clamp(2.4rem, 1.4rem + 4vw, 4.2rem); font-weight:800; line-height:1.04; margin:0 0 1.4rem; }
.ff-hero__sub { font-size: clamp(1.1rem, 1rem + .5vw, 1.3rem); color: var(--ff-muted); margin:0 auto 2rem; max-width:620px; line-height:1.6; }
.ff-hero__cta { display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.4rem; }
.ff-hero__trust { font-size:.92rem; color: var(--ff-faint); margin:0; }
.ff-hero__trust strong { color: var(--ff-ink); }
.ff-hero__media { max-width:1120px; margin: clamp(2.5rem,5vw,4rem) auto 0; padding:0 1.5rem; }
.ff-hero__frame {
  border-radius:18px; overflow:hidden; border:1px solid var(--ff-line); box-shadow: var(--ff-shadow-lg);
  aspect-ratio: 16/8; background: var(--ff-surface-3);
}
.ff-hero__frame img { width:100%; height:100%; object-fit:cover; display:block; }

.ff-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; max-width:820px; margin:2.5rem auto 0; }
.ff-stat { text-align:center; }
.ff-stat__num { display:block; font-family: var(--ff-display); font-weight:800; font-size:2.4rem; color: var(--ff-ink); line-height:1; }
.ff-stat__num .ff-dot { font-size:.5em; }
.ff-stat__label { display:block; margin-top:.45rem; font-size:.9rem; color: var(--ff-muted); }
@media (max-width:560px){ .ff-stats{grid-template-columns:1fr; gap:1.75rem;} }

.ff-cards { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.ff-card {
  background: var(--ff-surface); border:1px solid var(--ff-line); border-radius: var(--ff-radius);
  padding:2rem 1.85rem; box-shadow: var(--ff-shadow);
}
.ff-card__icon {
  display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px;
  border-radius: var(--ff-radius-sm); background: rgba(229,62,62,.08); color: var(--ff-accent); margin-bottom:1.1rem;
}
.ff-card__title { font-size:1.2rem; font-weight:700; margin:0 0 .55rem; }
.ff-card__body { color: var(--ff-muted); margin:0; font-size:.97rem; line-height:1.62; }

.ff-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1.25rem; }
.ff-tile {
  border:1px solid var(--ff-line); border-radius: var(--ff-radius); overflow:hidden;
  background: var(--ff-surface); box-shadow: var(--ff-shadow); text-decoration:none; display:block;
}
.ff-tile:hover { box-shadow: var(--ff-shadow-lg); transform: translateY(-2px); transition: all .15s ease; }
.ff-tile__art { aspect-ratio:4/3; background: var(--ff-surface-3); overflow:hidden; }
.ff-tile__art img { width:100%; height:100%; object-fit:cover; display:block; }
.ff-tile__body { padding:.95rem 1.05rem 1.15rem; }
.ff-tile__cat { display:block; font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color: var(--ff-accent); margin-bottom:.3rem; }
.ff-tile__title { display:block; font-family: var(--ff-display); font-weight:700; color: var(--ff-ink); font-size:1.02rem; margin-bottom:.2rem; }
.ff-tile__meta { display:block; font-size:.85rem; color: var(--ff-faint); }
.ff-grid-foot { text-align:center; color: var(--ff-muted); margin:2rem auto 0; max-width:640px; }

.ff-lib-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
@media (max-width: 640px) {
  .ff-lib-grid { grid-template-columns: repeat(2, 1fr); }
}
.ff-lib-thumb {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--ff-radius);
  aspect-ratio: 4 / 3;
  background: var(--ff-surface-3);
  text-decoration: none;
  box-shadow: var(--ff-shadow);
  transition: transform .18s ease, box-shadow .18s ease;
}
.ff-lib-thumb:hover { transform: translateY(-3px) scale(1.01); box-shadow: var(--ff-shadow-lg); }
.ff-lib-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ff-lib-thumb__chip {
  position: absolute;
  bottom: .6rem;
  left: .65rem;
  background: rgba(0,0,0,.65);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .25rem .55rem;
  border-radius: 4px;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.ff-plan {
  max-width:480px; margin:0 auto; background: var(--ff-surface);
  border:1px solid var(--ff-line); border-radius: 18px; padding: clamp(2rem,4vw,2.75rem);
  box-shadow: var(--ff-shadow-lg); text-align:center;
}
.ff-plan__badge { display:inline-block; font-size:.75rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color: var(--ff-accent); background: rgba(229,62,62,.08); padding:.35rem .8rem; border-radius:99px; margin-bottom:1.1rem; }
.ff-plan__name { font-size:1.5rem; font-weight:800; margin:0 0 .3rem; }
.ff-plan__period { color: var(--ff-muted); margin:0 0 1.2rem; font-size:.95rem; }
.ff-plan__price { font-family: var(--ff-display); font-weight:800; color: var(--ff-ink); line-height:1; margin:0 0 .5rem; }
.ff-plan__price sup { font-size:1.4rem; font-weight:700; vertical-align:super; }
.ff-plan__price b { font-size: clamp(3rem,2rem+3vw,4rem); }
.ff-plan__price small { font-size:1rem; font-weight:600; color: var(--ff-muted); }
.ff-plan__initial { font-size:.9rem; color: var(--ff-muted); margin:.2rem 0 1.4rem; }
.ff-plan__features { list-style:none; margin:1.4rem 0; padding:0; text-align:left; }
.ff-plan__features li { position:relative; padding:.55rem 0 .55rem 1.9rem; color: var(--ff-ink-2); border-bottom:1px solid var(--ff-line); font-size:.97rem; }
.ff-plan__features li:last-child { border-bottom:none; }
.ff-plan__features li::before { content:""; position:absolute; left:0; top:.95rem; width:18px; height:18px;
  background: var(--ff-accent); border-radius:50%;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/14px no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/14px no-repeat; }
.ff-plan__trial { font-size:.85rem; color: var(--ff-faint); margin:1rem 0 0; }
.ff-plan__descriptor { font-size:.82rem; color: var(--ff-faint); margin:1rem 0 0; }
.ff-plan__descriptor strong { color: var(--ff-ink-2); }

.ff-faq { max-width:760px; margin:0 auto; }
.ff-faq__item { border:1px solid var(--ff-line); border-radius: var(--ff-radius); margin-bottom:.85rem; background: var(--ff-surface); overflow:hidden; }
.ff-faq__q {
  display:flex; justify-content:space-between; align-items:center; gap:1rem; cursor:pointer; list-style:none;
  padding:1.15rem 1.4rem; font-family: var(--ff-display); font-weight:700; color: var(--ff-ink); font-size:1.05rem;
}
.ff-faq__q::-webkit-details-marker { display:none; }
.ff-faq__q::after { content:"+"; color: var(--ff-accent); font-weight:700; font-size:1.4rem; line-height:1; }
.ff-faq__item[open] .ff-faq__q::after { content:"\2212"; }
.ff-faq__a { padding:0 1.4rem 1.3rem; color: var(--ff-muted); line-height:1.65; }
.ff-faq__a p { margin:0; }

.ff-footer { background: var(--ff-ink); color:#CBD3DE; padding: clamp(3rem,5vw,4rem) 0 1.5rem; }
.ff-footer a { color:#CBD3DE; text-decoration:none; }
.ff-footer a:hover { color:#fff; }
.ff-footer__grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem; }
.ff-footer__name { font-family: var(--ff-display); font-weight:800; color:#fff; font-size:1.15rem; margin:.6rem 0 .25rem; }
.ff-footer__tag { color:#8A93A2; margin:0 0 .9rem; font-size:.9rem; }
.ff-footer__address { color:#8A93A2; font-style:normal; font-size:.85rem; line-height:1.5; }
.ff-footer__heading { font-family: var(--ff-body); font-weight:700; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:#fff; margin:0 0 .9rem; }
.ff-footer__nav ul, .ff-footer__contact ul { list-style:none; margin:0; padding:0; }
.ff-footer__nav li, .ff-footer__contact li { margin-bottom:.55rem; font-size:.92rem; }
.ff-footer__mark { color: var(--ff-accent); display:inline-flex; }
.ff-footer__base {
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.75rem;
  border-top:1px solid rgba(255,255,255,.1); margin-top:2.5rem; padding-top:1.5rem; font-size:.82rem; color:#8A93A2;
}
.ff-footer__payment { display:flex; justify-content:center; margin-top:1.25rem; }
@media (max-width:780px){ .ff-footer__grid{grid-template-columns:1fr 1fr;} }
@media (max-width:480px){ .ff-footer__grid{grid-template-columns:1fr;} .ff-footer__base{flex-direction:column; text-align:center;} }

.btn.btn-primary, button.signup-submit, .signup-pay, .signup-submit {
  background: var(--ff-accent); color:#fff; border:1px solid transparent; border-radius: var(--ff-radius-sm);
  font-family: var(--ff-body); font-weight:700;
}
.btn.btn-primary:hover, button.signup-submit:hover, .signup-pay:hover { background: var(--ff-accent-d); color:#fff; }
.legal-prose { color: var(--ff-ink-2); line-height:1.7; }
.legal-prose h1,.legal-prose h2,.legal-prose h3 { color: var(--ff-ink); }
.legal-prose a { color: var(--ff-accent); }

.page--members, body { background: var(--ff-surface); }
.visually-hidden { position:absolute!important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); white-space:nowrap; border:0; }
