/* ===========================================================
   Marketing sections (used across landing pages)
   =========================================================== */

/* ---- Bento feature grid ----
   4-column rhythm. Spans:
     lg   = 2 cols × 2 rows  (hero feature card)
     md   = 2 cols × 1 row
     sm   = 1 col  × 1 row
     full = 4 cols × 1 row
*/
.bento {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: minmax(220px, auto);
  gap: var(--space-5);
}
.bento__cell {
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--duration) var(--ease-out),
              box-shadow var(--duration) var(--ease-out),
              border-color var(--duration) var(--ease-out);
}
.bento__cell:hover {
  transform: translateY(-4px);
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-md);
}
.bento__cell::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), color-mix(in srgb, var(--color-primary) 12%, transparent) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--duration) var(--ease-out);
  pointer-events: none;
  z-index: -1;
}
.bento__cell:hover::before { opacity: 1; }

.bento__cell--lg   { grid-column: span 2; grid-row: span 2; }
.bento__cell--md   { grid-column: span 2; }
.bento__cell--sm   { grid-column: span 1; }
.bento__cell--full { grid-column: span 4; }

/* Horizontal layout (text left, chips right) used by the bilingual/offline cell. */
.bento__cell--row {
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  padding: var(--space-10) var(--space-12);
}
.bento__cell--row > .bento__cell-text { flex: 1; min-width: 0; }
.bento__cell--row > .bento__cell-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  flex-shrink: 0;
  max-width: 100%;
}
@media (max-width: 880px) {
  .bento__cell--row {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-4);
    padding: var(--space-6);
  }
  .bento__cell--row > .bento__cell-chips { width: 100%; }
}

.bento__cell h3 {
  font-size: var(--fs-2xl);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-snug);
  line-height: 1.15;
}
.bento__cell--sm h3 { font-size: var(--fs-xl); }
.bento__cell p {
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}
.bento__cell-visual {
  margin-top: auto;
  padding-top: var(--space-4);
}

/* Iconic visual previews inside bento cells */
.preview-card {
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.preview-card__circle {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--color-accent-soft);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.preview-card__circle svg { width: 18px; height: 18px; color: var(--color-accent-dark); }
.preview-card__txt { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.preview-card__label { font-size: var(--fs-xs); color: var(--color-text-soft); text-transform: uppercase; letter-spacing: 0.06em; font-weight: var(--weight-medium); }
.preview-card__val { font-weight: var(--weight-bold); color: var(--color-text); }

/* Mini calendar visual */
.mini-cal {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-top: var(--space-4);
}
.mini-cal__day {
  aspect-ratio: 1;
  border-radius: 6px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  position: relative;
  font-size: 10px;
  color: var(--color-text-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--weight-medium);
}
.mini-cal__day--income { background: var(--color-accent-soft); color: var(--color-accent-dark); border-color: rgba(146,211,80,0.3); font-weight: var(--weight-bold); }
.mini-cal__day--expense { background: var(--color-red-soft); color: var(--color-red); border-color: rgba(239,68,68,0.3); font-weight: var(--weight-bold); }
.mini-cal__day--today { box-shadow: 0 0 0 2px var(--color-primary); }
.mini-cal__day::after { content: var(--num); }

/* Code-like strip used as visual filler */
.code-strip {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-3) var(--space-4);
  color: var(--color-text-muted);
  display: flex;
  align-items: center;
  gap: 8px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  min-width: 0;
}
@media (max-width: 640px) {
  .code-strip {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    /* Soft fade on the right edge to hint that there's more to scroll. */
    -webkit-mask-image: linear-gradient(to right, black 88%, transparent 100%);
            mask-image: linear-gradient(to right, black 88%, transparent 100%);
  }
  .code-strip::-webkit-scrollbar { display: none; }
}
.code-strip__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-accent); flex-shrink: 0; }
.code-strip span { color: var(--color-primary); font-weight: var(--weight-semibold); }

/* Tablet: keep the 4-col rhythm but let large/medium cells span the row. */
@media (max-width: 1024px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .bento__cell--lg   { grid-column: span 2; grid-row: auto; }
  .bento__cell--md   { grid-column: span 2; }
  .bento__cell--sm   { grid-column: span 1; }
  .bento__cell--full { grid-column: span 2; }
}
/* Phone: single column. */
@media (max-width: 640px) {
  .bento { grid-template-columns: 1fr; }
  .bento__cell,
  .bento__cell--lg,
  .bento__cell--md,
  .bento__cell--sm,
  .bento__cell--full { grid-column: span 1; grid-row: auto; }
}

/* ---- How-it-works (3 steps) ---- */
.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  position: relative;
}
.steps::before {
  content: '';
  position: absolute;
  top: 28px;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--color-border), transparent);
  z-index: 0;
}

.step {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  text-align: center;
  align-items: center;
  padding: var(--space-6) var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  z-index: 1;
}
.step__num {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--grad-primary);
  color: #fff;
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--fs-xl);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-glow);
  margin-bottom: var(--space-2);
}
.step h3 {
  font-size: var(--fs-lg);
  font-weight: var(--weight-bold);
}
.step p { font-size: var(--fs-sm); color: var(--color-text-muted); }

@media (max-width: 880px) {
  .steps { grid-template-columns: 1fr; }
  .steps::before { display: none; }
}

/* ---- Showcase (image + text 2-col rows) ---- */
.showcase {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
  margin-bottom: clamp(64px, 10vw, 120px);
}
.showcase:last-child { margin-bottom: 0; }
.showcase--reverse { direction: rtl; }
.showcase--reverse > * { direction: ltr; }

.showcase__txt { display: flex; flex-direction: column; gap: var(--space-4); align-items: flex-start; }
.showcase__txt h2 {
  font-size: var(--fs-3xl);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-snug);
}
.showcase__txt p {
  font-size: var(--fs-lg);
  color: var(--color-text-muted);
  line-height: var(--lh-relaxed);
}
.showcase__media {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-bg-soft);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
}
.showcase__media img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 880px) {
  .showcase, .showcase--reverse { grid-template-columns: 1fr; direction: ltr; }
}

/* ---- Pricing layout ---- */
.pricing {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  align-items: stretch;
}
@media (max-width: 1024px) {
  .pricing { grid-template-columns: 1fr; max-width: 480px; margin-inline: auto; }
  .pricing-card--pro { transform: none; }
  .pricing-card--pro:hover { transform: translateY(-4px); }
}

/* ---- CTA banner ---- */
.cta-banner {
  position: relative;
  background: var(--grad-primary);
  border-radius: var(--radius-xl);
  padding: clamp(56px, 8vw, 120px) clamp(32px, 5vw, 80px);
  text-align: center;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
}
.cta-banner::before {
  content: '';
  position: absolute;
  inset: -100%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,0.20), transparent 50%),
    radial-gradient(circle at 70% 70%, rgba(146,211,80,0.30), transparent 50%);
  animation: rotate-bg 30s linear infinite;
  z-index: -1;
}
.cta-banner::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 60% 50% at 50% 0%, black 0%, transparent 70%);
          mask-image: radial-gradient(ellipse 60% 50% at 50% 0%, black 0%, transparent 70%);
  pointer-events: none;
  z-index: -1;
}
.cta-banner h2 {
  font-size: clamp(36px, 5vw, 64px);
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-tight);
  line-height: var(--lh-tight);
  color: #fff;
  margin-bottom: var(--space-4);
  max-width: 760px;
  margin-inline: auto;
}
.cta-banner p {
  font-size: var(--fs-lg);
  color: rgba(255,255,255,0.85);
  max-width: 560px;
  margin-inline: auto;
  margin-bottom: var(--space-8);
}
.cta-banner .btn--primary {
  background: #fff;
  color: var(--color-primary);
  border: none;
  box-shadow: 0 12px 32px rgba(0,0,0,0.18);
}
.cta-banner .btn--primary:hover { box-shadow: 0 24px 64px rgba(0,0,0,0.28); }
.cta-banner .btn--ghost {
  background: rgba(255,255,255,0.10);
  color: #fff;
  border-color: rgba(255,255,255,0.30);
}
.cta-banner .btn--ghost:hover { background: rgba(255,255,255,0.20); border-color: rgba(255,255,255,0.50); }

@keyframes rotate-bg {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ---- Feature comparison row ---- */
.compare {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-8);
}
.compare-row {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  align-items: center;
  font-size: var(--fs-sm);
}
.compare-row--header {
  background: transparent;
  border: none;
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-text-soft);
  padding-block: 0;
}
.compare-row__name { font-weight: var(--weight-semibold); }
.compare-row__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  border-radius: 50%;
}
.compare-row__check--yes { background: var(--color-accent-soft); color: var(--color-accent-dark); }
.compare-row__check--no  { background: var(--color-bg-soft);    color: var(--color-text-soft); }
.compare-row__check svg { width: 14px; height: 14px; }
@media (max-width: 640px) {
  .compare-row { grid-template-columns: 1.4fr 1fr 1fr; gap: var(--space-2); padding: var(--space-3); }
}

/* ---- Hero scroll cue ---- */
.scroll-cue {
  position: absolute;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text-soft);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  z-index: 2;
}
.scroll-cue__line {
  width: 1px;
  height: 32px;
  background: var(--color-border-strong);
  position: relative;
  overflow: hidden;
}
.scroll-cue__line::after {
  content: '';
  position: absolute;
  top: -100%;
  left: 0;
  width: 100%;
  height: 50%;
  background: var(--color-primary);
  animation: scroll-cue 2.4s ease-in-out infinite;
}
@keyframes scroll-cue {
  0%   { top: -100%; }
  100% { top: 200%; }
}
@media (max-width: 1024px) { .scroll-cue { display: none; } }

/* ---- Big mockup section ---- */
.mockup-section {
  position: relative;
  overflow: hidden;
}
.mockup-frame {
  position: relative;
  margin: 0 auto;
  max-width: 1080px;
  border-radius: var(--radius-xl);
  background: linear-gradient(180deg, var(--color-surface-2), var(--color-surface));
  border: 1px solid var(--color-border);
  padding: 14px 14px 0;
  box-shadow: var(--shadow-xl);
  transform: perspective(1600px) rotateX(8deg);
  transform-origin: center top;
  transition: transform var(--duration-slow) var(--ease-out);
}
.mockup-frame:hover { transform: perspective(1600px) rotateX(2deg); }
.mockup-frame__bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 14px;
}
.mockup-frame__dot { width: 10px; height: 10px; border-radius: 50%; background: var(--color-border-strong); }
.mockup-frame__dot:nth-child(1) { background: #FF5F57; }
.mockup-frame__dot:nth-child(2) { background: #FEBC2E; }
.mockup-frame__dot:nth-child(3) { background: #28C840; }
.mockup-frame img {
  width: 100%;
  display: block;
  border-radius: var(--radius);
}

/* Portrait variant: used for App Store-style vertical iPhone marketing
   screenshots. Drops the browser-chrome and keeps only a soft glow. */
.mockup-frame--portrait {
  max-width: 460px;
  background: none;
  border: none;
  padding: 0;
  border-radius: var(--radius-xl);
  box-shadow:
    0 80px 140px -30px rgba(79, 70, 229, 0.40),
    0 30px 60px -20px rgba(10, 10, 15, 0.18);
  overflow: hidden;
  transform: none;
}
.mockup-frame--portrait:hover { transform: translateY(-4px); }
.mockup-frame--portrait .mockup-frame__bar { display: none; }
.mockup-frame--portrait img { border-radius: var(--radius-xl); }

/* ---- Quote / testimonial card ---- */
.quote {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  position: relative;
  isolation: isolate;
}
.quote::before {
  content: '"';
  position: absolute;
  top: -28px;
  right: 28px;
  font-family: Georgia, serif;
  font-size: 200px;
  font-weight: bold;
  color: var(--color-primary-50);
  z-index: -1;
  line-height: 1;
}
.quote__text {
  font-size: var(--fs-lg);
  line-height: var(--lh-relaxed);
  color: var(--color-text);
  font-weight: var(--weight-medium);
}
.quote__author {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.quote__avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--grad-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: var(--weight-bold);
  font-size: var(--fs-md);
}
.quote__name { font-weight: var(--weight-semibold); }
.quote__role { font-size: var(--fs-sm); color: var(--color-text-muted); }
