/* ============================================================
   FEATURES PAGE STYLES  ->  features.html
   Loads after navorastyles.css. Bento tiles use per-tile color
   classes (.tile-*) with dark (--tile-flat) + light (--tile-flat-lt)
   values. Hover = lift + a glow in each tile's own hue.
   ============================================================ */
/* ═══════════════════════════════════════════════════
       FEATURES PAGE — bento grid, click-to-open modal
       Palette restricted to indigo/purple/pink family
    ═══════════════════════════════════════════════════ */

    /* guard against any horizontal overflow on this page */
    html, body { overflow-x: hidden; max-width: 100%; }
    .ft-hero, .ft-bento-section, .ft-compare { box-sizing: border-box; }
    .ft-bento-grid, .ft-tile { min-width: 0; }
    .ft-tile * { max-width: 100%; }

    .ft-hero {
      padding: 130px 40px 60px;
      max-width: 1240px;
      margin: 0 auto;
      text-align: center;
    }
    .ft-hero-pre {
      font-size: 0.78rem;
      letter-spacing: 0.14em;
      color: var(--blue-light);
      font-weight: 600;
      margin-bottom: 18px;
      text-transform: uppercase;
    }
    .ft-hero-title {
      font-size: clamp(2.2rem, 5vw, 4.2rem);
      font-weight: 800;
      letter-spacing: -0.04em;
      line-height: 1.04;
      color: var(--text);
      margin-bottom: 22px;
    }
    .ft-hero-accent {
      background: linear-gradient(135deg, #5ba3f5 0%, #9b59fa 50%, #ee92ba 100%);
      -webkit-background-clip: text;
      background-clip: text;
      -webkit-text-fill-color: transparent;
      color: transparent;
    }
    [data-theme="light"] .ft-hero-accent {
      background: linear-gradient(135deg, #3730a3 0%, #4f46e5 50%, #a8245a 100%);
      -webkit-background-clip: text;
      background-clip: text;
      -webkit-text-fill-color: transparent;
      color: transparent;
    }
    .ft-hero-sub {
      font-size: 1.1rem;
      color: var(--text-2);
      max-width: 640px;
      margin: 0 auto 32px;
      line-height: 1.55;
    }
    .ft-hero-trust {
      display: inline-flex;
      gap: 18px;
      font-size: 0.85rem;
      color: var(--text-3);
      flex-wrap: wrap;
      justify-content: center;
    }
    .ft-hero-trust span::before {
      content: '✓ ';
      color: var(--blue-light);
      margin-right: 4px;
    }

    /* ── BENTO SECTION ── */
    .ft-bento-section {
      padding: 40px 40px 100px;
      max-width: 1280px;
      margin: 0 auto;
    }
    .ft-bento-header {
      text-align: center;
      margin-bottom: 50px;
    }
    .ft-bento-title {
      font-size: clamp(1.8rem, 3.5vw, 2.6rem);
      font-weight: 800;
      letter-spacing: -0.03em;
      line-height: 1.1;
      margin-bottom: 14px;
    }
    .ft-bento-sub {
      color: var(--text-3);
      font-size: 1rem;
    }

    .ft-bento-grid {
      display: grid;
      grid-template-columns: repeat(6, 1fr);
      grid-auto-rows: 158px;
      gap: 16px;
    }

    .ft-tile {
      position: relative;
      border-radius: var(--radius-lg);
      padding: 26px;
      overflow: hidden;
      cursor: pointer;
      display: flex;
      flex-direction: column;
      gap: 16px;
      transition: transform 0.26s cubic-bezier(0.34, 1.1, 0.64, 1), box-shadow 0.28s ease, filter 0.28s ease;
      border: 1px solid transparent;
      isolation: isolate;
    }
    /* subtle zoom on hover */
    .ft-tile:hover {
      transform: translateY(-8px) scale(1.02) !important;
      box-shadow: 0 16px 36px -14px rgba(0,0,0,0.45);
      z-index: 3;
    }

    /* ── SOLID tiles (about-card vibe): FLAT saturated fill + white text ── */
    .ft-tile.ft-solid {
      background: var(--tile-flat);
      color: #fff;
    }
    [data-theme="light"] .ft-tile.ft-solid {
      background: var(--tile-flat-lt, var(--tile-flat));
    }
    .ft-tile.ft-solid .ft-tile-eyebrow { color: rgba(255,255,255,0.78); }
    .ft-tile.ft-solid .ft-tile-title   { color: #fff; }
    .ft-tile.ft-solid .ft-tile-desc    { color: rgba(255,255,255,0.82); }
    .ft-tile.ft-solid .ft-tile-cta     { color: #fff; }

    /* ── TINT tiles (smaller secondary): soft flat surface, normal text ── */
    .ft-tile.ft-tint {
      background: color-mix(in srgb, var(--tile-hue) 16%, var(--surface));
      border-color: color-mix(in srgb, var(--tile-hue) 26%, var(--glass-border));
    }
    .ft-tile.ft-tint:hover {
      border-color: color-mix(in srgb, var(--tile-hue) 55%, var(--glass-border));
    }
    .ft-tile.ft-tint .ft-tile-eyebrow { color: var(--tile-accent); }
    .ft-tile.ft-tint .ft-tile-title   { color: var(--text); }
    .ft-tile.ft-tint .ft-tile-desc    { color: var(--text-2); }
    .ft-tile.ft-tint .ft-tile-cta     { color: var(--tile-accent); }

    /* Tile sizes — heights tuned so content fills the box */
    .ft-tile-lg     { grid-column: span 4; grid-row: span 2; }
    .ft-tile-md-v   { grid-column: span 2; grid-row: span 2; }
    .ft-tile-md-h   { grid-column: span 3; grid-row: span 1; }
    .ft-tile-sm     { grid-column: span 2; grid-row: span 1; }
    .ft-tile-full   { grid-column: span 6; grid-row: span 1; }
    .ft-tile-full .ft-tile-title { font-size: 1.5rem; }

    .ft-tile-head { display: flex; flex-direction: column; gap: 9px; }
    .ft-tile-eyebrow {
      font-size: 0.68rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      font-weight: 700;
    }
    .ft-tile-title {
      font-size: 1.18rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1.25;
    }
    .ft-tile-lg .ft-tile-title { font-size: 1.7rem; }
    .ft-tile-md-h .ft-tile-title { font-size: 1.32rem; }
    .ft-tile-desc {
      font-size: 0.88rem;
      line-height: 1.55;
    }

    /* the mock + cta sit at the bottom, pushed down to fill space */
    .ft-tile-body { margin-top: auto; display: flex; flex-direction: column; gap: 16px; }
    .ft-tile-mock { margin-top: 4px; }
    /* single-row horizontal tiles are too short for an inline mock — hide it,
       the full mock still shows in the modal on click */
    .ft-tile-md-h .ft-tile-mock { display: none; }

    .ft-tile-cta {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 0.82rem;
      font-weight: 600;
    }
    .ft-tile-cta svg { width: 13px; height: 13px; transition: transform 0.25s ease; }
    .ft-tile:hover .ft-tile-cta svg { transform: translateX(4px); }
    /* top icon only appears in the mobile carousel */
    .ft-tile-icon { display: none; }

    /* Per-tile palettes — FLAT single colors mirroring the about-page .asc-* cards.
       --tile-flat (dark) / --tile-flat-lt (light); --tile-hue drives accents & chips. */
    .tile-indigo  { --tile-hue: var(--blue);   --tile-accent: var(--blue-light);
                    --tile-flat: #6366f1; --tile-flat-lt: #4338ca; }
    .tile-violet  { --tile-hue: #8b5cf6;        --tile-accent: #c4b5fd;
                    --tile-flat: #8b5cf6; --tile-flat-lt: #6d28d9; }
    .tile-pink    { --tile-hue: #ec4899;        --tile-accent: #f9a8d4;
                    --tile-flat: #db2777; --tile-flat-lt: #9d174d; }
    .tile-magenta { --tile-hue: #d946ef;        --tile-accent: #f0abfc;
                    --tile-flat: #c026d3; --tile-flat-lt: #86198f; }
    .tile-green   { --tile-hue: #14b8a6;        --tile-accent: #5eead4;
                    --tile-flat: #0d9488; --tile-flat-lt: #0f766e; }
    .tile-deep    { --tile-hue: var(--blue);    --tile-accent: var(--blue-light);
                    --tile-flat: #312e81; --tile-flat-lt: #1e1b4b; }
    .tile-amber   { --tile-hue: #f59e0b;        --tile-accent: #fcd34d;
                    --tile-flat: #d97706; --tile-flat-lt: #92400e; }

    /* ── shared mock components ──
       Defaults assume a SOLID (colored) tile → white-on-color surfaces.
       Inside .ft-tint tiles, surfaces switch to theme-aware via overrides below. */

    .ft-flow-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
    .ft-flow-node {
      background: rgba(255,255,255,0.16);
      border: 1px solid rgba(255,255,255,0.24);
      padding: 7px 12px;
      border-radius: 8px;
      font-size: 0.78rem;
      color: #fff;
      white-space: nowrap;
    }
    .ft-flow-arrow { color: rgba(255,255,255,0.8); font-size: 0.9rem; }
    .ft-rule-note {
      font-size: 0.8rem;
      color: rgba(255,255,255,0.82);
      padding: 10px 12px;
      border-radius: 8px;
      background: rgba(255,255,255,0.1);
      border: 1px dashed rgba(255,255,255,0.3);
    }

    .ft-bars { display: flex; align-items: flex-end; gap: 6px; height: 54px; }
    .ft-bar { flex: 1; background: rgba(255,255,255,0.55); border-radius: 4px 4px 0 0; min-height: 12px; }

    .ft-perm-grid { display: grid; grid-template-columns: 1fr auto; gap: 7px 12px; font-size: 0.82rem; }
    .ft-perm-grid > div:nth-child(odd) { color: rgba(255,255,255,0.82); }
    .ft-perm-dots { letter-spacing: 2px; color: #fff; }

    .ft-channel-row { display: flex; gap: 8px; flex-wrap: wrap; }
    .ft-channel-pill {
      background: rgba(255,255,255,0.16);
      border: 1px solid rgba(255,255,255,0.24);
      padding: 6px 13px;
      border-radius: 99px;
      font-size: 0.78rem;
      color: #fff;
    }

    .ft-tag-row { display: flex; gap: 7px; flex-wrap: wrap; }
    .ft-tag-row span {
      background: rgba(255,255,255,0.14);
      border: 1px solid rgba(255,255,255,0.22);
      padding: 5px 11px;
      border-radius: 99px;
      font-size: 0.74rem;
      color: rgba(255,255,255,0.92);
    }

    /* org chart mini */
    .ft-org { display: flex; flex-direction: column; align-items: center; gap: 10px; }
    .ft-org-node {
      background: rgba(255,255,255,0.16);
      border: 1px solid rgba(255,255,255,0.24);
      padding: 7px 16px;
      border-radius: 8px;
      font-size: 0.78rem;
      color: #fff;
      position: relative;
    }
    .ft-org-row { display: flex; gap: 12px; }
    .ft-org-line { width: 1px; height: 14px; background: rgba(255,255,255,0.35); }

    /* ── TINT-tile overrides: theme-aware surfaces instead of white ── */
    .ft-tint .ft-flow-node,
    .ft-tint .ft-channel-pill,
    .ft-tint .ft-org-node {
      background: color-mix(in srgb, var(--text) 7%, transparent);
      border-color: color-mix(in srgb, var(--tile-hue) 30%, var(--glass-border));
      color: var(--text);
    }
    .ft-tint .ft-tag-row span {
      background: color-mix(in srgb, var(--text) 7%, transparent);
      border-color: color-mix(in srgb, var(--tile-hue) 30%, var(--glass-border));
      color: var(--text-2);
    }
    .ft-tint .ft-flow-arrow,
    .ft-tint .ft-perm-dots { color: var(--tile-accent); }
    .ft-tint .ft-perm-grid > div:nth-child(odd) { color: var(--text-2); }
    .ft-tint .ft-bar { background: color-mix(in srgb, var(--tile-hue) 55%, transparent); }
    .ft-tint .ft-rule-note {
      color: var(--text-3);
      background: color-mix(in srgb, var(--text) 4%, transparent);
      border: 1px dashed color-mix(in srgb, var(--tile-hue) 30%, var(--glass-border));
    }
    .ft-tint .ft-org-line { background: color-mix(in srgb, var(--tile-hue) 40%, var(--glass-border)); }

    /* ═══════════ MODAL ═══════════ */
    .ft-modal-overlay {
      position: fixed;
      inset: 0;
      z-index: 9999;
      background: color-mix(in srgb, var(--bg) 60%, rgba(0,0,0,0.55));
      backdrop-filter: blur(8px);
      -webkit-backdrop-filter: blur(8px);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 24px;
      opacity: 0;
      pointer-events: none;
      transition: opacity 0.28s ease;
    }
    .ft-modal-overlay.open { opacity: 1; pointer-events: auto; }
    .ft-modal {
      position: relative;
      width: 100%;
      max-width: 600px;
      max-height: 86vh;
      overflow-y: auto;
      overflow-x: hidden;
      border-radius: var(--radius-lg);
      border: 1px solid color-mix(in srgb, var(--tile-hue) 35%, var(--glass-border));
      padding: 38px;
      background:
        linear-gradient(160deg,
          color-mix(in srgb, var(--tile-hue) 14%, var(--surface)) 0%,
          var(--surface) 60%);
      box-shadow: var(--glass-shadow-lg);
      transform: translateY(24px) scale(0.97);
      transition: transform 0.32s cubic-bezier(0.34, 1.3, 0.64, 1);
    }
    .ft-modal-overlay.open .ft-modal { transform: translateY(0) scale(1); }
    .ft-modal::-webkit-scrollbar { width: 8px; }
    .ft-modal::-webkit-scrollbar-track { background: transparent; }
    .ft-modal::-webkit-scrollbar-thumb {
      background: color-mix(in srgb, var(--tile-hue) 40%, transparent);
      border-radius: 100px;
      border: 2px solid transparent;
      background-clip: padding-box;
    }
    .ft-modal-close {
      position: absolute;
      top: 18px; right: 18px;
      width: 34px; height: 34px;
      border-radius: 50%;
      border: 1px solid var(--glass-border);
      background: color-mix(in srgb, var(--text) 8%, transparent);
      color: var(--text-2);
      font-size: 1.05rem;
      cursor: pointer;
      display: flex; align-items: center; justify-content: center;
      transition: background 0.2s ease, color 0.2s ease;
      z-index: 2;
    }
    .ft-modal-close:hover { background: color-mix(in srgb, var(--text) 16%, transparent); color: var(--text); }
    .ft-modal-eyebrow {
      font-size: 0.7rem;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      font-weight: 600;
      color: var(--tile-accent);
      margin-bottom: 12px;
    }
    .ft-modal-title {
      font-size: 1.7rem;
      font-weight: 700;
      letter-spacing: -0.025em;
      line-height: 1.15;
      color: var(--text);
      margin-bottom: 14px;
    }
    .ft-modal-desc {
      font-size: 0.95rem;
      color: var(--text-2);
      line-height: 1.6;
      margin-bottom: 24px;
    }
    .ft-modal-mock {
      background: color-mix(in srgb, var(--text) 5%, transparent);
      border: 1px solid var(--glass-border);
      border-radius: var(--radius);
      padding: 22px;
      margin-bottom: 22px;
    }
    /* mock chips inside the modal use theme-aware surfaces, not white-on-color */
    .ft-modal-mock .ft-flow-node,
    .ft-modal-mock .ft-channel-pill,
    .ft-modal-mock .ft-org-node {
      background: color-mix(in srgb, var(--text) 8%, transparent);
      border-color: color-mix(in srgb, var(--tile-hue) 30%, var(--glass-border));
      color: var(--text);
    }
    .ft-modal-mock .ft-tag-row span {
      background: color-mix(in srgb, var(--text) 8%, transparent);
      border-color: color-mix(in srgb, var(--tile-hue) 30%, var(--glass-border));
      color: var(--text-2);
    }
    .ft-modal-mock .ft-flow-arrow,
    .ft-modal-mock .ft-perm-dots { color: var(--tile-accent); }
    .ft-modal-mock .ft-perm-grid > div:nth-child(odd) { color: var(--text-2); }
    .ft-modal-mock .ft-bar { background: color-mix(in srgb, var(--tile-hue) 55%, transparent); }
    .ft-modal-mock .ft-org-line { background: color-mix(in srgb, var(--tile-hue) 40%, var(--glass-border)); }
    .ft-modal-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
    .ft-modal-stat {
      background: color-mix(in srgb, var(--text) 5%, transparent);
      border: 1px solid var(--glass-border);
      border-radius: var(--radius);
      padding: 14px;
      text-align: center;
    }
    .ft-modal-stat-val { font-size: 1.3rem; font-weight: 700; color: var(--text); letter-spacing: -0.02em; }
    .ft-modal-stat-lbl { font-size: 0.72rem; color: var(--text-3); margin-top: 4px; }
    .ft-modal-list { list-style: none; padding: 0; margin: 0; }
    .ft-modal-list li {
      font-size: 0.88rem;
      color: var(--text-2);
      padding: 9px 0 9px 26px;
      position: relative;
      border-bottom: 1px solid var(--glass-border);
    }
    .ft-modal-list li:last-child { border-bottom: none; }
    .ft-modal-list li::before {
      content: '✓';
      position: absolute;
      left: 0;
      color: var(--tile-accent);
      font-weight: 700;
    }

    /* ── Comparison section ── */
    .ft-compare { max-width: 1080px; margin: 80px auto 0; padding: 0 40px; }
    .ft-compare-scroll { /* scroll container — only scrolls on small screens */ }
    .ft-compare-grid {
      display: grid;
      grid-template-columns: 1.3fr 1fr 1fr 1.1fr;
      background: var(--glass);
      border: 1px solid var(--glass-border);
      border-radius: var(--radius-lg);
      overflow: hidden;
    }
    .ft-compare-grid > div {
      padding: 16px 20px;
      border-bottom: 1px solid var(--glass-border);
      border-right: 1px solid var(--glass-border);
      font-size: 0.88rem;
      color: var(--text-2);
    }
    .ft-compare-grid > div:nth-child(4n) { border-right: none; }
    .ft-compare-grid > div:nth-last-child(-n+4) { border-bottom: none; }
    .ft-compare-head {
      background: rgba(255,255,255,0.04);
      color: var(--text) !important;
      font-weight: 600;
      font-size: 0.85rem !important;
      letter-spacing: -0.01em;
    }
    .ft-compare-head.ft-compare-us {
      background: linear-gradient(135deg, rgba(99,102,241,0.18), rgba(240,98,146,0.18));
      color: var(--text) !important;
    }
    .ft-compare-yes  { color: #4ade80 !important; font-weight: 600; }
    .ft-compare-no   { color: #ef4444 !important; }
    .ft-compare-soso { color: #facc15 !important; }

    /* ── Responsive ── */
    @media (max-width: 1024px) {
      .ft-bento-grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 180px; }
      .ft-tile-lg   { grid-column: span 4; grid-row: span 2; }
      .ft-tile-md-v { grid-column: span 2; grid-row: span 2; }
      .ft-tile-md-h { grid-column: span 4; grid-row: span 1; }
      .ft-tile-sm   { grid-column: span 2; grid-row: span 1; }
    }
    @media (max-width: 768px) {
      .ft-hero { padding: 110px 20px 40px !important; }
      .ft-bento-section { padding: 20px 0 60px !important; }

      /* ── MOBILE: bento grid becomes a swipeable carousel ── */
      .ft-bento-header { padding: 0 16px; }
      .ft-bento-grid {
        display: flex !important;
        grid-template-columns: none !important;
        grid-auto-rows: auto !important;
        gap: 12px !important;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        padding: 4px 16px 0;
        scrollbar-width: none;
      }
      .ft-bento-grid::-webkit-scrollbar { display: none; }
      .ft-tile {
        grid-column: auto !important;
        grid-row: auto !important;
        flex: 0 0 86% !important;
        scroll-snap-align: center;
        min-height: 360px;
        border-radius: var(--radius-xl) !important;
        padding: 28px !important;
        justify-content: flex-start !important;
        gap: 18px !important;
      }
      /* top icon — like the mockup */
      .ft-tile-icon {
        display: flex !important;
        width: 44px; height: 44px;
        align-items: center; justify-content: center;
        color: #fff;
      }
      .ft-tile-icon svg { width: 28px; height: 28px; }
      /* content flows from the top; CTA pinned to the bottom */
      .ft-tile-body { margin-top: auto !important; }
      /* hide the dense inline mocks + tag rows on the carousel — keep cards clean */
      .ft-tile-mock, .ft-tile .ft-tag-row, .ft-tile .ft-rule-note { display: none !important; }
      .ft-tile-eyebrow { font-size: 0.72rem !important; }
      .ft-tile-title { font-size: 1.55rem !important; line-height: 1.18 !important; }
      .ft-tile-md-h .ft-tile-title,
      .ft-tile-sm .ft-tile-title { font-size: 1.55rem !important; }
      .ft-tile-desc { display: block !important; font-size: 0.95rem !important; }
      /* hover zoom off on touch; keep cards full */
      .ft-tile:hover { transform: none !important; }
      /* carousel cards must all be visible (data-ani would hide off-screen ones) */
      .ft-bento-grid .ft-tile[data-ani] { opacity: 1 !important; transform: none !important; }
      .ft-tile-sm .ft-tile-desc { display: block !important; }
      .ft-tile-mock { display: none !important; }
      /* let the body content breathe, push CTA down */
      .ft-tile-body { margin-top: auto; }
      .ft-tile-md-h .ft-tile-title { font-size: 1.25rem !important; }

      /* carousel counter + dots */
      .ft-carousel-meta {
        display: flex !important;
        align-items: center;
        justify-content: space-between;
        padding: 0 20px 10px;
        max-width: 1280px;
        margin: 0 auto;
      }
      .ft-carousel-count { font-size: 0.85rem; color: var(--text-3); }
      .ft-carousel-count b { color: var(--text); font-weight: 700; }
      .ft-carousel-hint { font-size: 0.78rem; color: var(--text-4); }
      .ft-carousel-dots {
        display: flex !important;
        gap: 5px; justify-content: center; flex-wrap: wrap;
        padding: 16px 20px 0; max-width: 320px; margin: 0 auto;
      }
      .ft-carousel-dots span {
        width: 6px; height: 6px; border-radius: 99px;
        background: var(--glass-border-2); transition: all 0.25s ease;
      }
      .ft-carousel-dots span.on { width: 18px; background: var(--blue); }

      .ft-modal-overlay { padding: 12px !important; }
      .ft-modal { padding: 24px 20px !important; max-height: 90vh !important; }
      .ft-modal-title { font-size: 1.4rem !important; }
      /* stat row: swipe sideways instead of squeezing 3 across */
      .ft-modal-stats {
        display: flex !important;
        gap: 10px;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scroll-snap-type: x mandatory;
        margin: 0 -20px;
        padding: 4px 20px;
      }
      .ft-modal-stats::-webkit-scrollbar { display: none; }
      .ft-modal-stat {
        flex: 0 0 38%;
        scroll-snap-align: start;
      }
      .ft-compare { padding: 0 16px !important; }
      /* keep the table as a real table — scroll it sideways instead of stacking */
      .ft-compare-scroll {
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        border-radius: var(--radius-lg);
        border: 1px solid var(--glass-border);
      }
      .ft-compare-grid {
        grid-template-columns: 150px 130px 130px 150px;
        width: max-content;
        min-width: 100%;
        border: none;
        border-radius: 0;
      }
      .ft-compare-grid > div { font-size: 0.82rem; padding: 14px 16px; }
    }

    /* carousel chrome hidden on desktop, shown only on mobile */
    .ft-carousel-meta, .ft-carousel-dots { display: none; }
