
/* ============================================================
   SIDEBAR NAV — global so NavLink elements get styles correctly
   ============================================================ */

.tiq-sidebar {
    width: 220px;
    flex-shrink: 0;
    background: #FFFFFF;
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: 200;
    border-right: 1px solid var(--tiq-border);
    box-shadow: 2px 0 12px rgba(0,0,0,0.04);
    /* No overflow:hidden — allows profile dropdown to escape the sidebar bounds */
}

/* Brand / logo area */
.tiq-sidebar-brand {
    padding: 1.1rem 1.1rem 1rem;
    border-bottom: 1px solid var(--tiq-border);
    flex-shrink: 0;
}

.tiq-sidebar-logo-link {
    display: flex;
    align-items: center;
    text-decoration: none;
}

.tiq-sidebar-logo {
    height: 26px;
    width: auto;
    display: block;
}

/* Nav body */
.tiq-sidebar-body {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    padding: 0.5rem 0;
    display: flex;
    flex-direction: column;
    scrollbar-width: none;
}

.tiq-sidebar-body::-webkit-scrollbar { display: none; }

/* Section */
.tiq-nav-section {
    padding: 0.75rem 0 0.25rem;
}

.tiq-nav-section--bottom {
    margin-top: auto;
    padding-top: 0.75rem;
    border-top: 1px solid var(--tiq-border);
}

.tiq-nav-section-label {
    display: block;
    font-size: 0.59rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--tiq-text-4);
    padding: 0 1.1rem 0.35rem;
}

/* Nav items — all states */
.tiq-nav-item,
a.tiq-nav-item,
.tiq-nav-item:link,
.tiq-nav-item:visited {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    padding: 0.5rem 1.1rem;
    color: var(--tiq-text-3);
    text-decoration: none;
    font-size: 0.875rem;
    font-weight: 500;
    font-family: 'Geist', 'Inter', system-ui, -apple-system, sans-serif;
    border: none;
    background: none;
    width: 100%;
    text-align: left;
    cursor: pointer;
    letter-spacing: 0.005em;
    transition: color 0.15s, background 0.15s;
    position: relative;
    border-radius: 0;
}

.tiq-nav-item:hover,
a.tiq-nav-item:hover {
    color: var(--tiq-text);
    background: var(--tiq-surface-2);
    text-decoration: none;
}

/* Active state — set by Blazor NavLink */
.tiq-nav-item.active,
a.tiq-nav-item.active {
    color: var(--tiq-green-dim);
    background: var(--tiq-green-light);
    font-weight: 600;
}

/* Active left-border indicator */
.tiq-nav-item.active::before,
a.tiq-nav-item.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 4px;
    bottom: 4px;
    width: 3px;
    background: var(--tiq-green);
    border-radius: 0 2px 2px 0;
}

/* Sub-item indent */
.tiq-nav-item--sub,
a.tiq-nav-item--sub {
    padding-left: 2.4rem;
    font-size: 0.84rem;
    color: var(--tiq-text-4);
}

.tiq-nav-item--sub:hover,
a.tiq-nav-item--sub:hover { color: var(--tiq-text-2); }

.tiq-nav-item--sub.active,
a.tiq-nav-item--sub.active { color: var(--tiq-green-dim); }

/* Sub-sub-item (e.g. Ad Studio under Meta Ads) */
.tiq-nav-item--subsub,
a.tiq-nav-item--subsub {
    padding-left: 3.4rem;
    font-size: 0.8rem;
}

.tiq-nav-item--subsub.active,
a.tiq-nav-item--subsub.active { color: var(--tiq-green-dim); }

/* Icon */
.tiq-nav-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    flex-shrink: 0;
    color: var(--tiq-text-4);
}

.tiq-nav-item:hover .tiq-nav-icon,
.tiq-nav-item.active .tiq-nav-icon { color: var(--tiq-green); }

/* Badge */
.tiq-nav-badge {
    margin-left: auto;
    font-size: 0.58rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    background: var(--tiq-green);
    color: #fff;
    padding: 0.1rem 0.45rem;
    border-radius: 20px;
    flex-shrink: 0;
}

.tiq-nav-badge--ai {
    background: linear-gradient(135deg, #7C3AED, #4F46E5);
}

/* ── Sidebar footer ── */
.tiq-sidebar-footer {
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--tiq-border);
    flex-shrink: 0;
    background: var(--tiq-surface-2);
    position: relative; /* establishes stacking context for dropdown */
}

.tiq-sidebar-footer-link {
    display: block;
    color: var(--tiq-text-3);
    font-size: 0.82rem;
    font-weight: 500;
    text-decoration: none;
    padding: 0.4rem 0;
    transition: color 0.15s;
}

.tiq-sidebar-footer-link:hover { color: var(--tiq-text); }

.tiq-sidebar-footer-btn {
    display: block;
    margin-top: 0.5rem;
    padding: 0.5rem 1rem;
    background: var(--tiq-green);
    color: #fff;
    border-radius: 6px;
    font-size: 0.82rem;
    font-weight: 700;
    text-decoration: none;
    text-align: center;
    transition: all 0.15s;
    box-shadow: 0 2px 8px rgba(0,178,122,0.25);
}

.tiq-sidebar-footer-btn:hover { background: var(--tiq-green-dim); }

/* ── Profile dropdown: open UPWARD when in sidebar ── */
/* Override the default downward position from app.css */
.tiq-sidebar-footer .fi-profile-wrap { position: static; }

.tiq-sidebar-footer .fi-profile-dropdown {
    position: fixed;          /* fixed so it's never clipped */
    bottom: 80px;             /* above the footer */
    left: 12px;
    right: 12px;
    top: auto;
    width: auto;
    max-width: 220px;
    z-index: 9999;            /* above everything */
    box-shadow: var(--tiq-shadow-lg), 0 0 0 1px var(--tiq-border);
}

.tiq-sidebar-footer .fi-profile-btn {
    width: 100%;
    border-radius: 8px;
    padding: 0.4rem 0.6rem;
    justify-content: flex-start;
    border-color: var(--tiq-border);
    background: var(--tiq-surface);
}

.tiq-sidebar-footer .fi-profile-btn:hover {
    border-color: var(--tiq-green);
    background: var(--tiq-green-light);
}

.tiq-sidebar-footer .fi-profile-avatar {
    width: 26px;
    height: 26px;
    font-size: 0.65rem;
}

.tiq-sidebar-footer .fi-profile-chevron {
    margin-left: auto;
    font-size: 0.75rem;
}

/* ── Collapsible nav section ── */
.tiq-nav-section-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0 1.1rem 0.35rem;
    text-align: left;
    gap: 0.25rem;
}

.tiq-nav-section-toggle .tiq-nav-section-label {
    padding: 0;
}

.tiq-nav-section-chevron {
    display: flex;
    align-items: center;
    color: var(--tiq-text-4);
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.tiq-nav-section--collapsed .tiq-nav-section-chevron {
    transform: rotate(-90deg);
}

.tiq-nav-section-items {
    overflow: hidden;
}

.tiq-nav-section--collapsed .tiq-nav-section-items {
    display: none;
}

/* Sub-group labels within collapsible sections */
.tiq-nav-subgroup-label {
    display: block;
    font-size: 0.54rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--tiq-text-4);
    padding: 0.6rem 1.1rem 0.2rem 2.4rem;
    opacity: 0.7;
}
