//! SQLite persistence layer.
//!
//! All database operations are isolated in repositories. Each repository owns
//! one SQLite table (or set of related tables) and exposes only domain-typed
//! methods — no raw SQL leaks through the public API.
//!
//! ## Repository overview
//!
//! | Repository | Table(s) | Responsibility |
//! |------------|----------|----------------|
//! | `MediaRepository` | `media`, `media_alias`, `media_external_id` | Media record upsert and lookup |
//! | `EpisodeRepository` | `episode`, `episode_source_record` | Canonical and source episode upsert and lookup |
//! | `SearchRepository` | `media_fts` + all media tables | FTS5 search, `MediaDocument` assembly |
//! | `SyncStateRepository` | `sync_state` | Cursor persistence across sync runs |
//!
//! ## Transaction semantics
//!
//! [`MediaRepository::upsert_media`] runs inside a transaction; all related
//! tables (`media`, `media_alias`, `media_external_id`, `source_record`,
//! `field_provenance`, `media_fts`) are updated atomically.
pub use EpisodeRepository;
pub use MediaRepository;
pub use SearchRepository;
pub use SyncStateRepository;