{# Apply saved theme before render to avoid flash #} {# Inter font — matches Catalyst #} {# HTMX #} {% if htmx_local %} {% else %} {% endif %} {% for css_url in extra_css %} {% endfor %} {# Catalyst-inspired layout: - Sidebar: always secondary-950 (dark), regardless of color scheme - Content: white (light) / secondary-900 (dark) - No separate topbar strip — breadcrumb sits inline in main #} {# ─── Mobile backdrop ─────────────────────────────────────────────── #} {# ─── Sidebar (always secondary-950) ───────────────────────────────────── #} {# ─── Main content ────────────────────────────────────────────────── #}
{# Slim top strip: hamburger + dark toggle #}
{# Hamburger — mobile only #}
{# Right: user dropdown + dark toggle #}
{% if auth_enabled and current_user %} {# User avatar dropdown #}
{# Dropdown panel #}
{% endif %}
{# Flash messages #}
{% block flash %}{% endblock %}
{# Page content #}
{# Breadcrumb — small, above the page heading #} {% if self.breadcrumb() %}
{% block breadcrumb %}{% endblock %}
{% endif %} {# Page header: title on the left, actions on the right #} {% if self.page_heading() or self.header_actions() %}
{% block page_heading %}{% endblock %}
{% block header_actions %}{% endblock %}
{% endif %} {% block content %}{% endblock %}
{# ─── Action modal dialog ─────────────────────────────────────────── #}