:root {
    /* Cores Institucionais PROJUDI/TJPR - iOS Style */
    --color-primary: #007AFF; /* Azul iOS */
    --color-secondary: #0056b3;
    --color-accent: #FF9500; /* Laranja iOS */
    --color-success: #34C759; /* Verde iOS */
    --color-danger: #FF3B30; /* Vermelho iOS */
    --color-bg: #F2F2F7; /* Cinza claro do iOS */
    --color-text: #1C1C1E;
    --text-soft: #8E8E93; /* System Gray 1 */
    --text-tertiary: #C7C7CC; /* System Gray 3 */
    --color-white: #ffffff;
    
    /* Surfaces */
    --surface-level-1: #FFFFFF;
    --surface-level-2: #F2F2F7;
    
    /* Glass & Borders */
    --glass-bg: rgba(255, 255, 255, 0.75);
    --glass-border: rgba(0, 0, 0, 0.05); /* very subtle for light mode */
    --glass-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    --separator-color: rgba(60, 60, 67, 0.36); /* iOS Light Separator */
    
    transition: background-color 0.3s ease, color 0.3s ease;
}

[data-theme="dark"] {
    --color-primary: #0A84FF; /* Dark iOS Blue */
    --color-secondary: #0A84FF;
    --color-accent: #FF9F0A; /* Dark iOS Orange */
    --color-success: #32D74B; /* Dark iOS Green */
    --color-danger: #FF453A; /* Dark iOS Red */
    --color-bg: #000000; /* Preto iOS puro */
    --color-text: #FFFFFF;
    --text-soft: rgba(235, 235, 245, 0.6);
    --text-tertiary: rgba(235, 235, 245, 0.3);
    --color-white: #1C1C1E; /* Map white to Level 1 Surface */
    
    /* Surfaces */
    --surface-level-1: #1C1C1E; /* Cards, etc */
    --surface-level-2: #2C2C2E; /* Modals, Popovers */
    
    /* Glass & Borders */
    --glass-bg: rgba(30, 30, 30, 0.75);
    --glass-border: rgba(84, 84, 88, 0.65); /* Opaque Separator */
    --glass-shadow: none; /* iOS dark mode mostly relies on light, not shadows */
    --separator-color: rgba(84, 84, 88, 0.65);
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}

html {
    overflow-x: clip;
    -webkit-text-size-adjust: 100%;
}

body {
    background-color: var(--color-bg);
    color: var(--color-text);
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    overflow-x: clip;
}

img,
video {
    max-width: 100%;
    height: auto;
}

/* Glassmorphism Utilities */
.glass-panel {
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
    border-radius: 16px;
    transition: background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

[data-theme="dark"] .glass-panel,
[data-theme="dark"] .sidebar,
[data-theme="dark"] .modal-header,
[data-theme="dark"] .profile-dropdown {
    backdrop-filter: blur(25px) !important;
    -webkit-backdrop-filter: blur(25px) !important;
}

/* Navbar */
.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 2rem 0.35rem;
    padding-left: max(1rem, env(safe-area-inset-left));
    padding-right: max(1rem, env(safe-area-inset-right));
    position: sticky;
    top: 0;
    z-index: 1000;
    background: var(--glass-bg);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
    border-bottom: 0.5px solid var(--separator-color);
    min-width: 0;
    gap: 0.5rem;
    max-width: 100%;
}

.nav-sidebar-toggle {
    display: none;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    margin: 0 0.35rem 0 0;
    padding: 0;
    border: none;
    border-radius: 12px;
    background: rgba(10, 48, 85, 0.08);
    color: var(--color-primary);
    cursor: pointer;
    transition: background 0.2s ease, transform 0.1s cubic-bezier(0.25, 1, 0.5, 1);
    flex-shrink: 0;
    -webkit-tap-highlight-color: transparent;
}

html[data-theme="dark"] .nav-sidebar-toggle {
    background: rgba(122, 177, 255, 0.12);
    color: var(--color-text);
}

.nav-sidebar-toggle:active {
    transform: scale(0.94);
}

.nav-brand {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-weight: bold;
    font-size: 1.5rem;
    color: var(--color-primary);
    min-width: 0;
}

/* Logos PROJUDI (PNG branco, fundo transparente): claro → preto; escuro → sem filtro */
html:not([data-theme="dark"]) .brand-logo-img {
    filter: brightness(0);
}

html[data-theme="dark"] .brand-logo-img {
    filter: none;
}

.nav-brand .brand-logo-img--navbar {
    display: block;
    height: 64px;
    width: auto;
    max-width: min(400px, 72vw);
    object-fit: contain;
    flex-shrink: 0;
}

.nav-brand:has(.brand-logo-img) {
    gap: 0.5rem;
}

.ios-auth-brand-logo-wrap {
    display: flex;
    justify-content: center;
    margin: 0 auto 0.85rem;
}

.brand-logo-img--login {
    display: block;
    width: 112px;
    height: 112px;
    max-width: min(112px, 40vw);
    max-height: min(112px, 30vw);
    object-fit: contain;
}

.ios-auth-brand-logo-wrap--wide .brand-logo-img--login-navbar-fallback {
    width: auto;
    max-width: min(280px, 85vw);
    height: auto;
    max-height: 56px;
    object-fit: contain;
}

/* Perfil + relógio Brasília (JS): data/hora abaixo do botão, centrada sob a largura do trigger */
.nav-user-profile-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.06rem;
    flex-shrink: 0;
    min-width: 0;
}

/* Relógio: America/Sao_Paulo via client; encostado à borda inferior útil da navbar */
.nav-brasilia-clock {
    display: block;
    font-size: 0.68rem;
    font-weight: 450;
    letter-spacing: 0.01em;
    color: var(--text-soft);
    opacity: 0.88;
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
    line-height: 1;
    margin: 0;
    padding: 0;
    pointer-events: none;
    text-align: center;
    width: 100%;
    max-width: 100%;
}

.nav-brasilia-clock--profile {
    margin-bottom: 0;
    padding-bottom: 0;
    align-self: stretch;
    text-align: center;
}

[data-theme="dark"] .nav-brasilia-clock {
    opacity: 0.8;
}

.nav-user {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.user-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 2px solid var(--color-accent);
}

/* Buttons */
.btn {
    padding: 0.8rem 1.5rem;
    border-radius: 14px; /* iOS highly rounded */
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.25, 0.8, 0.25, 1);
    border: none;
    text-decoration: none;
    display: inline-block;
    text-align: center;
    font-size: 0.95rem;
}

.btn-primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.btn-primary:hover {
    background-color: #0056b3; /* Slightly darker iOS blue */
    opacity: 0.9;
}

.btn-primary:active {
    transform: scale(0.96);
    opacity: 0.8;
}

/* Global button and interactive card active state (iOS Spring/Taptic) */
.btn:active, .widget-card.float-card:active, .process-list-item:active, .sidebar-item:active, .proc-tab:active {
    transform: scale(0.96) !important;
    transition: transform 0.1s cubic-bezier(0.25, 1, 0.5, 1) !important;
}

.btn-accent {
    background-color: var(--color-accent);
    color: var(--color-white);
}

/* Layout Dashboard */
.dashboard-container {
    display: flex;
    flex: 1;
    min-width: 0;
}

/* Sidebar */
.sidebar {
    width: 260px;
    padding: 2rem 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    border-right: 0.5px solid var(--separator-color);
    background-color: rgba(242, 242, 247, 0.6) !important; /* iOS Sidebar color */
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    height: 100vh;
    position: sticky;
    top: 0;
    box-shadow: none !important;
    border-radius: 0 !important;
}

html[data-theme="dark"] .sidebar {
    background-color: rgba(30, 30, 30, 0.75) !important;
    border-right: 0.5px solid var(--separator-color);
}

.sidebar-item {
    padding: 0.85rem 1rem;
    border-radius: 12px;
    color: var(--text-soft);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 1rem;
    transition: all 0.3s ease;
    font-weight: 500;
}

.sidebar-item i {
    width: 20px;
    text-align: center;
}

.sidebar-section-label {
    margin-top: 1rem;
    margin-bottom: 0.5rem;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-soft);
    text-transform: uppercase;
    padding-left: 1rem;
    letter-spacing: 0.04em;
}

.sidebar-footer-actions {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 0.5px solid var(--separator-color);
}

.sidebar-btn-novo {
    width: 100%;
    border-radius: 999px;
}

.sidebar-backdrop {
    display: none;
}

.sidebar-mobile-header {
    display: none;
}

.sidebar-item:hover, .sidebar-item.active {
    background: rgba(10, 48, 85, 0.05);
    color: var(--color-primary);
}

html[data-theme="dark"] .sidebar-item:hover, 
html[data-theme="dark"] .sidebar-item.active {
    background: rgba(122, 177, 255, 0.1);
}

/* Main Content */
@keyframes slideInFromRight {
    0% { transform: translateX(30px); opacity: 0; }
    100% { transform: translateX(0); opacity: 1; }
}

.main-content {
    flex: 1;
    min-width: 0;
    padding: 2rem;
    animation: slideInFromRight 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.1) forwards;
}

.page-header {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 2rem;
}

.page-title {
    color: var(--color-text); /* iOS titles are usually system text color */
    margin-bottom: 0;
    font-size: 2.5rem; /* Larger Title */
    font-weight: 800; /* Bolder */
    letter-spacing: -0.5px;
    line-height: 1.12;
}

/* Cards & Widgets */
.dashboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
    gap: 1.5rem;
}

.widget-card {
    padding: 1.5rem;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.widget-title {
    font-size: 1.1rem;
    color: #8E8E93; /* System Gray 1 */
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.widget-title i {
    color: #8E8E93 !important; /* Force icons to be gray */
}

.widget-value {
    font-size: 2.5rem;
    font-weight: 800;
    color: var(--color-secondary);
}

/* Messages — toasts estilo iOS (Human Interface / iosdesign.md) */
.messages {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 1050;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    align-items: flex-end;
    max-width: min(420px, calc(100vw - 2.5rem));
    pointer-events: none;
}

.messages .message-alert {
    pointer-events: auto;
}

.message-alert {
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    border-radius: 16px;
    padding: 0.95rem 1.1rem 0.95rem 3rem;
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1.38;
    letter-spacing: -0.015em;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display",
        "Segoe UI", Inter, system-ui, sans-serif;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid rgba(60, 60, 67, 0.12);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 2px 8px rgba(0, 0, 0, 0.04);
    position: relative;
    animation: slideInIosToast 0.4s cubic-bezier(0.25, 1, 0.5, 1) forwards;
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.88);
}

[data-theme="dark"] .message-alert {
    background: rgba(44, 44, 46, 0.92);
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.45), 0 2px 12px rgba(0, 0, 0, 0.25);
}

.message-alert::before {
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%);
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-size: 1.05rem;
    line-height: 1;
    content: "\f05a";
    color: #007aff;
}

.message-alert.error {
    background: rgba(255, 245, 245, 0.94);
    border-color: rgba(255, 59, 48, 0.35);
    color: #8b1e1a;
}

.message-alert.error::before {
    content: "\f071";
    color: #ff3b30;
}

[data-theme="dark"] .message-alert.error {
    background: rgba(72, 28, 28, 0.88);
    color: #ffccc7;
    border-color: rgba(255, 105, 97, 0.45);
}

[data-theme="dark"] .message-alert.error::before {
    color: #ff6961;
}

.message-alert.success {
    background: rgba(241, 251, 244, 0.94);
    border-color: rgba(52, 199, 89, 0.35);
    color: #1a4d24;
}

.message-alert.success::before {
    content: "\f00c";
    color: #34c759;
}

[data-theme="dark"] .message-alert.success {
    background: rgba(26, 58, 32, 0.88);
    color: #b8f0c4;
    border-color: rgba(82, 200, 110, 0.4);
}

[data-theme="dark"] .message-alert.success::before {
    color: #32d74b;
}

.message-alert.info,
.message-alert.debug {
    background: rgba(240, 247, 255, 0.94);
    border-color: rgba(0, 122, 255, 0.32);
    color: #0a3d7a;
}

.message-alert.info::before,
.message-alert.debug::before {
    content: "\f05a";
    color: #007aff;
}

[data-theme="dark"] .message-alert.info,
[data-theme="dark"] .message-alert.debug {
    background: rgba(28, 48, 78, 0.88);
    color: #c8e0ff;
    border-color: rgba(10, 132, 255, 0.4);
}

[data-theme="dark"] .message-alert.info::before,
[data-theme="dark"] .message-alert.debug::before {
    color: #0a84ff;
}

.message-alert.warning {
    background: rgba(255, 250, 235, 0.96);
    border-color: rgba(255, 149, 0, 0.4);
    color: #7a4a00;
}

.message-alert.warning::before {
    content: "\f06a";
    color: #ff9500;
}

[data-theme="dark"] .message-alert.warning {
    background: rgba(62, 48, 20, 0.9);
    color: #ffe0a8;
    border-color: rgba(255, 159, 10, 0.45);
}

[data-theme="dark"] .message-alert.warning::before {
    color: #ff9f0a;
}

/* Login iOS: toasts centralizados no topo */
body:has(.ios-auth-page) .messages {
    top: max(1rem, env(safe-area-inset-top, 0px));
    bottom: auto;
    left: 50%;
    right: auto;
    transform: translateX(-50%);
    width: min(calc(100vw - 2rem), 520px);
    max-width: min(calc(100vw - 2rem), 520px);
    align-items: stretch;
}

@keyframes slideInIosToast {
    from {
        transform: translateY(-14px);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Utilities */
.notification-wrapper {
    position: relative;
    z-index: 10020;
}

/* Painel de notificações — estilo iOS (popover / lista agrupada, iosdesign.md) */
.notification-dropdown {
    display: block;
    z-index: 10021 !important;
    position: absolute;
    top: 120%;
    right: -10px;
    width: 340px;
    max-width: calc(100vw - 24px);
    overflow: hidden;
    border-radius: 14px;
    border: 1px solid rgba(60, 60, 67, 0.18);
    background: #f2f2f7;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Segoe UI",
        Inter, system-ui, sans-serif;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.07), 0 12px 48px rgba(0, 0, 0, 0.08);
    transform-origin: top right;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transform: scale(0.94) translateY(-8px);
    transition:
        opacity 0.34s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.38s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0s linear 0.38s,
        box-shadow 0.34s ease;
}

[data-theme="dark"] .notification-dropdown {
    background: #1c1c1e;
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.45);
}

.notification-dropdown-header-mark {
    padding: 0.65rem 1rem 0.55rem;
    background: #f2f2f7;
    border-bottom: 0.33px solid rgba(60, 60, 67, 0.29);
}

[data-theme="dark"] .notification-dropdown-header-mark {
    background: #1c1c1e;
    border-bottom-color: rgba(84, 84, 88, 0.65);
}

.notification-dropdown-title {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.2;
    color: #000000;
}

[data-theme="dark"] .notification-dropdown-title {
    color: #ffffff;
}

.notification-dropdown-body {
    max-height: 320px;
    overflow-y: auto;
    overflow-x: hidden;
    background: #f2f2f7;
    margin: 0 0.5rem;
    padding: 0.15rem 0 0.25rem;
    border-radius: 10px;
}

[data-theme="dark"] .notification-dropdown-body {
    background: #1c1c1e;
}

.notification-dropdown-body:has(.notification-item-wrap) {
    background: #ffffff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
    padding: 0;
}

[data-theme="dark"] .notification-dropdown-body:has(.notification-item-wrap) {
    background: #2c2c2e;
    box-shadow: none;
}

.notification-dropdown-body:has(.notification-item-wrap) .notification-item-wrap:first-child {
    border-top-left-radius: 10px;
    border-top-right-radius: 10px;
    overflow: hidden;
}

.notification-dropdown-body:has(.notification-item-wrap) .notification-item-wrap:last-child {
    border-bottom-left-radius: 10px;
    border-bottom-right-radius: 10px;
    overflow: hidden;
}

.notification-dropdown-footer {
    padding: 0.5rem 0.65rem 0.65rem;
    background: #f2f2f7;
    border-top: none;
}

[data-theme="dark"] .notification-dropdown-footer {
    background: #1c1c1e;
}

.notification-mark-all-read {
    width: 100%;
    display: block;
    padding: 0.72rem 1rem;
    border: none;
    border-radius: 12px;
    font-size: 1.0625rem;
    font-weight: 600;
    letter-spacing: -0.01em;
    cursor: pointer;
    color: #007aff;
    background: #ffffff;
    transition: background 0.15s ease, color 0.15s ease, transform 0.1s ease;
    box-shadow: 0 0.33px 0 rgba(0, 0, 0, 0.04);
}

.notification-mark-all-read:hover:not(:disabled) {
    background: #e8e8ed;
}

.notification-mark-all-read:active:not(:disabled) {
    transform: scale(0.985);
    background: #d1d1d6;
}

.notification-mark-all-read:disabled {
    color: #c7c7cc;
    background: #ffffff;
    cursor: not-allowed;
}

[data-theme="dark"] .notification-mark-all-read {
    color: #0a84ff;
    background: #2c2c2e;
}

[data-theme="dark"] .notification-mark-all-read:hover:not(:disabled) {
    background: #3a3a3c;
}

[data-theme="dark"] .notification-mark-all-read:active:not(:disabled) {
    background: #48484a;
}

[data-theme="dark"] .notification-mark-all-read:disabled {
    color: #636366;
    background: #2c2c2e;
}

.notification-item-wrap {
    border-bottom: 1px solid var(--separator-color);
}

.notification-item-wrap:last-child {
    border-bottom: none;
}

.notification-item {
    display: block;
    padding: 0.85rem 1rem;
    text-decoration: none;
    color: var(--color-text);
    transition: background 0.15s ease;
}

.notification-item:hover {
    background: rgba(0, 122, 255, 0.06);
}

[data-theme="dark"] .notification-item:hover {
    background: rgba(10, 132, 255, 0.12);
}

.notification-item__title {
    display: block;
    font-size: 0.9rem;
    font-weight: 650;
    margin-bottom: 0.25rem;
    color: var(--color-text);
    overflow-wrap: anywhere;
    word-break: break-word;
}

.notification-item__msg {
    margin: 0;
    font-size: 0.84rem;
    color: var(--text-soft);
    line-height: 1.4;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.notification-item__ago {
    display: block;
    font-size: 0.72rem;
    color: var(--text-soft);
    margin-top: 0.4rem;
}

.notification-ciencia-btn {
    display: block;
    width: calc(100% - 2rem);
    margin: 0 1rem 0.85rem;
    padding: 0.45rem 0.75rem;
    border: 1px solid var(--color-primary, #007aff);
    border-radius: 10px;
    background: transparent;
    color: var(--color-primary, #007aff);
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.notification-ciencia-btn:hover {
    background: rgba(0, 122, 255, 0.1);
}

.notification-empty-msg {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 168px;
    padding: 1.75rem 1.35rem 1.5rem;
    text-align: center;
    margin: 0.35rem 0;
    background: #ffffff;
    border-radius: 12px;
}

[data-theme="dark"] .notification-empty-msg {
    background: #2c2c2e;
}

.notification-empty-msg__iconWrap {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    margin-bottom: 0.65rem;
    border-radius: 14px;
    background: #e5e5ea;
    color: #8e8e93;
}

[data-theme="dark"] .notification-empty-msg__iconWrap {
    background: #3a3a3c;
    color: #98989d;
}

.notification-empty-msg__iconWrap .fa-regular {
    font-size: 1.35rem;
    font-weight: 400;
}

.notification-empty-msg__title {
    margin: 0 0 0.35rem;
    font-size: 1.0625rem;
    font-weight: 600;
    letter-spacing: -0.02em;
    color: #000000;
    line-height: 1.25;
}

[data-theme="dark"] .notification-empty-msg__title {
    color: #ffffff;
}

.notification-empty-msg__caption {
    margin: 0;
    max-width: 16rem;
    font-size: 0.8125rem;
    font-weight: 400;
    line-height: 1.35;
    letter-spacing: -0.01em;
    color: #8e8e93;
}

[data-theme="dark"] .notification-empty-msg__caption {
    color: #98989d;
}

.notification-dropdown.notification-dropdown--open {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
    transform: scale(1) translateY(0);
    transition:
        opacity 0.36s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.4s cubic-bezier(0.22, 1, 0.36, 1),
        visibility 0s,
        box-shadow 0.36s ease;
}

.notification-bell {
    position: relative;
    overflow: visible;
    cursor: pointer;
    font-size: 1.3rem;
    color: var(--color-text);
    background: none;
    border: none;
    padding: 0.5rem;
    line-height: 1;
    transition: transform 0.1s cubic-bezier(0.25, 1, 0.5, 1);
}

.notification-bell__graphic {
    display: inline-block;
    position: relative;
    z-index: 0;
    transform-origin: 50% 0;
    line-height: 1;
}

.notification-bell__body {
    display: block;
    line-height: 1;
}

.notification-bell__clapper {
    position: absolute;
    left: 50%;
    bottom: 0.1em;
    width: 0.26em;
    height: 0.36em;
    margin-left: -0.13em;
    border-radius: 0.07em;
    background: currentColor;
    opacity: 0.9;
    transform-origin: 50% 0;
    pointer-events: none;
}

.notification-bell.notification-bell--ringing .notification-bell__graphic {
    animation: notification-bell-swing 4s cubic-bezier(0.28, 0.85, 0.22, 1) both;
}

.notification-bell.notification-bell--ringing .notification-bell__clapper {
    animation: notification-clapper-swing 4s cubic-bezier(0.28, 0.85, 0.22, 1) both;
}

@keyframes notification-bell-swing {
    0%,
    100% {
        transform: rotate(0deg);
    }
    5% {
        transform: rotate(11deg);
    }
    12% {
        transform: rotate(-9deg);
    }
    20% {
        transform: rotate(7.5deg);
    }
    28% {
        transform: rotate(-6deg);
    }
    37% {
        transform: rotate(5deg);
    }
    46% {
        transform: rotate(-3.8deg);
    }
    56% {
        transform: rotate(2.8deg);
    }
    66% {
        transform: rotate(-2deg);
    }
    76% {
        transform: rotate(1.2deg);
    }
    86% {
        transform: rotate(-0.6deg);
    }
    94% {
        transform: rotate(0.25deg);
    }
}

@keyframes notification-clapper-swing {
    0%,
    100% {
        transform: rotate(0deg) translateX(0);
    }
    6% {
        transform: rotate(-14deg) translateX(0.06em);
    }
    14% {
        transform: rotate(13deg) translateX(-0.065em);
    }
    23% {
        transform: rotate(-11deg) translateX(0.055em);
    }
    32% {
        transform: rotate(9deg) translateX(-0.048em);
    }
    42% {
        transform: rotate(-7deg) translateX(0.038em);
    }
    52% {
        transform: rotate(5.5deg) translateX(-0.03em);
    }
    62% {
        transform: rotate(-4deg) translateX(0.022em);
    }
    72% {
        transform: rotate(2.8deg) translateX(-0.015em);
    }
    82% {
        transform: rotate(-1.5deg) translateX(0.01em);
    }
    92% {
        transform: rotate(0.5deg) translateX(-0.004em);
    }
}

.notification-badge {
    position: absolute;
    /* Canto do botão: bolinha fora do centro do sino */
    top: 0.06rem;
    right: 0.16rem;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 9px;
    height: 9px;
    min-width: 9px;
    max-width: 9px;
    padding: 0;
    background-color: #ff3b30;
    border-radius: 50%;
    border: 2px solid var(--glass-bg);
    box-sizing: border-box;
    overflow: hidden;
    aspect-ratio: 1;
    transform-origin: center center;
    transform: translate(0, 0);
    /* Ao sair do “ringing”: volta a encolher e aproximar devagar */
    transition:
        width 1.38s cubic-bezier(0.33, 0.52, 0.2, 1),
        height 1.38s cubic-bezier(0.33, 0.52, 0.2, 1),
        min-width 1.38s cubic-bezier(0.33, 0.52, 0.2, 1),
        max-width 1.38s cubic-bezier(0.33, 0.52, 0.2, 1),
        transform 1.35s cubic-bezier(0.28, 0.45, 0.22, 1),
        box-shadow 0.95s ease;
}

.notification-badge__n {
    font-size: 0.5rem;
    font-weight: 700;
    line-height: 1;
    color: #ffffff;
    letter-spacing: -0.03em;
    opacity: 0;
    transform: scale(0.2);
    max-width: 0;
    overflow: hidden;
    white-space: nowrap;
    pointer-events: none;
    text-align: center;
    transition:
        opacity 1.2s cubic-bezier(0.33, 0.52, 0.2, 1) 0.05s,
        transform 1.25s cubic-bezier(0.33, 0.52, 0.2, 1),
        max-width 1.25s cubic-bezier(0.33, 0.52, 0.2, 1);
}

/* Sempre círculo: desloca na diagonal ↗ (direita + para cima) para ficar “do outro lado” do sino */
.notification-bell.notification-bell--ringing .notification-badge {
    width: 20px;
    height: 20px;
    min-width: 20px;
    max-width: 20px;
    border-radius: 50%;
    transform: translate(0.72rem, -0.62rem);
    transition:
        width 0.9s cubic-bezier(0.22, 1, 0.34, 1),
        height 0.9s cubic-bezier(0.22, 1, 0.34, 1),
        min-width 0.9s cubic-bezier(0.22, 1, 0.34, 1),
        max-width 0.9s cubic-bezier(0.22, 1, 0.34, 1),
        transform 1s cubic-bezier(0.22, 1, 0.34, 1),
        box-shadow 0.5s ease;
    animation: notification-badge-soft-glow 4s ease-in-out both;
}

.notification-bell.notification-bell--ringing .notification-badge__n {
    opacity: 1;
    transform: scale(1);
    max-width: 2.25rem;
    transition:
        opacity 0.75s cubic-bezier(0.22, 1, 0.34, 1) 0.14s,
        transform 0.85s cubic-bezier(0.22, 1, 0.34, 1) 0.12s,
        max-width 0.75s cubic-bezier(0.22, 1, 0.34, 1) 0.1s;
}

@keyframes notification-badge-soft-glow {
    0%,
    100% {
        box-shadow: 0 0 0 0 rgba(255, 59, 48, 0);
    }
    35% {
        box-shadow: 0 0 0 4px rgba(255, 59, 48, 0.18);
    }
    70% {
        box-shadow: 0 0 0 2px rgba(255, 59, 48, 0.08);
    }
}

@keyframes pulse {
    0% { transform: scale(1); box-shadow: 0 0 0 0 rgba(211, 47, 47, 0.7); }
    70% { transform: scale(1.1); box-shadow: 0 0 0 10px rgba(211, 47, 47, 0); }
    100% { transform: scale(1); box-shadow: 0 0 0 0 rgba(211, 47, 47, 0); }
}

/* Home / Login Page */
.home-container {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: linear-gradient(135deg, #0a3055 0%, #164a84 100%);
}

.login-card {
    text-align: center;
    max-width: 500px;
    width: 90%;
    padding: 3rem 2rem;
}

.login-card h1 {
    color: var(--color-primary);
    margin-bottom: 1rem;
    font-size: 2.5rem;
}

.login-card p {
    color: #666;
    margin-bottom: 2rem;
}

/* Modern Login Styles (from reference images) */
.login-page-bg {
    background-color: #0d47a1; /* Fundo azul escuro */
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

/* Animação de entrada da página */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px) scale(0.98);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

.login-card-modern {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.4);
    width: 100%;
    max-width: 420px;
    padding: 2.5rem 2rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.login-logo {
    width: 80px;
    height: 80px;
    margin-bottom: 1.5rem;
    animation: fadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.login-card-modern h1 {
    color: #0a3055;
    font-size: 1.6rem;
    font-weight: 800;
    margin-bottom: 0.5rem;
    text-transform: uppercase;
}

.login-subtitle {
    color: #666;
    margin-bottom: 2rem;
    font-size: 0.95rem;
}

/* Animações base para botões */
.btn-animated {
    position: relative;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    z-index: 1;
}

/* Efeito Ripple (Onda) ao clicar */
.btn-animated::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.2);
    border-radius: inherit;
    z-index: -2;
}

.btn-animated::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.1);
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    border-radius: inherit;
    z-index: -1;
}

.btn-animated:hover::before {
    width: 100%;
}

.btn-animated:active {
    transform: scale(0.96);
}

/* Login Buttons */
.btn-roblox-oauth {
    background: #00a2ff;
    color: white;
    border-radius: 12px;
    padding: 0.9rem;
    font-weight: bold;
    width: 100%;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    text-decoration: none;
    box-shadow: 0 4px 15px rgba(0, 162, 255, 0.3);
}

.btn-roblox-oauth:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(0, 162, 255, 0.5);
}

.divider {
    display: flex;
    align-items: center;
    text-align: center;
    margin: 1.5rem 0;
    color: #888;
    width: 100%;
    font-size: 0.9rem;
}

.divider::before, .divider::after {
    content: '';
    flex: 1;
    border-bottom: 1px solid #ddd;
}

.divider:not(:empty)::before {
    margin-right: 1em;
}

.divider:not(:empty)::after {
    margin-left: 1em;
}

/* —— Páginas legais (Política / Termos) — estilo iOS HIG —— */
.ios-legal-page {
    min-height: 100vh;
    background: var(--color-bg);
    color: var(--color-text);
}

.ios-legal-nav {
    position: sticky;
    top: 0;
    z-index: 50;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.65rem 1rem max(0.65rem, env(safe-area-inset-top));
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 0.5px solid var(--separator-color);
}

.ios-legal-back {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    color: var(--color-primary);
    font-size: 1rem;
    font-weight: 600;
    text-decoration: none;
    letter-spacing: -0.01em;
    padding: 0.35rem 0.25rem;
    border-radius: 10px;
    transition: opacity 0.2s ease;
}

.ios-legal-back:hover {
    opacity: 0.75;
}

.ios-legal-back i {
    font-size: 0.85em;
    opacity: 0.9;
}

.ios-legal-nav-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--text-soft);
    font-size: 0.8125rem;
    font-weight: 500;
}

.ios-legal-nav-meta i {
    font-size: 1rem;
    color: var(--color-primary);
    opacity: 0.85;
}

.ios-legal-main {
    max-width: 42rem;
    margin: 0 auto;
    padding: 1.25rem 1.25rem 3rem;
    padding-left: max(1.25rem, env(safe-area-inset-left));
    padding-right: max(1.25rem, env(safe-area-inset-right));
}

.ios-legal-kicker {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    margin-bottom: 0.35rem;
}

.ios-legal-large-title {
    font-size: clamp(1.75rem, 5.5vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.12;
    margin: 0 0 0.5rem;
    color: var(--color-text);
}

.ios-legal-subtitle {
    font-size: 0.9375rem;
    line-height: 1.45;
    color: var(--text-soft);
    margin: 0 0 1rem;
    max-width: 36rem;
}

.ios-legal-segment {
    display: flex;
    background: var(--surface-level-2);
    border-radius: 11px;
    padding: 3px;
    margin: 1rem 0 1.5rem;
    max-width: 100%;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.04);
}

[data-theme="dark"] .ios-legal-segment {
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
}

.ios-legal-segment a {
    flex: 1;
    text-align: center;
    padding: 0.55rem 0.75rem;
    border-radius: 9px;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-soft);
    text-decoration: none;
    transition: color 0.2s ease, background 0.2s ease, box-shadow 0.2s ease;
}

.ios-legal-segment a:hover:not(.is-active) {
    color: var(--color-text);
}

.ios-legal-segment a.is-active {
    background: var(--surface-level-1);
    color: var(--color-text);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .ios-legal-segment a.is-active {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.ios-legal-card {
    background: var(--surface-level-1);
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    border: 0.5px solid var(--glass-border);
    padding: 0.25rem 0;
    overflow: hidden;
    animation: iosLegalFadeIn 0.45s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes iosLegalFadeIn {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

[data-theme="dark"] .ios-legal-card {
    box-shadow: none;
}

.ios-legal-section {
    padding: 1.15rem 1.25rem 1.25rem;
}

.ios-legal-section + .ios-legal-section {
    border-top: 0.5px solid var(--separator-color);
}

.ios-legal-h2 {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 1.0625rem;
    font-weight: 600;
    letter-spacing: -0.015em;
    margin: 0 0 0.55rem;
    color: var(--color-text);
}

.ios-legal-h2-num {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.5rem;
    height: 1.5rem;
    margin-top: 0.1rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--color-primary);
    background: rgba(0, 122, 255, 0.12);
    border-radius: 6px;
}

[data-theme="dark"] .ios-legal-h2-num {
    background: rgba(10, 132, 255, 0.22);
}

.ios-legal-h2 span:last-child {
    line-height: 1.3;
}

.ios-legal-p {
    font-size: 1rem;
    line-height: 1.55;
    color: var(--text-soft);
    margin: 0 0 0.65rem;
}

.ios-legal-p:last-child {
    margin-bottom: 0;
}

.ios-legal-p strong {
    color: var(--color-text);
    font-weight: 600;
}

.ios-legal-footer {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 0.5px solid var(--separator-color);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.75rem 1.25rem;
}

.ios-legal-footer a {
    color: var(--color-primary);
    font-size: 0.9375rem;
    font-weight: 500;
    text-decoration: none;
}

.ios-legal-footer a:hover {
    opacity: 0.8;
}

.ios-legal-footer-sep {
    color: var(--text-tertiary);
    font-size: 0.75rem;
    user-select: none;
}

/* Bloco legal na home (login) — coerente com iOS */
.ios-home-legal {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 0.5px solid rgba(255, 255, 255, 0.25);
    text-align: center;
    width: 100%;
}

.ios-home-legal-lock {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: rgba(255, 255, 255, 0.85);
    margin-bottom: 0.65rem;
}

.ios-home-legal-lock i {
    color: var(--color-success);
    font-size: 0.95rem;
}

.ios-home-legal-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.5rem 0.75rem;
    margin-bottom: 0.65rem;
}

.ios-home-legal-links a {
    color: rgba(255, 255, 255, 0.95);
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.35rem 0.65rem;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.12);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 0.5px solid rgba(255, 255, 255, 0.2);
    transition: background 0.2s ease, transform 0.15s ease;
}

.ios-home-legal-links a:hover {
    background: rgba(255, 255, 255, 0.22);
    transform: translateY(-1px);
}

.ios-home-legal-note {
    font-size: 0.78rem;
    line-height: 1.45;
    color: rgba(255, 255, 255, 0.65);
    max-width: 22rem;
    margin: 0 auto;
}

/* Variante legal na home iOS (fundo claro / cartão) */
.ios-home-legal--auth {
    border-top-color: var(--separator-color);
}

.ios-home-legal--auth .ios-home-legal-lock {
    color: var(--text-soft);
}

.ios-home-legal--auth .ios-home-legal-lock i {
    color: var(--color-success);
}

.ios-home-legal--auth .ios-home-legal-links a {
    color: var(--color-primary);
    background: rgba(0, 122, 255, 0.1);
    border: 0.5px solid rgba(0, 122, 255, 0.2);
}

[data-theme="dark"] .ios-home-legal--auth .ios-home-legal-links a {
    background: rgba(10, 132, 255, 0.18);
    border-color: rgba(10, 132, 255, 0.35);
}

.ios-home-legal--auth .ios-home-legal-links a:hover {
    background: rgba(0, 122, 255, 0.18);
}

.ios-home-legal--auth .ios-home-legal-note {
    color: var(--text-soft);
}

/* —— Autenticação (home + login OAuth redirect + fluxo código) — iOS HIG —— */
body:has(.ios-auth-page) .bg-decor {
    display: none;
}

@keyframes iosAuthPageIn {
    from {
        opacity: 0;
        transform: translateY(12px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.ios-auth-page {
    min-height: 100vh;
    min-height: 100dvh;
    background: var(--color-bg);
    color: var(--color-text);
    position: relative;
    display: flex;
    flex-direction: column;
    animation: iosAuthPageIn 0.42s cubic-bezier(0.16, 1, 0.3, 1) backwards;
}

@media (prefers-reduced-motion: reduce) {
    .ios-auth-page {
        animation: none;
    }
}

.ios-auth-page.ios-auth-is-leaving {
    animation: none !important;
    opacity: 0 !important;
    transition: opacity 0.22s ease;
    pointer-events: none;
}

.ios-auth-page::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse 80% 55% at 10% -10%, rgba(0, 122, 255, 0.1), transparent 50%),
        radial-gradient(ellipse 65% 50% at 100% 100%, rgba(52, 199, 89, 0.07), transparent 45%),
        radial-gradient(ellipse 50% 40% at 50% 100%, rgba(100, 80, 40, 0.05), transparent 50%);
    z-index: 0;
}

[data-theme="dark"] .ios-auth-page::before {
    background:
        radial-gradient(ellipse 70% 50% at 15% 0%, rgba(10, 132, 255, 0.16), transparent 55%),
        radial-gradient(ellipse 50% 40% at 100% 110%, rgba(52, 199, 89, 0.05), transparent 50%),
        radial-gradient(ellipse 45% 35% at 40% 95%, rgba(180, 150, 90, 0.06), transparent 55%);
}

/* Home login — fundo tecnológico em canvas: auroras + campo de bolinhas (ondas no tempo) */
.ios-auth-ambient {
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 0;
    overflow: hidden;
}

.ios-auth-ambient__canvas {
    display: block;
    width: 100%;
    height: 100%;
    vertical-align: middle;
}

.ios-auth-ambient__vignette {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(
        ellipse 85% 70% at 50% 45%,
        transparent 0%,
        transparent 45%,
        rgba(255, 255, 255, 0.55) 100%
    );
    mix-blend-mode: soft-light;
}

[data-theme="dark"] .ios-auth-ambient__vignette {
    background: radial-gradient(ellipse 90% 75% at 50% 48%, transparent 35%, rgba(0, 8, 24, 0.75) 100%);
    mix-blend-mode: multiply;
}

.ios-auth-ambient__scan {
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0.22;
    background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 3px,
        rgba(0, 110, 220, 0.06) 3px,
        rgba(0, 110, 220, 0.06) 4px
    );
    animation: iosAuthTechScan 7.5s linear infinite;
    mix-blend-mode: overlay;
}

[data-theme="dark"] .ios-auth-ambient__scan {
    opacity: 0.12;
    background: repeating-linear-gradient(
        0deg,
        transparent,
        transparent 4px,
        rgba(80, 200, 255, 0.05) 4px,
        rgba(80, 200, 255, 0.05) 5px
    );
}

@keyframes iosAuthTechScan {
    0% {
        transform: translateY(0);
    }
    100% {
        transform: translateY(5px);
    }
}

@media (prefers-reduced-motion: reduce) {
    .ios-auth-ambient__scan {
        animation: none;
        opacity: 0.1;
    }
}


.ios-auth-scroll {
    position: relative;
    z-index: 2;
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 0 env(safe-area-inset-right) calc(1.5rem + env(safe-area-inset-bottom)) env(safe-area-inset-left);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.ios-auth-topbar {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.6rem 1rem;
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 0.5px solid var(--separator-color);
    flex-shrink: 0;
}

.ios-auth-topbar-spacer {
    flex: 1;
    min-width: 0;
}

.ios-auth-brand-mark {
    font-weight: 700;
    font-size: 1.125rem;
    letter-spacing: -0.03em;
    color: var(--color-primary);
}

.ios-auth-brand-mark--img {
    display: flex;
    align-items: center;
    min-width: 0;
    line-height: 0;
}

.ios-auth-brand-mark--img .brand-logo-img--home-topbar {
    display: block;
    height: 40px;
    width: auto;
    max-width: min(260px, 52vw);
    object-fit: contain;
}

.ios-auth-brand-mark--img .brand-logo-img--home-topbar-square {
    height: 36px;
    width: 36px;
    max-width: 36px;
    object-fit: contain;
}

/* Reflexo: ciclo de cor via `color` + currentColor (evita @property, que em alguns navegadores não anima e fica só no verde) */
/* Reflexo diagonal na marca (home topbar + navbar); mask = PNG */
.ios-auth-topbar-brand-shimmer,
.nav-brand.marca-brand-shimmer {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    line-height: 0;
}

/*
 * Navbar: sem isto o <a> cresce com flex:1 e o ::after (inset:0) cobre toda a largura;
 * a máscara centra no retângulo grande e o reflexo aparece ao lado da imagem (pior no mobile).
 */
.nav-brand.marca-brand-shimmer {
    flex: 0 1 auto;
    width: fit-content;
    max-width: min(400px, 72vw);
    align-self: center;
}

.ios-auth-topbar-brand-shimmer .brand-logo-img--home-topbar,
.ios-auth-topbar-brand-shimmer .brand-logo-img--home-topbar-square,
.nav-brand.marca-brand-shimmer .brand-logo-img--navbar {
    position: relative;
    z-index: 0;
}

.ios-auth-topbar-brand-shimmer::after,
.nav-brand.marca-brand-shimmer::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    color: rgba(0, 156, 59, 0.82);
    /* Faixa mais larga para cobrir o preenchimento da logo (não só o contorno) */
    background: linear-gradient(
        128deg,
        transparent 0%,
        transparent 32%,
        currentColor 42%,
        currentColor 58%,
        transparent 68%,
        transparent 100%
    );
    background-size: 220% 220%;
    background-repeat: no-repeat;
    background-position: 0% 0%;
    /* Um único ciclo: em cada terço só uma cor + uma passagem completa do reflexo (sem trocar cor a meio). */
    animation: marcaReflectLogoUnified 24s cubic-bezier(0.42, 0, 0.58, 1) infinite;

    -webkit-mask-image: var(--marca-shimmer-mask);
    mask-image: var(--marca-shimmer-mask);
    -webkit-mask-size: contain;
    mask-size: contain;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-mode: alpha;
    mask-mode: alpha;

    /* Logo preta (claro): screen aplica a cor ao preenchimento sólido, não só ao AA das bordas */
    mix-blend-mode: screen;
    opacity: 0.9;
}

html[data-theme="dark"] .ios-auth-topbar-brand-shimmer::after,
html[data-theme="dark"] .nav-brand.marca-brand-shimmer::after {
    /* Logo branca: multiply tinga o miolo inteiro onde a faixa passa */
    mix-blend-mode: multiply;
    opacity: 0.88;
}

@keyframes marcaReflectLogoUnified {
    /* ~8 s verde: posição vai e volta suave no mesmo patamar de cor */
    0% {
        color: rgba(0, 156, 59, 0.82);
        background-position: -55% -55%;
    }
    33.333% {
        color: rgba(0, 156, 59, 0.82);
        background-position: 115% 115%;
    }
    /* Troca cor + reinício da faixa (instantâneo no tempo) */
    33.334% {
        color: rgba(255, 223, 0, 0.8);
        background-position: -55% -55%;
    }
    66.666% {
        color: rgba(255, 223, 0, 0.8);
        background-position: 115% 115%;
    }
    66.667% {
        color: rgba(0, 39, 118, 0.84);
        background-position: -55% -55%;
    }
    99.99% {
        color: rgba(0, 39, 118, 0.84);
        background-position: 115% 115%;
    }
    100% {
        color: rgba(0, 156, 59, 0.82);
        background-position: -55% -55%;
    }
}

@media (prefers-reduced-motion: reduce) {
    .ios-auth-topbar-brand-shimmer::after,
    .nav-brand.marca-brand-shimmer::after {
        animation: none;
        background-position: 30% 30%;
        color: rgba(0, 156, 59, 0.55);
    }
}

.brand-logo-img--home-hero {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
}

.brand-logo-img--home-hero-wide {
    width: 100%;
    height: auto;
    max-height: 100%;
    object-fit: contain;
}

.ios-auth-step-label {
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-soft);
    letter-spacing: -0.01em;
}

.ios-auth-body {
    flex: 1;
    width: 100%;
    max-width: 28rem;
    margin: 0 auto;
    padding: 1.25rem 1.25rem 2rem;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.ios-auth-main-col {
    width: 100%;
    max-width: 26.5rem;
    margin: 0 auto;
    padding: 1.5rem 1.25rem 2.5rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.ios-auth-hero {
    text-align: center;
    margin-bottom: 1.75rem;
}

.ios-auth-logo-ring {
    width: 88px;
    height: 88px;
    margin: 0 auto 1.25rem;
    border-radius: 22px;
    background: var(--surface-level-1);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    border: 0.5px solid var(--glass-border);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 14px;
}

[data-theme="dark"] .ios-auth-logo-ring {
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
}

/* Hero: logo cadastrada — sem “cartão”; área ~5× a versão antiga (~58px → ~290px) */
.ios-auth-logo-ring.ios-auth-logo-ring--marca {
    width: min(290px, 85vw);
    height: min(290px, 85vw);
    max-width: 100%;
    margin: 0 auto 1.25rem;
    padding: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    border: none;
}

[data-theme="dark"] .ios-auth-logo-ring.ios-auth-logo-ring--marca {
    box-shadow: none;
}

.ios-auth-logo-ring.ios-auth-logo-ring--marca .brand-logo-img--home-hero {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.ios-auth-logo-ring.ios-auth-logo-ring--marca .brand-logo-img--home-hero-wide {
    width: 100%;
    height: auto;
    max-height: 100%;
    object-fit: contain;
}

/* Hero SVG (vector + animações dentro do ficheiro) — tema: .brand-logo-img no shell */
.ios-auth-sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.ios-auth-hero-svg-shell {
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(290px, 85vw);
    height: min(290px, 85vw);
    max-width: 100%;
}

.ios-auth-hero-svg {
    width: 100%;
    height: 100%;
    border: none;
    pointer-events: none;
}

.ios-auth-hero-svg-shell--compact {
    width: 100%;
    max-width: min(220px, 88vw);
    height: auto;
    min-height: 120px;
    max-height: min(220px, 42vw);
    margin-left: auto;
    margin-right: auto;
}

.ios-auth-hero-svg--compact {
    min-height: 100px;
    max-height: min(200px, 40vw);
}

.ios-auth-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: brightness(0) saturate(100%) invert(27%) sepia(89%) saturate(1598%) hue-rotate(199deg) brightness(98%) contrast(98%);
}

[data-theme="dark"] .ios-auth-logo-img {
    filter: brightness(0) saturate(100%) invert(58%) sepia(31%) saturate(2400%) hue-rotate(191deg) brightness(100%) contrast(101%);
}

.ios-auth-large-title {
    font-size: clamp(2rem, 6vw, 2.375rem);
    font-weight: 700;
    letter-spacing: -0.035em;
    line-height: 1.08;
    margin: 0 0 0.4rem;
    color: var(--color-text);
    text-align: left;
}

.ios-auth-main-col .ios-auth-large-title {
    text-align: center;
}

.ios-auth-subtitle {
    font-size: 1.0625rem;
    line-height: 1.4;
    color: var(--text-soft);
    margin: 0;
    text-align: left;
    font-weight: 400;
}

.ios-auth-main-col .ios-auth-subtitle {
    text-align: center;
}

.ios-auth-subtitle--brand {
    font-size: 1.125rem;
    font-weight: 650;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-top: 0.15rem;
}

[data-theme="dark"] .ios-auth-subtitle--brand {
    color: #5eb0ff;
}

.ios-auth-card-stack {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.ios-auth-card {
    background: var(--surface-level-1);
    border-radius: 16px;
    border: 0.5px solid var(--glass-border);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    padding: 1.35rem 1.25rem 1.4rem;
    width: 100%;
    animation: iosLegalFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

[data-theme="dark"] .ios-auth-card {
    box-shadow: none;
}

.ios-auth-body .ios-auth-card {
    margin-top: 1rem;
}

.ios-auth-card-eyebrow {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.065em;
    color: var(--text-soft);
    margin: 0 0 1rem;
    text-align: center;
}

.ios-auth-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    padding: 0.85rem 1.1rem;
    border-radius: 14px;
    font-size: 1.0625rem;
    font-weight: 600;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: transform 0.15s ease, opacity 0.15s ease, filter 0.15s ease;
    letter-spacing: -0.01em;
}

.ios-auth-btn:active {
    transform: scale(0.98);
}

/* Logo Roblox nos botões da home iOS (mesmo asset que referência .roblox-icon) */
.roblox-icon {
    display: block;
    object-fit: contain;
    flex-shrink: 0;
}

.ios-auth-btn .ios-auth-roblox-icon {
    width: 24px;
    height: 24px;
    transform-origin: 50% 50%;
    pointer-events: none;
}

/* Contraste no botão azul: logótipo em branco */
.ios-auth-btn-primary .ios-auth-roblox-icon {
    filter: brightness(0) invert(1);
}

.ios-auth-btn-secondary .ios-auth-roblox-icon {
    opacity: 0.95;
}

.ios-auth-btn:hover .ios-auth-roblox-icon,
.ios-auth-btn:focus-visible .ios-auth-roblox-icon {
    animation: iosAuthRobloxSpin 0.75s linear infinite;
}

@keyframes iosAuthRobloxSpin {
    to {
        transform: rotate(360deg);
    }
}

@media (prefers-reduced-motion: reduce) {
    .ios-auth-btn:hover .ios-auth-roblox-icon,
    .ios-auth-btn:focus-visible .ios-auth-roblox-icon {
        animation: none;
    }
}

.ios-auth-btn-primary {
    background        : var(--color-primary);
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(0, 122, 255, 0.28);
}

[data-theme="dark"] .ios-auth-btn-primary {
    box-shadow: 0 2px 12px rgba(10, 132, 255, 0.25);
}

.ios-auth-btn-primary:hover {
    filter: brightness(1.06);
}

.ios-auth-btn-secondary {
    background: var(--surface-level-2);
    color: var(--color-text);
}

[data-theme="dark"] .ios-auth-btn-secondary {
    background: #2c2c2e;
}

.ios-auth-btn-secondary:hover {
    filter: brightness(0.98);
}

.ios-auth-btn-tertiary {
    background: transparent;
    color: var(--color-primary);
    font-size: 1rem;
    padding: 0.65rem;
    box-shadow: none;
}

.ios-auth-btn-success {
    background: var(--color-success);
    color: #ffffff;
    box-shadow: 0 2px 8px rgba(52, 199, 89, 0.3);
}

.ios-auth-btn-success:hover {
    filter: brightness(1.05);
}

.ios-auth-btn-danger-ghost {
    background: var(--surface-level-2);
    color: var(--color-danger);
    border: 0.5px solid var(--separator-color);
}

.ios-auth-divider {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin: 1rem 0;
    color: var(--text-soft);
    font-size: 0.8125rem;
    font-weight: 500;
}

.ios-auth-divider::before,
.ios-auth-divider::after {
    content: "";
    flex: 1;
    height: 0.5px;
    background: var(--separator-color);
}

/* Formulários no fluxo código — Search Bar / grupos */
.ios-auth-page .ios-auth-field {
    margin-bottom: 1.15rem;
}

.ios-auth-page .ios-auth-field label {
    display: block;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--text-soft);
    margin-bottom: 0.45rem;
    letter-spacing: -0.01em;
}

.ios-auth-search-wrap {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    background: var(--surface-level-2);
    border-radius: 14px;
    padding: 0.75rem 1rem;
    border: none;
    transition: box-shadow 0.2s ease;
}

[data-theme="dark"] .ios-auth-search-wrap {
    background: #2c2c2e;
}

.ios-auth-search-wrap:focus-within {
    box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.25);
}

[data-theme="dark"] .ios-auth-search-wrap:focus-within {
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.35);
}

.ios-auth-search-wrap i {
    color: var(--text-soft);
    font-size: 1rem;
    flex-shrink: 0;
}

.ios-auth-search-wrap input {
    flex: 1;
    border: none;
    background: transparent;
    font-size: 1.0625rem;
    color: var(--color-text);
    outline: none;
    min-width: 0;
}

.ios-auth-search-wrap input::placeholder {
    color: var(--text-tertiary);
}

.ios-auth-search-roblox {
    width: 20px;
    height: 20px;
    object-fit: contain;
    flex-shrink: 0;
    opacity: 0.88;
    pointer-events: none;
}

.ios-auth-btn-roblox-tiny {
    width: 22px;
    height: 22px;
    object-fit: contain;
    flex-shrink: 0;
    pointer-events: none;
    filter: brightness(0) invert(1);
}

.ios-auth-hint {
    display: block;
    font-size: 0.8125rem;
    color: var(--text-soft);
    margin-top: 0.45rem;
    line-height: 1.35;
}

.ios-auth-page .ios-auth-infopill {
    background: var(--surface-level-2);
    border-radius: 14px;
    padding: 0.95rem 1rem;
    margin-bottom: 1.15rem;
    text-align: left;
    font-size: 0.9375rem;
    line-height: 1.45;
    color: var(--text-soft);
    border: 0.5px solid var(--glass-border);
}

[data-theme="dark"] .ios-auth-page .ios-auth-infopill {
    background: #2c2c2e;
}

.ios-auth-page .ios-auth-infopill strong {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    color: var(--color-text);
    font-size: 0.8125rem;
    font-weight: 600;
    margin-bottom: 0.35rem;
}

.ios-auth-page .ios-auth-infopill strong i {
    color: var(--color-primary);
}

.ios-auth-page .ios-auth-infopill code,
.ios-auth-page .ios-auth-mono {
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;
    font-size: 0.875em;
    color: var(--color-primary);
    word-break: break-all;
}

.ios-auth-actions-row {
    display: flex;
    gap: 0.65rem;
    width: 100%;
    margin-top: 0.25rem;
}

.ios-auth-actions-row .ios-auth-btn {
    flex: 1;
    margin-bottom: 0;
}

.ios-auth-page .user-confirm-card {
    background: var(--surface-level-2);
    border: 0.5px solid var(--glass-border);
    border-radius: 16px;
    padding: 1.35rem 1rem;
    box-shadow: none;
}

.ios-auth-page .user-confirm-card:hover {
    transform: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
}

.ios-auth-page .user-confirm-card img {
    border: 2px solid var(--color-primary);
    width: 84px;
    height: 84px;
}

.ios-auth-page .user-confirm-card .display-name {
    color: var(--color-text);
}

.ios-auth-page .user-confirm-card .username,
.ios-auth-page .user-confirm-card .user-id {
    color: var(--text-soft);
}

.ios-auth-page .user-card-horizontal {
    background: var(--surface-level-2);
    border: 0.5px solid var(--glass-border);
    border-radius: 14px;
}

.ios-auth-page .user-card-horizontal:hover {
    transform: none;
}

.ios-auth-page .user-card-horizontal img {
    border-color: var(--color-primary);
}

.ios-auth-page .user-card-horizontal .ios-auth-udisplay {
    font-weight: 600;
    color: var(--color-text);
}

.ios-auth-page .user-card-horizontal .ios-auth-uuser {
    font-size: 0.875rem;
    color: var(--text-soft);
}

/* Passo 3 — layout em secções */
.ios-auth-subtitle-row {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    margin-bottom: 0.25rem;
}

.ios-auth-subtitle--flex {
    flex: 1;
    margin: 0;
    min-width: 0;
}

.ios-auth-help-chip {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: 0.5px solid var(--glass-border);
    background: var(--surface-level-2);
    color: var(--color-primary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
    transition: transform 0.15s ease, filter 0.15s ease;
}

.ios-auth-help-chip:hover {
    filter: brightness(0.97);
}

.ios-auth-help-chip:active {
    transform: scale(0.96);
}

.ios-auth-card--verify {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
    padding: 1.2rem 1.15rem 1.35rem;
}

.ios-auth-verify-section {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.ios-auth-verify-label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-soft);
    margin: 0;
}

.ios-auth-user-strip {
    margin-bottom: 0 !important;
}

a.ios-auth-user-strip--link {
    text-decoration: none;
    color: inherit;
    cursor: pointer;
    box-sizing: border-box;
    transition: background 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

a.ios-auth-user-strip--link:hover {
    background: var(--surface-level-1);
    border-color: rgba(0, 122, 255, 0.35);
    box-shadow: 0 2px 12px rgba(0, 122, 255, 0.08);
}

a.ios-auth-user-strip--link:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 3px;
}

[data-theme="dark"] a.ios-auth-user-strip--link:hover {
    border-color: rgba(10, 132, 255, 0.45);
    box-shadow: 0 2px 16px rgba(10, 132, 255, 0.12);
}

.ios-auth-code-panel {
    background: var(--surface-level-2);
    border: 0.5px solid var(--glass-border);
    border-radius: 14px;
    padding: 0.85rem 0.9rem 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

[data-theme="dark"] .ios-auth-code-panel {
    background: #2c2c2e;
}

.ios-auth-code-value {
    display: block;
    width: 100%;
    font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
    font-size: 1.35rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-align: center;
    color: var(--color-text);
    background: transparent;
    border: none;
    padding: 0.35rem 0;
    cursor: pointer;
    border-radius: 8px;
    transition: background 0.15s ease;
}

.ios-auth-code-value:hover {
    background: rgba(0, 122, 255, 0.06);
}

[data-theme="dark"] .ios-auth-code-value:hover {
    background: rgba(10, 132, 255, 0.12);
}

.ios-auth-copy-btn-subtle {
    align-self: center;
    padding: 0.45rem 1rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-primary);
    background: transparent;
    border: none;
    border-radius: 10px;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    transition: background 0.15s ease;
}

.ios-auth-copy-btn-subtle:hover {
    background: rgba(0, 122, 255, 0.1);
}

.ios-auth-verify-actions {
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
    margin-top: 0.25rem;
}

.ios-auth-verify-form {
    width: 100%;
    margin: 0;
}

.ios-auth-code-panel--expired {
    opacity: 0.58;
}

.ios-auth-code-panel--expired .ios-auth-code-value {
    text-decoration: line-through;
    cursor: default;
}

.ios-auth-code-panel--expired .ios-auth-code-value:hover {
    background: transparent;
}

.ios-auth-code-meta {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.45rem;
    margin-top: 0.4rem;
    text-align: center;
}

.ios-auth-code-ttl {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.4;
    color: var(--text-soft);
}

.ios-auth-code-expired-note {
    margin: 0;
    font-size: 0.875rem;
    font-weight: 600;
    color: #ff3b30;
}

[data-theme="dark"] .ios-auth-code-expired-note {
    color: #ff6961;
}

.ios-auth-regen-form {
    margin: 0;
    padding: 0;
}

.ios-auth-regen-btn {
    margin: 0;
    padding: 0.4rem 0.75rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-primary);
    background: transparent;
    border: none;
    border-radius: 12px;
    cursor: pointer;
    opacity: 0.88;
    transition: opacity 0.15s ease, background 0.15s ease;
    font-family: inherit;
}

.ios-auth-regen-btn:hover:not(:disabled) {
    opacity: 1;
    background: rgba(0, 122, 255, 0.09);
}

[data-theme="dark"] .ios-auth-regen-btn:hover:not(:disabled) {
    background: rgba(10, 132, 255, 0.16);
}

.ios-auth-regen-btn:disabled {
    opacity: 0.42;
    cursor: not-allowed;
}

.ios-auth-verify-actions .ios-auth-btn-primary:disabled {
    opacity: 0.45;
    cursor: not-allowed;
    filter: grayscale(0.15);
}

.ios-auth-btn-outline {
    background: transparent;
    color: var(--color-primary);
    border: 1.5px solid var(--color-primary);
    box-shadow: none;
}

.ios-auth-btn-outline:hover {
    background: rgba(0, 122, 255, 0.08);
    filter: none;
}

/* Ajuda login: mesmo .modal-overlay que o resto do site (#iosAuthHelpModal) */
.ios-auth-help-modal-body .ios-auth-help-lead {
    margin-top: 0;
}

.ios-auth-help-lead {
    font-size: 0.9375rem;
    line-height: 1.45;
    color: var(--text-soft);
    margin: 0 0 1rem;
}

/* Demo animado — fluxo Roblox (perfil → Editar perfil → Sobre → modal bio), paleta escura fixa no mock */
.ios-auth-profile-mock {
    --mock-bg: #060607;
    --mock-surface: #121214;
    --mock-card: #161617;
    --mock-row: #1b1d1e;
    --mock-row-hl: #2a2d30;
    --mock-pill: #2c2c2e;
    --mock-text: #ffffff;
    --mock-dim: #8e8e93;
    --mock-blue: #0056ff;
    --mock-border: rgba(255, 255, 255, 0.08);

    margin-bottom: 1rem;
    border-radius: 16px;
    border: 0.5px solid var(--mock-border);
    background: var(--mock-bg);
    overflow: hidden;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", Roboto, sans-serif;
    text-align: left;
    -webkit-font-smoothing: antialiased;
}

.ios-auth-mock-viewport {
    position: relative;
    min-height: 288px;
    max-height: 340px;
}

@media (min-width: 420px) {
    .ios-auth-mock-viewport {
        min-height: 300px;
    }
}

.ios-auth-mock-scene {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.38s cubic-bezier(0.25, 1, 0.5, 1);
    z-index: 1;
}

.ios-auth-mock-scene.is-mock-active {
    opacity: 1;
    pointer-events: none;
    z-index: 2;
}

/* —— Tela 1: perfil Roblox —— */
.ios-auth-mock-rb {
    position: relative;
    height: 100%;
    display: flex;
    flex-direction: column;
    min-height: 288px;
}

.ios-auth-mock-rb-badge {
    position: absolute;
    top: 6px;
    right: 8px;
    z-index: 3;
    font-size: 0.58rem;
    font-weight: 600;
    color: var(--mock-text);
    padding: 0.2rem 0.45rem;
    border-radius: 8px;
    background: var(--mock-pill);
}

.ios-auth-mock-rb-figure {
    flex: 1;
    min-height: 72px;
    max-height: 92px;
    margin: 0 8px;
    border-radius: 12px;
    background: linear-gradient(180deg, #1a1a1e 0%, #0d0d0f 100%);
    position: relative;
    overflow: hidden;
}

.ios-auth-mock-rb-figure::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 6px;
    transform: translateX(-50%);
    width: 36px;
    height: 52px;
    border-radius: 6px 6px 4px 4px;
    background: linear-gradient(145deg, #2a2a32, #18181c);
    box-shadow: 0 3px 12px rgba(234, 67, 53, 0.06);
}

.ios-auth-mock-rb-body {
    padding: 0.35rem 0.65rem 0.7rem;
    flex-shrink: 0;
}

.ios-auth-mock-rb-user {
    display: flex;
    gap: 0.45rem;
    align-items: flex-start;
    margin-top: -22px;
    position: relative;
    z-index: 2;
}

.ios-auth-mock-rb-avatar-ring {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--mock-bg);
    padding: 2px;
    position: relative;
}

.ios-auth-mock-rb-avatar-ring::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: #2563eb;
    border: 2px solid var(--mock-bg);
}

.ios-auth-mock-rb-avatar {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    background: linear-gradient(145deg, #4a5568, #1a202c);
}

.ios-auth-mock-rb-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ios-auth-mock-rb-meta {
    padding-top: 26px;
    min-width: 0;
}

.ios-auth-mock-rb-dn {
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--mock-text);
    letter-spacing: -0.02em;
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

.ios-auth-mock-rb-dn-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 140px;
}

.ios-auth-mock-rb-premium {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.95rem;
    height: 0.95rem;
    font-size: 0.5rem;
    font-weight: 800;
    border-radius: 3px;
    background: #fff;
    color: #111;
    flex-shrink: 0;
}

.ios-auth-mock-rb-handle {
    font-size: 0.62rem;
    color: var(--mock-dim);
    margin-top: 0.05rem;
}

.ios-auth-mock-rb-seen {
    font-size: 0.55rem;
    color: var(--mock-dim);
    margin-top: 0.15rem;
    opacity: 0.85;
}

.ios-auth-mock-rb-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 0.28rem;
    margin-top: 0.4rem;
}

.ios-auth-mock-rb-pills span {
    font-size: 0.52rem;
    font-weight: 600;
    color: var(--mock-text);
    background: var(--mock-pill);
    padding: 0.22rem 0.4rem;
    border-radius: 999px;
}

.ios-auth-mock-rb-about {
    margin-top: 0.45rem;
    text-align: left;
}

.ios-auth-mock-rb-bio-line {
    margin: 0;
    font-size: 0.6rem;
    font-weight: 600;
    color: var(--mock-text);
}

.ios-auth-mock-rb-muted {
    margin: 0.15rem 0 0;
    font-size: 0.55rem;
    color: var(--mock-dim);
}

.ios-auth-mock-rb-more {
    font-size: 0.55rem;
    color: var(--mock-text);
    display: inline-block;
    margin-top: 0.2rem;
    font-weight: 600;
}

.ios-auth-mock-rb-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 0.32rem;
    margin-top: 0.45rem;
    align-items: center;
}

.ios-auth-mock-chip {
    font-size: 0.54rem;
    font-weight: 600;
    color: var(--mock-text);
    background: var(--mock-pill);
    padding: 0.38rem 0.55rem;
    border-radius: 14px;
    white-space: nowrap;
    transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease;
}

.ios-auth-mock-chip--accent {
    background: #3a3a3c;
}

.ios-auth-mock-chip--dots {
    padding: 0.38rem 0.65rem;
    letter-spacing: 0.1em;
}

.ios-auth-mock-chip.ios-auth-mock-tap,
[data-mock-ref].ios-auth-mock-tap {
    transform: scale(0.96);
    box-shadow: 0 0 0 2px rgba(0, 122, 255, 0.55);
}

.ios-auth-mock-set-row.ios-auth-mock-tap {
    transform: scale(0.985);
    box-shadow: inset 0 0 0 1px rgba(10, 132, 255, 0.45);
}

.ios-auth-mock-bio-save.ios-auth-mock-tap {
    transform: scale(0.97);
    filter: brightness(1.08);
}

/* —— Tela 2: editar perfil —— */
.ios-auth-mock-scene--settings {
    background: #000000;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}

.ios-auth-mock-set {
    padding: 0.4rem 0.5rem 0.6rem;
    flex: 1;
}

.ios-auth-mock-set-head {
    text-align: center;
    position: relative;
    margin-bottom: 0.35rem;
}

.ios-auth-mock-set-back {
    position: absolute;
    left: 0;
    top: 2px;
    font-size: 0.62rem;
    font-weight: 600;
    color: var(--mock-text);
}

.ios-auth-mock-set-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    margin: 1.15rem auto 0;
    overflow: hidden;
    background: linear-gradient(145deg, #4a5568, #1a202c);
}

.ios-auth-mock-set-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ios-auth-mock-set-group {
    margin-top: 0.5rem;
    background: var(--mock-row);
    border-radius: 16px;
    overflow: hidden;
    border: 0.33px solid var(--mock-border);
}

.ios-auth-mock-set-row {
    display: grid;
    grid-template-columns: 1fr auto 0.65rem;
    gap: 0.35rem;
    align-items: center;
    padding: 0.5rem 0.55rem;
    border-bottom: 0.33px solid rgba(255, 255, 255, 0.06);
    font-size: 0.62rem;
    transition: background 0.15s ease, transform 0.12s ease;
}

.ios-auth-mock-set-row:last-child {
    border-bottom: none;
}

.ios-auth-mock-set-l {
    font-weight: 700;
    color: var(--mock-text);
}

.ios-auth-mock-set-v {
    color: var(--mock-dim);
    text-align: right;
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ios-auth-mock-set-v--clip {
    font-size: 0.55rem;
    max-width: 100px;
}

.ios-auth-mock-set-c {
    color: var(--mock-dim);
    font-weight: 600;
    font-size: 0.75rem;
}

.ios-auth-mock-set-row--sobre {
    background: var(--mock-row-hl);
}

/* —— Sheet “Mudar a bio” —— */
.ios-auth-mock-bio-sheet {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10;
    background: #212325;
    border-radius: 18px 18px 0 0;
    border: 0.33px solid var(--mock-border);
    border-bottom: none;
    padding: 0.55rem 0.65rem 0.65rem;
    transform: translateY(102%);
    transition: transform 0.42s cubic-bezier(0.25, 1, 0.35, 1);
    box-shadow: 0 -12px 40px rgba(0, 0, 0, 0.55);
}

.ios-auth-profile-mock--bio-open .ios-auth-mock-bio-sheet {
    transform: translateY(0);
}

.ios-auth-mock-bio-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 0.35rem;
}

.ios-auth-mock-bio-title {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--mock-text);
}

.ios-auth-mock-bio-x {
    color: var(--mock-dim);
    font-size: 1rem;
    line-height: 1;
    cursor: default;
}

.ios-auth-mock-bio-lead {
    margin: 0 0 0.4rem;
    font-size: 0.52rem;
    line-height: 1.35;
    color: var(--mock-dim);
}

.ios-auth-mock-bio-field {
    background: #141518;
    border-radius: 10px;
    border: 0.33px solid rgba(255, 255, 255, 0.1);
    padding: 0.45rem 0.5rem;
    min-height: 82px;
    max-height: 92px;
    overflow-y: auto;
}

.ios-auth-mock-bio-lines {
    font-size: 0.54rem;
    line-height: 1.4;
    color: #c5c5c7;
    word-break: break-word;
}

.ios-auth-mock-bio-pre {
    color: #adb5bd;
}

.ios-auth-mock-bio-code-line {
    display: block;
    margin-top: 0.3rem;
}

.ios-auth-mock-bio-typed {
    color: var(--mock-text);
    font-weight: 600;
    font-family: ui-monospace, "SF Mono", Menlo, monospace;
    letter-spacing: 0.04em;
}

.ios-auth-mock-bio-caret {
    display: inline-block;
    width: 1px;
    height: 0.85em;
    margin-left: 1px;
    background: var(--mock-blue);
    animation: iosAuthMockCaretBlink 1s step-end infinite;
    vertical-align: text-bottom;
}

@keyframes iosAuthMockCaretBlink {
    50% { opacity: 0; }
}

.ios-auth-profile-mock--bio-open .ios-auth-mock-bio-caret {
    visibility: visible;
}

.ios-auth-mock-bio-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 0.4rem;
}

.ios-auth-mock-bio-count {
    font-size: 0.52rem;
    color: var(--mock-dim);
}

.ios-auth-mock-bio-save {
    font-size: 0.6rem;
    font-weight: 700;
    color: #fff;
    background: var(--mock-blue);
    padding: 0.38rem 1rem;
    border-radius: 12px;
    transition: transform 0.12s ease, filter 0.12s ease;
}

@media (prefers-reduced-motion: reduce) {
    .ios-auth-mock-scene,
    .ios-auth-mock-bio-sheet,
    .ios-auth-mock-chip,
    .ios-auth-mock-set-row {
        transition: none !important;
    }
}

.ios-auth-help-steps {
    margin: 0 0 1rem;
    padding-left: 1.2rem;
    font-size: 0.9375rem;
    line-height: 1.5;
    color: var(--text-soft);
}

.ios-auth-help-steps li {
    margin-bottom: 0.4rem;
}

.ios-auth-help-dismiss {
    width: 100%;
}

/* Legado: ocultar timer se ainda existir em cache */
.ios-auth-page .timer-box {
    display: none !important;
}

.ios-auth-page .btn-outline-blue {
    border: 1.5px solid var(--color-primary);
    color: var(--color-primary);
    border-radius: 14px;
    font-weight: 600;
    background: transparent;
}

.ios-auth-page .btn-outline-blue:hover {
    background: rgba(0, 122, 255, 0.08);
    color: var(--color-primary);
}

.ios-auth-page .btn-blue {
    background: var(--color-primary);
    border-radius: 14px;
    font-weight: 600;
    box-shadow: 0 2px 10px rgba(0, 122, 255, 0.25);
}

.ios-auth-page .btn-gray {
    background: var(--surface-level-2);
    color: var(--color-text);
    border-radius: 14px;
    font-weight: 600;
    box-shadow: none;
}

[data-theme="dark"] .ios-auth-page .btn-gray {
    background: #3a3a3c;
}

.ios-auth-page .btn-green {
    background: var(--color-success);
    border-radius: 14px;
    font-weight: 600;
}

.btn-roblox-code {
    background: #555555;
    color: white;
    border-radius: 12px;
    padding: 0.9rem;
    font-weight: bold;
    width: 100%;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    text-decoration: none;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.btn-roblox-code:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 15px rgba(0, 0, 0, 0.3);
}

/* Common Buttons */
.btn-blue {
    background: #1565c0;
    color: white;
    border-radius: 12px;
    padding: 0.9rem;
    font-weight: bold;
    width: 100%;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-decoration: none;
    margin-bottom: 1rem;
    box-shadow: 0 4px 10px rgba(21, 101, 192, 0.3);
}
.btn-blue:hover { 
    transform: translateY(-3px);
    box-shadow: 0 8px 15px rgba(21, 101, 192, 0.4);
}

.btn-gray {
    background: #757575;
    color: white;
    border-radius: 12px;
    padding: 0.9rem;
    font-weight: bold;
    width: 100%;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-decoration: none;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}
.btn-gray:hover { 
    transform: translateY(-2px);
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2);
}

.btn-green {
    background: #2bc06a;
    color: white;
    border-radius: 12px;
    padding: 0.9rem;
    font-weight: bold;
    width: 100%;
    border: none;
    cursor: pointer;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    text-decoration: none;
    margin-bottom: 1rem;
    box-shadow: 0 4px 10px rgba(43, 192, 106, 0.3);
}
.btn-green:hover { 
    transform: translateY(-3px);
    box-shadow: 0 8px 15px rgba(43, 192, 106, 0.4);
}

/* Inputs & Info Boxes */
.info-box {
    background: #f8f9fa;
    border-left: 4px solid #1565c0;
    padding: 1rem;
    border-radius: 4px 8px 8px 4px;
    margin-bottom: 1.5rem;
    text-align: left;
    font-size: 0.9rem;
    color: #444;
    width: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.info-box:hover {
    transform: translateX(5px);
    box-shadow: -2px 4px 10px rgba(0,0,0,0.05);
}

.info-box strong {
    display: block;
    margin-bottom: 0.5rem;
    color: #1565c0;
}

.input-group {
    width: 100%;
    text-align: left;
    margin-bottom: 1.5rem;
}

.input-group label {
    display: block;
    font-weight: bold;
    color: #0a3055;
    margin-bottom: 0.5rem;
    font-size: 0.9rem;
    transition: color 0.3s ease;
}

.input-group input {
    width: 100%;
    padding: 0.9rem;
    border: 2px solid #e0e0e0;
    border-radius: 12px;
    font-size: 1rem;
    outline: none;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
    background-color: #fafafa;
}

.input-group input:focus {
    border-color: #1565c0;
    background-color: #ffffff;
    box-shadow: 0 0 0 4px rgba(21, 101, 192, 0.15);
    transform: translateY(-2px);
}

.input-group input:focus + label {
    color: #1565c0;
}

.input-help {
    font-size: 0.8rem;
    color: #666;
    margin-top: 0.5rem;
    display: block;
    transition: opacity 0.3s ease;
}

/* User Card */
/* ==========================================================================
   Modal Global (HTMX/Fetch) - iOS Bottom Sheet
   ========================================================================== */
.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    display: flex;
    justify-content: center;
    align-items: flex-end; /* Align to bottom for iOS sheet */
    z-index: 9999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), visibility 0.3s ease;
}

.modal-overlay.active {
    opacity: 1;
    visibility: visible;
}

.modal-dialog {
    background: var(--color-white);
    width: 100%;
    max-width: 600px;
    box-sizing: border-box;
    border-radius: 20px 20px 0 0; /* Only top rounded */
    box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.15);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transform: translateY(100%); /* Start from bottom */
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.1); /* iOS Spring Animation */
    border: none;
    max-height: min(90vh, 90dvh);
    padding-bottom: env(safe-area-inset-bottom, 0px);
}

/* Sem animação de entrada com transform (fadeInUp quebrava o follow do arraste) */
.modal-dialog.modal-dialog--dragging {
    animation: none !important;
}

[data-theme="dark"] .modal-dialog {
    background: #1C1C1E;
    box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.5);
    border-top: 1px solid rgba(255,255,255,0.1);
}

.modal-overlay.active .modal-dialog {
    transform: translateY(0);
}

/* Comunicado oficial: folha mais larga, corpo maior, corpo do modal rolável */
.modal-overlay:has(#comunicadoForm) .modal-dialog {
    max-width: min(980px, calc(100vw - 1rem));
}

.modal-overlay:has(#comunicadoForm) .modal-body {
    padding: 1.15rem 1.35rem 1.65rem;
    max-height: min(82vh, 82dvh);
}

@media (min-width: 768px) {
    .modal-overlay.active:has(#comunicadoForm) {
        align-items: center;
        padding: 1rem 0 max(1rem, env(safe-area-inset-bottom, 0px));
    }

    .modal-overlay.active:has(#comunicadoForm) .modal-dialog {
        border-radius: 20px;
        box-shadow:
            0 4px 24px rgba(0, 0, 0, 0.06),
            0 16px 48px rgba(0, 0, 0, 0.1);
    }
}

.org-com-modal-form .org-com-rich-editor {
    min-height: 280px;
    max-height: min(58vh, 560px);
    font-size: 1rem;
    line-height: 1.55;
    padding: 1.05rem 1.15rem;
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.05);
}

[data-theme="dark"] .org-com-modal-form .org-com-rich-editor {
    box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.35);
}

.org-com-modal-form .org-com-editor-toolbar {
    padding: 0.5rem 0.6rem;
    gap: 0.3rem;
    margin-bottom: 0.45rem;
}

.org-com-modal-form .org-com-editor-toolbar--docs {
    padding: 0.48rem 0.55rem;
}

.org-com-modal-form .org-com-tb-select {
    height: 38px;
    font-size: 0.8rem;
    max-width: 12rem;
}

.org-com-modal-form .org-com-tb-row {
    gap: 0.28rem;
}

.org-com-modal-form .org-com-tb-btn {
    width: 40px;
    height: 38px;
    border-radius: 10px;
    font-size: 0.88rem;
}

.org-com-modal-form .org-com-tb-btn:active {
    transform: scale(0.96);
}

.org-com-modal-form .org-com-form-actions {
    padding-top: 0.85rem;
    margin-top: 0.35rem;
    border-top: 0.5px solid var(--separator-color);
}

.org-com-modal-form .org-com-capa-input {
    border-radius: 12px;
    padding: 0.55rem;
    border: 0.5px dashed var(--separator-color);
    background: var(--surface-level-1, rgba(0, 0, 0, 0.02));
}

.org-com-modal-form .form-group:has(.org-com-rich-editor) {
    margin-bottom: 0.25rem;
}

/* Leitura do comunicado (ios-com-sheet): modal mais largo */
.modal-overlay:has(.ios-com-sheet) .modal-dialog {
    max-width: min(1100px, calc(100vw - 1.5rem));
}

.modal-overlay:has(.ios-com-sheet) .modal-body {
    padding: 1rem 1.45rem 1.35rem;
    max-height: min(88vh, 88dvh);
}

@media (min-width: 768px) {
    .modal-overlay.active:has(.ios-com-sheet) {
        align-items: center;
        padding: 1rem 0 max(1rem, env(safe-area-inset-bottom, 0px));
    }

    .modal-overlay.active:has(.ios-com-sheet) .modal-dialog {
        border-radius: 20px;
        box-shadow:
            0 4px 24px rgba(0, 0, 0, 0.06),
            0 16px 48px rgba(0, 0, 0, 0.1);
    }
}

/* Confirmação de exclusão — admin do órgão */
.org-admin-delete-modal .org-admin-delete-modal__body {
    padding: 1.25rem 1.5rem 1.5rem;
}

.org-admin-delete-modal__message {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.5;
    color: var(--color-text);
}

.org-admin-delete-modal__actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.35rem;
}

.org-admin-delete-modal__cancel {
    border-radius: 12px;
    padding: 0.55rem 1.1rem;
    font-weight: 600;
    font-size: 0.9rem;
    background: var(--surface-level-2);
    color: var(--color-text);
    border: 0.5px solid var(--separator-color);
}

.org-admin-delete-confirm {
    position: relative;
    overflow: hidden;
    border-radius: 12px;
    padding: 0.55rem 1.15rem;
    font-weight: 600;
    font-size: 0.9rem;
    min-height: 44px;
    border: none;
    background: var(--color-danger, #ff3b30);
    color: #fff;
    z-index: 1;
}

.org-admin-delete-confirm:disabled {
    opacity: 0.95;
    cursor: not-allowed;
}

.org-admin-delete-confirm__progress {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 0;
    border-radius: inherit;
    background-color: rgba(0, 0, 0, 0.12);
    z-index: 0;
    pointer-events: none;
}

.org-admin-delete-confirm__label {
    position: relative;
    z-index: 1;
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem 2rem;
    border-bottom: 0.5px solid var(--separator-color);
    background: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    position: relative;
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
    touch-action: none;
}

.modal-header.modal-header--dragging {
    cursor: grabbing;
}

/* Drag Handle */
.modal-header::before {
    content: '';
    position: absolute;
    top: 8px;
    left: 50%;
    transform: translateX(-50%);
    width: 40px;
    height: 5px;
    background: rgba(0,0,0,0.2);
    border-radius: 10px;
}

[data-theme="dark"] .modal-header::before {
    background: rgba(255,255,255,0.2);
}

[data-theme="dark"] .modal-header {
    background: rgba(30, 30, 30, 0.5);
}

.modal-title {
    margin: 0;
    font-size: 1.25rem;
    color: var(--color-primary);
    font-weight: 700;
}

.modal-close {
    background: var(--surface-soft);
    border: none;
    font-size: 1.2rem;
    color: var(--text-soft);
    cursor: pointer;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    touch-action: manipulation;
    position: relative;
    z-index: 2;
    user-select: none;
}

.modal-close:hover {
    background: rgba(255, 59, 48, 0.1);
    color: var(--color-danger);
}

.modal-body {
    padding: 2rem;
    overflow-y: auto;
}

/* Scrollbar Personalizado para o Modal Body */
.modal-body::-webkit-scrollbar {
    width: 6px;
}
.modal-body::-webkit-scrollbar-track {
    background: transparent;
}
.modal-body::-webkit-scrollbar-thumb {
    background: rgba(10, 48, 85, 0.2);
    border-radius: 4px;
}
.modal-body::-webkit-scrollbar-thumb:hover {
    background: rgba(10, 48, 85, 0.4);
}
[data-theme="dark"] .modal-body::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
}
[data-theme="dark"] .modal-body::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.3);
}

.modal-body form {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

/* Formulários carregados no modal (movimentação, etc.) */
.modal-form-subtitle {
    margin: 0 0 1.25rem 0;
    padding-bottom: 1rem;
    border-bottom: 0.5px solid var(--separator-color);
    font-size: 0.92rem;
    color: var(--text-soft);
    line-height: 1.45;
}

.modal-form-subtitle__label {
    display: block;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-soft);
    margin-bottom: 0.2rem;
}

.modal-form-subtitle__numero {
    font-weight: 600;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
    word-break: break-all;
}

.modal-form-section {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.modal-form-section + .modal-form-section {
    margin-top: 0.25rem;
    padding-top: 1.25rem;
    border-top: 0.5px solid var(--separator-color);
}

.modal-form-section__title {
    margin: 0;
    font-size: 0.95rem;
    font-weight: 650;
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.form-actions,
.modal-form-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
    justify-content: flex-end;
}

.modal-form-actions {
    margin-top: 0.25rem !important;
    padding-top: 1.25rem;
    border-top: 0.5px solid var(--separator-color);
}

.modal-form-btn-cancel {
    background: transparent !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--color-text) !important;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.form-field-error {
    font-size: 0.82rem;
    color: var(--color-danger);
    margin-top: 0.35rem;
}

/* Área de arquivo — estilo iOS + arrastar e soltar (movimentação) */
.ios-dropzone-group .ios-field-hint {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin: 0.35rem 0 0.65rem;
    line-height: 1.35;
}

.ios-dropzone-field-label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.4rem;
}

/* Lista de anexos — nome editável e remover (movimentação) */
.ios-attachments-root {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.ios-attachments-root .ios-field-hint {
    font-size: 0.78rem;
    color: var(--text-muted);
    margin: 0;
    line-height: 1.35;
}

.ios-attachments-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.ios-attachment-row {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    padding: 0.65rem 0.75rem;
    border-radius: 14px;
    border: 1px solid var(--glass-border);
    background: rgba(255, 255, 255, 0.05);
}

[data-theme="dark"] .ios-attachment-row {
    background: rgba(255, 255, 255, 0.06);
}

.ios-attachment-row__ico {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    background: rgba(0, 122, 255, 0.1);
    color: var(--ios-blue, #007aff);
    font-size: 1.1rem;
}

.ios-attachment-row__meta {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.ios-attachment-row__name {
    font-size: 0.9rem;
    min-height: 40px;
    padding: 0.45rem 0.65rem;
    border-radius: 10px;
}

.ios-attachment-row__sub {
    font-size: 0.75rem;
    color: var(--text-muted);
    word-break: break-word;
    line-height: 1.3;
}

.ios-attachment-row__remove {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 10px;
    background: rgba(255, 59, 48, 0.12);
    color: var(--color-danger, #ff3b30);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
}

.ios-attachment-row__remove:hover {
    background: rgba(255, 59, 48, 0.2);
}

.ios-file-dropzone {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    gap: 0.35rem;
    min-height: 140px;
    padding: 1.25rem 1rem;
    border-radius: 16px;
    border: 1.5px dashed rgba(0, 0, 0, 0.14);
    background: rgba(255, 255, 255, 0.06);
    transition: border-color 0.2s ease, background 0.2s ease, transform 0.15s ease;
    cursor: pointer;
}

[data-theme="dark"] .ios-file-dropzone {
    border-color: rgba(255, 255, 255, 0.18);
    background: rgba(255, 255, 255, 0.04);
}

.ios-file-dropzone:hover {
    border-color: var(--ios-blue, #007aff);
    background: rgba(0, 122, 255, 0.06);
}

.ios-file-dropzone--dragover {
    border-color: var(--ios-blue, #007aff);
    border-style: solid;
    background: rgba(0, 122, 255, 0.1);
    transform: scale(1.01);
}

.ios-file-dropzone--has-file {
    border-style: solid;
    border-color: rgba(52, 199, 89, 0.45);
    background: rgba(52, 199, 89, 0.06);
}

.ios-file-dropzone__icon {
    font-size: 2rem;
    line-height: 1;
    opacity: 0.85;
}

.ios-file-dropzone__title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
}

.ios-file-dropzone__sub {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin: 0;
    max-width: 100%;
}

.ios-file-dropzone__hint {
    font-size: 0.8rem;
    color: var(--text-muted);
    margin: 0;
    max-width: 100%;
}

.ios-file-dropzone__name {
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--ios-blue, #007aff);
    margin: 0.25rem 0 0;
    max-width: 100%;
    word-break: break-word;
}

.ios-file-dropzone__filename {
    text-align: center;
    line-height: 1.35;
    max-height: 4.2rem;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
}

.ios-file-input-native {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    font-size: 0;
}

/* Modal visualizador PDF (estilo iOS) */
.pdf-viewer-modal {
    position: fixed;
    inset: 0;
    z-index: 11000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: max(1rem, env(safe-area-inset-top)) max(1rem, env(safe-area-inset-right)) max(1rem, env(safe-area-inset-bottom)) max(1rem, env(safe-area-inset-left));
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.25s ease, visibility 0.25s ease;
}

.pdf-viewer-modal.active {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.pdf-viewer-modal__dialog {
    display: flex;
    flex-direction: column;
    width: min(92vw, 900px);
    height: min(88vh, 820px);
    max-height: calc(100vh - 2rem);
    border-radius: 20px;
    overflow: hidden;
    background: var(--glass-bg-elevated, rgba(255, 255, 255, 0.95));
    border: 1px solid var(--glass-border);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
}

[data-theme="dark"] .pdf-viewer-modal__dialog {
    background: rgba(44, 44, 46, 0.96);
}

/* Folha central — sobrescreve bottom sheet do .modal-overlay global */
.pdf-viewer-modal.modal-overlay {
    align-items: center;
    justify-content: center;
}

.pdf-viewer-modal.modal-overlay .modal-dialog.pdf-viewer-modal__dialog {
    width: min(92vw, 900px);
    max-width: min(92vw, 900px);
    height: min(88vh, 820px);
    max-height: calc(100vh - 2rem);
    border-radius: 20px;
    border-top: none;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
    transform: translateY(20px) scale(0.97);
    opacity: 0;
    transition:
        transform 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        opacity 0.28s ease;
}

.pdf-viewer-modal.modal-overlay.active .modal-dialog.pdf-viewer-modal__dialog {
    transform: translateY(0) scale(1);
    opacity: 1;
}

.pdf-viewer-modal .modal-header {
    cursor: default;
    touch-action: auto;
    user-select: text;
    -webkit-user-select: text;
    padding: 0.75rem 1rem 0.7rem;
}

.pdf-viewer-modal .modal-header::before {
    display: none;
}

.pdf-viewer-modal__header {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.65rem 1rem;
    border-bottom: 1px solid var(--glass-border);
    background: rgba(0, 0, 0, 0.03);
}

[data-theme="dark"] .pdf-viewer-modal__header {
    background: rgba(255, 255, 255, 0.04);
}

.pdf-viewer-modal__title {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text);
    margin: 0;
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.pdf-viewer-modal__close {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.06);
    color: var(--color-text);
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
}

.pdf-viewer-modal__close:hover {
    background: rgba(0, 0, 0, 0.1);
}

[data-theme="dark"] .pdf-viewer-modal__close {
    background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .pdf-viewer-modal__close:hover {
    background: rgba(255, 255, 255, 0.16);
}

.pdf-viewer-modal__body {
    flex: 1;
    min-height: 0;
    padding: 0;
    background: rgba(0, 0, 0, 0.04);
    display: flex;
    flex-direction: column;
}

[data-theme="dark"] .pdf-viewer-modal__body {
    background: #1c1c1e;
}

.pdf-viewer-modal__frame,
.pdf-viewer-modal__iframe {
    width: 100%;
    flex: 1 1 auto;
    min-height: 0;
    border: none;
    display: block;
}

/* Data/hora pt-BR: campo + botão calendário (Flatpickr) */
.datetime-br-row {
    display: flex;
    align-items: stretch;
    gap: 0.5rem;
    width: 100%;
}

.datetime-br-row .form-control {
    flex: 1;
    min-width: 0;
}

.datetime-br-calendar-btn {
    flex-shrink: 0;
    width: 48px;
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: var(--surface-level-2);
    color: var(--color-text);
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
    font-size: 1.05rem;
}

.datetime-br-calendar-btn:hover {
    background: var(--surface-soft);
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.flatpickr-calendar {
    z-index: 10050 !important;
}

html[data-theme="dark"] .flatpickr-calendar {
    background: #2c2c2e;
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: #f2f2f7;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.5);
}

html[data-theme="dark"] .flatpickr-months .flatpickr-month {
    color: #f2f2f7;
}

html[data-theme="dark"] .flatpickr-current-month .flatpickr-monthDropdown-months,
html[data-theme="dark"] .flatpickr-current-month .numInputWrapper .numInput {
    color: #f2f2f7;
}

html[data-theme="dark"] .flatpickr-weekday {
    color: rgba(255, 255, 255, 0.55);
}

html[data-theme="dark"] .flatpickr-day {
    color: #e8e8ed;
}

html[data-theme="dark"] .flatpickr-day:hover {
    background: rgba(255, 255, 255, 0.08);
    border-color: transparent;
}

html[data-theme="dark"] .flatpickr-day.selected {
    background: var(--color-primary);
    border-color: var(--color-primary);
    color: #fff;
}

html[data-theme="dark"] .flatpickr-time input {
    color: #f2f2f7;
    background: transparent;
}

/* Pesquisa destinatário (notificação / demanda) no modal de ato */
.alvo-search-wrap {
    position: relative;
    width: 100%;
}

.alvo-search-results {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 4px);
    z-index: 12000;
    max-height: 240px;
    overflow-y: auto;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: var(--color-white);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
}

html[data-theme="dark"] .alvo-search-results {
    background: #2c2c2e;
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
}

.alvo-search-item {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.15rem;
    width: 100%;
    padding: 0.65rem 0.9rem;
    margin: 0;
    border: none;
    border-bottom: 0.5px solid var(--separator-color);
    background: transparent;
    color: var(--color-text);
    text-align: left;
    cursor: pointer;
    font: inherit;
    transition: background 0.15s ease;
}

.alvo-search-item:last-child {
    border-bottom: none;
}

.alvo-search-item:hover {
    background: var(--surface-level-2);
}

.alvo-search-item__label {
    font-weight: 600;
    font-size: 0.9rem;
}

.alvo-search-item__sub {
    font-size: 0.78rem;
    color: var(--text-soft);
}

.alvo-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    margin-top: 0.55rem;
}

.alvo-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.25rem 0.5rem 0.25rem 0.65rem;
    border-radius: 999px;
    background: var(--surface-level-2);
    border: 1px solid var(--glass-border);
    font-size: 0.82rem;
    max-width: 100%;
}

.alvo-chip__label {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 220px;
}

.alvo-chip__rm {
    border: none;
    background: transparent;
    color: var(--text-soft);
    cursor: pointer;
    font-size: 1.1rem;
    line-height: 1;
    padding: 0 0.15rem;
    border-radius: 4px;
}

.alvo-chip__rm:hover {
    color: var(--color-danger);
    background: rgba(220, 53, 69, 0.08);
}

.proc-toast-notice {
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    z-index: 200000;
    padding: 0.75rem 1.25rem;
    border-radius: 12px;
    background: rgba(30, 30, 32, 0.92);
    color: #fff;
    font-size: 0.9rem;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
    opacity: 0;
    transition: opacity 0.25s ease, transform 0.25s ease;
    max-width: min(420px, calc(100vw - 2rem));
    pointer-events: none;
}

.proc-toast-notice--show {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* Modal Dark Mode Adjustments */
[data-theme="dark"] .modal-overlay {
    background: rgba(0, 0, 0, 0.7);
}

[data-theme="dark"] .modal-dialog {
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.user-confirm-card {
    background: #f0f6ff;
    border: 1px solid #d0e1f9;
    border-radius: 12px;
    padding: 1.5rem;
    width: 100%;
    margin-bottom: 1.5rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.user-confirm-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 20px rgba(21, 101, 192, 0.1);
}

.user-confirm-card img {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 3px solid #1565c0;
    margin-bottom: 1rem;
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.user-confirm-card:hover img {
    transform: scale(1.1) rotate(5deg);
}

.user-confirm-card .display-name {
    color: #0a3055;
    font-weight: bold;
    font-size: 1.2rem;
    margin-bottom: 0.2rem;
}

.user-confirm-card .username {
    color: #666;
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
}

.user-confirm-card .user-id {
    color: #888;
    font-size: 0.8rem;
    font-family: monospace;
}

.user-card-horizontal {
    background: #d0e1f9;
    border-radius: 12px;
    padding: 1rem;
    width: 100%;
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
    transition: transform 0.3s ease;
}

.user-card-horizontal:hover {
    transform: translateX(5px);
}

.user-card-horizontal img {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: 2px solid #1565c0;
    transition: transform 0.3s ease;
}

.user-card-horizontal:hover img {
    transform: scale(1.1);
}

.user-card-horizontal div {
    text-align: left;
}

/* Code Verification Box */
.code-box {
    background: #1565c0;
    border-radius: 12px;
    padding: 1.5rem;
    width: 100%;
    color: white;
    margin-bottom: 1.5rem;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.code-box:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(21, 101, 192, 0.4);
}

.code-display {
    background: #4a8ddb;
    font-size: 2rem;
    font-family: monospace;
    letter-spacing: 5px;
    padding: 1rem;
    border-radius: 12px;
    margin: 1rem 0;
    position: relative;
    overflow: hidden;
    cursor: pointer;
    transition: background 0.3s ease, transform 0.1s ease;
}

.code-display:hover {
    background: #5c9ce6;
}

.code-display:active {
    transform: scale(0.98);
}

.btn-outline-white {
    background: transparent;
    color: white;
    border: 1px solid white;
    border-radius: 12px;
    padding: 0.6rem 1rem;
    cursor: pointer;
    font-size: 0.9rem;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.btn-outline-white:hover {
    background: rgba(255,255,255,0.15);
    transform: translateY(-2px);
    box-shadow: 0 4px 10px rgba(255,255,255,0.2);
}

.btn-outline-white:active {
    transform: scale(0.95);
}

.timer-box {
    background: #d32f2f;
    color: white;
    border-radius: 12px;
    padding: 0.8rem;
    width: 100%;
    font-weight: bold;
    margin-bottom: 1rem;
    animation: pulse 2s infinite;
}

.btn-outline-blue {
    background: transparent;
    color: #1565c0;
    border: 2px solid #1565c0;
    border-radius: 12px;
    padding: 0.8rem;
    font-weight: bold;
    width: 100%;
    cursor: pointer;
    margin-bottom: 1rem;
    display: block;
    text-decoration: none;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.btn-outline-blue:hover {
    background: #1565c0;
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(21, 101, 192, 0.3);
}

.btn-outline-blue:active {
    transform: scale(0.98);
}

/* =========================
   Dashboard V2 + Theme
========================= */

:root {
    --bg-gradient-a: rgba(22, 74, 132, 0.2);
    --bg-gradient-b: rgba(212, 175, 55, 0.18);
    --surface-soft: rgba(255, 255, 255, 0.55);
    --text-soft: #6a7587;
}

html[data-theme="dark"] {
    --color-primary: #7ab1ff;
    --color-secondary: #3f8cff;
    --color-accent: #f0c35c;
    --color-success: #46d08b;
    --color-bg: #0b1220;
    --color-text: #e4ecff;
    --color-white: #f6f8ff;
    --glass-bg: rgba(15, 24, 40, 0.68);
    --glass-border: rgba(120, 170, 255, 0.18);
    --glass-shadow: 0 12px 32px rgba(0, 0, 0, 0.45);
    --bg-gradient-a: rgba(83, 136, 255, 0.3);
    --bg-gradient-b: rgba(40, 232, 184, 0.24);
    --surface-soft: rgba(74, 113, 184, 0.16);
    --text-soft: #9cb0d2;
}

body {
    position: relative;
    overflow-x: clip;
    transition: background-color 0.35s ease, color 0.35s ease;
}

.bg-decor {
    position: fixed;
    z-index: -1;
    border-radius: 50%;
    filter: blur(70px);
    pointer-events: none;
}

.bg-decor-1 {
    width: 380px;
    height: 380px;
    top: -100px;
    right: -80px;
    background: var(--bg-gradient-a);
    animation: blobFloat 12s ease-in-out infinite alternate;
}

.bg-decor-2 {
    width: 420px;
    height: 420px;
    bottom: -130px;
    left: -100px;
    background: var(--bg-gradient-b);
    animation: blobFloat 14s ease-in-out infinite alternate-reverse;
}

@keyframes blobFloat {
    from {
        transform: translate(0, 0) scale(1);
    }
    to {
        transform: translate(25px, -20px) scale(1.08);
    }
}

.navbar {
    margin: 0.75rem;
    border-radius: 18px;
    animation: fadeInUp 0.35s ease-out;
}

.theme-toggle {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    border: 1px solid var(--glass-border);
    background: var(--surface-soft);
    color: var(--color-primary);
    cursor: pointer;
    transition: all 0.25s ease;
}

.theme-toggle:hover {
    transform: translateY(-2px) rotate(8deg);
    box-shadow: 0 6px 18px rgba(34, 91, 175, 0.22);
}

.profile-menu-wrapper {
    position: relative;
}

.profile-menu-trigger {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.4rem 0.65rem;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: var(--surface-soft);
    color: var(--color-text);
    cursor: pointer;
    transition: all 0.25s ease;
}

.profile-menu-trigger:hover {
    transform: translateY(-2px);
}

.avatar-fallback {
    background: rgba(130, 140, 160, 0.28);
    display: flex;
    align-items: center;
    justify-content: center;
}

.nav-user-info {
    display: flex;
    flex-direction: column;
    text-align: left;
    line-height: 1.05;
    font-weight: 700;
    font-size: 0.92rem;
}

.nav-user-info small {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-soft);
}

.menu-chevron {
    font-size: 0.8rem;
    color: var(--text-soft);
    transition: transform 0.25s ease;
}

.profile-menu-wrapper.open .menu-chevron {
    transform: rotate(180deg);
}

.profile-dropdown {
    position: absolute;
    right: 0;
    top: calc(100% + 10px);
    min-width: 190px;
    padding: 0.4rem;
    border: 1px solid var(--glass-border);
    border-radius: 16px;
    background: var(--glass-bg);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    box-shadow: var(--glass-shadow);
    opacity: 0;
    transform: scale(0.8);
    transform-origin: top right;
    pointer-events: none;
    transition: all 0.2s cubic-bezier(0.25, 1.5, 0.5, 1); /* iOS Spring Bounce */
    z-index: 1100;
}

.profile-menu-wrapper.open .profile-dropdown {
    opacity: 1;
    transform: scale(1);
    pointer-events: auto;
}

.dropdown-item {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    text-decoration: none;
    color: var(--color-text);
    padding: 0.65rem 0.7rem;
    border-radius: 9px;
    transition: all 0.2s ease;
}

.dropdown-item:hover {
    background: rgba(91, 140, 230, 0.15);
    color: var(--color-primary);
}

.dropdown-item.danger:hover {
    background: rgba(233, 61, 61, 0.18);
    color: #e34242;
}

.dashboard-header {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 1.2rem 1.4rem;
    margin-bottom: 1.5rem;
}

.dashboard-subtitle {
    color: var(--text-soft);
    margin-top: -0.8rem;
}

.page-header .dashboard-subtitle {
    margin-top: 0.35rem;
}

.dashboard-pill-group {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
}

.dashboard-pill {
    border: 1px solid var(--glass-border);
    background: var(--surface-soft);
    color: var(--color-primary);
    border-radius: 999px;
    padding: 0.45rem 0.8rem;
    font-size: 0.78rem;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.float-card {
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.1), box-shadow 0.4s ease;
    animation: fadeInUp 0.4s ease;
}

.float-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.04);
}

.widget-description {
    color: var(--text-soft);
    font-size: 0.9rem;
}

.widget-empty {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-soft);
}

.process-table-panel {
    margin-top: 2rem;
    padding: 1.5rem;
    border-radius: 16px;
    overflow-x: auto;
    max-width: 100%;
    min-width: 0;
    -webkit-overflow-scrolling: touch;
}

.process-table-title {
    color: var(--color-primary);
    margin-bottom: 1rem;
}

.process-table {
    width: 100%;
    border-collapse: collapse;
}

.process-table th {
    padding: 1rem 0.5rem;
    color: var(--text-soft);
    text-align: left;
    border-bottom: 0.5px solid var(--separator-color);
}

.process-table td {
    padding: 0.9rem 0.5rem;
    border-bottom: 0.5px solid var(--separator-color);
}

.process-number a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 700;
}

.status-chip {
    background: rgba(56, 119, 226, 0.12);
    color: var(--color-primary);
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.8rem;
    font-weight: 700;
    border: 1px solid rgba(56, 119, 226, 0.28);
}

.process-action-btn {
    background: var(--surface-soft);
    color: var(--color-primary);
    padding: 0.4rem 0.8rem;
    font-size: 0.8rem;
    border: 1px solid var(--glass-border);
}

.process-action-btn:hover {
    transform: translateY(-2px);
}

.empty-row {
    padding: 2rem;
    text-align: center;
    color: var(--text-soft);
}

/* Perfil */
.profile-page-wrap {
    max-width: 900px;
    margin: 0 auto;
}

.profile-card {
    padding: 1.8rem;
    animation: fadeInUp 0.4s ease;
}

.profile-top {
    display: flex;
    gap: 1.2rem;
    align-items: center;
    margin-bottom: 1.3rem;
}

.profile-avatar {
    width: 82px;
    height: 82px;
    border-radius: 50%;
    border: 3px solid var(--color-accent);
}

.profile-title {
    margin-bottom: 0.2rem;
}

.profile-meta {
    color: var(--text-soft);
    font-size: 1.05rem;
    font-weight: 600;
}

/* Identidade digital (RG) — cartão estilo carteira BR + slots de logo */
.rg-digital-section {
    margin-bottom: 1.5rem;
    padding: 1.25rem 1.35rem;
    border-radius: 16px;
    border: 1px solid var(--glass-border);
}

.rg-digital-section__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.rg-digital-section__title {
    margin: 0;
    font-size: 1.02rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.rg-digital-card {
    --rg-green: #125432;
    --rg-green-dark: #0e3f28;
    --rg-cream: #f5faf6;
    background: var(--rg-cream);
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(18, 84, 50, 0.25);
    max-width: 100%;
}

html[data-theme="dark"] .rg-digital-card {
    --rg-cream: #1a221e;
    border-color: rgba(120, 200, 150, 0.2);
}

.rg-digital-card__header {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 0.65rem;
    align-items: center;
    padding: 0.65rem 0.85rem;
    background: linear-gradient(180deg, var(--rg-green-dark), var(--rg-green));
    color: #f4fbf7;
}

.rg-digital-card__logo-slot {
    min-width: 56px;
    min-height: 56px;
    border-radius: 10px;
    border: 2px dashed rgba(255, 255, 255, 0.35);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    opacity: 0.85;
}

.rg-digital-card__logo-slot--brasao {
    min-width: 72px;
    min-height: 72px;
}

.rg-digital-card__logo-hint {
    padding: 0.25rem;
    text-align: center;
    line-height: 1.2;
}

.rg-digital-card__logo-img {
    width: 52px;
    height: 52px;
    object-fit: contain;
    display: block;
    border-radius: 6px;
}

.rg-digital-card__logo-img--brasao {
    width: 68px;
    height: 68px;
}

.rg-digital-card__titles {
    text-align: center;
    min-width: 0;
}

.rg-digital-card__rep {
    margin: 0;
    font-weight: 800;
    font-size: 0.72rem;
    letter-spacing: 0.02em;
}

.rg-digital-card__gov {
    margin: 0.05rem 0 0;
    font-size: 0.68rem;
    opacity: 0.95;
}

.rg-digital-card__doc-title {
    margin: 0.35rem 0 0;
    font-weight: 800;
    font-size: 0.78rem;
    letter-spacing: 0.02em;
}

.rg-digital-card__main {
    display: grid;
    grid-template-columns: 150px 1fr minmax(100px, 120px);
    gap: 1rem;
    padding: 1rem 1rem 0.85rem;
    align-items: start;
}

@media (max-width: 768px) {
    .rg-digital-card__main {
        grid-template-columns: 1fr;
    }
    .rg-digital-card__side {
        justify-self: center;
        text-align: center;
    }
}

.rg-digital-card__photo {
    width: 150px;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid rgba(18, 84, 50, 0.35);
    background: #fff;
    aspect-ratio: 3 / 3.8;
    display: flex;
    align-items: center;
    justify-content: center;
}

.rg-digital-card__photo-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.rg-digital-card__photo-fallback {
    color: var(--text-soft);
    font-size: 2.5rem;
}

.rg-digital-card__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.65rem 1rem;
}

.rg-digital-card__field--full {
    grid-column: 1 / -1;
}

.rg-digital-card__label {
    display: block;
    font-size: 0.62rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #5a655f;
    margin-bottom: 0.12rem;
}

html[data-theme="dark"] .rg-digital-card__label {
    color: var(--text-soft);
}

.rg-digital-card__hint {
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
}

.rg-digital-card__value {
    display: block;
    font-size: 0.88rem;
    font-weight: 600;
    color: #0f1f17;
    line-height: 1.3;
}

html[data-theme="dark"] .rg-digital-card__value {
    color: var(--color-text);
}

.rg-digital-card__value--cpf {
    font-size: 1.05rem;
    font-weight: 800;
    letter-spacing: 0.02em;
}

.rg-digital-card__side {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
}

.rg-digital-card__qr {
    border-radius: 8px;
    border: 1px solid rgba(18, 84, 50, 0.2);
}

.rg-digital-card__qr-caption {
    margin: 0;
    font-size: 0.62rem;
    color: var(--text-soft);
    text-align: center;
    line-height: 1.35;
    max-width: 140px;
    word-break: break-word;
}

.rg-digital-card__qr-link {
    color: var(--color-primary);
    font-weight: 600;
}

.rg-digital-card__footer {
    padding: 0 1rem 1rem;
}

.rg-digital-card__sig {
    max-width: 320px;
}

.rg-digital-card__sig-img {
    max-height: 56px;
    width: auto;
    display: block;
    object-fit: contain;
}

.rg-digital-card__sig-line {
    height: 1px;
    background: rgba(18, 84, 50, 0.45);
    margin-top: 0.25rem;
}

.rg-digital-card__sig-label {
    margin: 0.35rem 0 0;
    font-size: 0.62rem;
    color: #5a655f;
    text-align: left;
}

html[data-theme="dark"] .rg-digital-card__sig-label {
    color: var(--text-soft);
}

.identidade-cadastro-page .identidade-cadastro-wrap {
    max-width: 560px;
    margin: 1.5rem auto;
    padding: 2rem 1.75rem;
    border-radius: 18px;
    border: 1px solid var(--glass-border);
}

.identidade-cadastro__icon {
    font-size: 2.25rem;
    color: var(--color-primary);
    margin-bottom: 0.75rem;
}

.identidade-cadastro__title {
    margin: 0 0 0.75rem;
    font-size: 1.45rem;
    font-weight: 800;
}

.identidade-cadastro__lead {
    margin: 0 0 1.5rem;
    font-size: 0.92rem;
    line-height: 1.55;
    color: var(--text-soft);
}

.identidade-cadastro__form .profile-field {
    margin-bottom: 1rem;
}

.identidade-cadastro__form .profile-field label {
    display: block;
    font-weight: 650;
    font-size: 0.82rem;
    margin-bottom: 0.35rem;
}

.identidade-cadastro__actions {
    margin-top: 1.5rem;
}

.identidade-cadastro__logout-hint {
    margin: 1.25rem 0 0;
    font-size: 0.82rem;
    text-align: center;
    color: var(--text-soft);
}

.identidade-cadastro__logout-hint a {
    color: var(--color-primary);
    font-weight: 600;
}

/* Verificação de identidade (QR) — iosdesign.md: fundo sistema, card branco, squircle, sombra suave */
.verificar-identidade-page .verificar-identidade-main {
    flex: 1;
    min-width: 0;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 2rem 1.25rem 3rem;
    background: #f2f2f7;
}

html[data-theme="dark"] .verificar-identidade-page .verificar-identidade-main {
    background: var(--bg-app, #000);
}

.verificar-identidade-stack {
    width: 100%;
    max-width: 480px;
    display: flex;
    flex-direction: column;
    gap: 1.35rem;
}

.verificar-identidade-hero {
    text-align: left;
    padding: 0 0.15rem;
}

.verificar-identidade-hero__icon-wrap {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: rgba(52, 199, 89, 0.14);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1rem;
    box-shadow: 0 2px 12px rgba(52, 199, 89, 0.12);
}

html[data-theme="dark"] .verificar-identidade-hero__icon-wrap {
    background: rgba(52, 199, 89, 0.18);
    box-shadow: none;
}

.verificar-identidade-hero__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    font-size: 1.05rem;
    color: #34c759;
}

.verificar-identidade-hero__title {
    margin: 0;
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.15;
    color: var(--color-text);
    font-family: inherit;
}

.verificar-identidade-hero__sub {
    margin: 0.55rem 0 0;
    font-size: 0.95rem;
    line-height: 1.45;
    color: var(--text-soft);
    font-weight: 400;
    max-width: 42rem;
}

.verificar-identidade-inset {
    margin: 0;
}

.verificar-identidade-inset__group {
    background: #ffffff;
    border-radius: 20px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.045);
    border: 0.5px solid rgba(0, 0, 0, 0.06);
    overflow: hidden;
}

html[data-theme="dark"] .verificar-identidade-inset__group {
    background: rgba(44, 44, 46, 0.92);
    border-color: var(--glass-border);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.verificar-identidade-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem 1.25rem;
    padding: 0.85rem 1.1rem;
    border-bottom: 0.5px solid var(--separator-color);
}

.verificar-identidade-row--last {
    border-bottom: none;
}

.verificar-identidade-row__label {
    flex: 0 0 42%;
    max-width: 12.5rem;
    font-size: 0.67rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.055em;
    color: var(--text-soft);
    line-height: 1.35;
    padding-top: 0.2rem;
}

.verificar-identidade-row__value {
    flex: 1;
    min-width: 0;
    text-align: right;
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.35;
    word-break: break-word;
}

.verificar-identidade-row__value--mono {
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}

button.verificar-identidade-roblox-link {
    display: inline;
    margin: 0;
    padding: 0;
    border: none;
    background: none;
    font: inherit;
    font-weight: 600;
    font-size: 1rem;
    color: #007aff;
    cursor: pointer;
    text-decoration: none;
    border-radius: 6px;
    text-align: right;
}

button.verificar-identidade-roblox-link:hover {
    text-decoration: underline;
}

button.verificar-identidade-roblox-link:focus-visible {
    outline: 2px solid #007aff;
    outline-offset: 2px;
}

html[data-theme="dark"] button.verificar-identidade-roblox-link {
    color: #0a84ff;
}

html[data-theme="dark"] button.verificar-identidade-roblox-link:focus-visible {
    outline-color: #0a84ff;
}

.verificar-identidade-hero--fail .verificar-identidade-hero__title {
    font-size: 1.5rem;
}

.verificar-identidade-hero__icon-wrap--fail {
    background: rgba(255, 149, 0, 0.16);
    box-shadow: 0 2px 12px rgba(255, 149, 0, 0.1);
}

html[data-theme="dark"] .verificar-identidade-hero__icon-wrap--fail {
    background: rgba(255, 159, 10, 0.22);
}

.verificar-identidade-hero__icon--fail {
    color: #ff9500;
    font-size: 1.15rem;
}

.verificar-identidade-stack--fail .verificar-identidade-hero__sub {
    margin-top: 0.65rem;
}

.profile-institution {
    margin-bottom: 1.35rem;
    padding: 1.15rem 1.25rem;
    border-radius: 14px;
    border: 1px solid var(--glass-border);
}

.profile-institution__title {
    margin: 0 0 0.85rem;
    font-size: 1rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text);
}

.profile-institution__title i {
    color: var(--color-primary);
    opacity: 0.9;
}

.profile-institution__dl {
    margin: 0;
}

.profile-institution__row {
    display: grid;
    grid-template-columns: minmax(120px, 160px) 1fr;
    gap: 0.5rem 1rem;
    padding: 0.55rem 0;
    border-top: 0.5px solid var(--separator-color);
    font-size: 0.92rem;
}

.profile-institution__row:first-of-type {
    border-top: none;
    padding-top: 0;
}

.profile-institution__row dt {
    margin: 0;
    font-weight: 650;
    color: var(--text-soft);
    text-transform: uppercase;
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    align-self: start;
    padding-top: 0.2rem;
}

.profile-institution__row dd {
    margin: 0;
    color: var(--color-text);
    line-height: 1.45;
}

.profile-institution__sigla {
    margin-left: 0.35rem;
    color: var(--text-soft);
    font-weight: 600;
}

.profile-institution__tipo {
    display: inline-block;
    margin-left: 0.5rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-soft);
    background: var(--surface-level-2);
    padding: 0.15rem 0.45rem;
    border-radius: 6px;
}

.profile-institution__dash-link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    margin-left: 0.65rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-primary, #007aff);
    text-decoration: none;
}

.profile-institution__dash-link:hover {
    text-decoration: underline;
}

.profile-institution__hint {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.8rem;
    color: var(--text-soft);
}

.profile-institution__empty {
    color: var(--text-soft);
    font-style: italic;
}

.profile-institution__row--note dd {
    font-size: 0.85rem;
}

.profile-pill {
    display: inline-block;
    margin-left: 0.4rem;
    padding: 0.15rem 0.5rem;
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    vertical-align: middle;
}

.profile-pill--admin {
    background: rgba(175, 82, 222, 0.18);
    color: #af52de;
}

[data-theme="dark"] .profile-pill--admin {
    background: rgba(191, 90, 242, 0.22);
    color: #bf5af2;
}

.profile-pill--resp {
    background: rgba(0, 122, 255, 0.14);
    color: #007aff;
}

[data-theme="dark"] .profile-pill--resp {
    background: rgba(10, 132, 255, 0.22);
    color: #64b5ff;
}

.profile-perms {
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 0.5px solid var(--separator-color);
}

.profile-perms__title {
    margin: 0 0 0.45rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-soft);
}

.profile-perms__list {
    margin: 0;
    padding-left: 1.15rem;
    color: var(--color-text);
    font-size: 0.88rem;
    line-height: 1.55;
}

@media (max-width: 560px) {
    .profile-institution__row {
        grid-template-columns: 1fr;
    }
}

.profile-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
}

.profile-field {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.profile-field label {
    color: var(--color-primary);
    font-weight: 700;
}

.profile-field input {
    border: 1px solid var(--glass-border);
    border-radius: 10px;
    padding: 0.72rem 0.85rem;
    background: var(--surface-soft);
    color: var(--color-text);
}

.profile-field input:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(70, 130, 255, 0.18);
}

.profile-field small {
    color: var(--text-soft);
}

.profile-field-readonly input {
    opacity: 0.9;
    cursor: not-allowed;
}

.profile-actions {
    display: flex;
    gap: 0.6rem;
    margin-top: 0.4rem;
}

.profile-cancel-btn {
    background: var(--surface-soft);
    color: var(--color-text);
    border: 1px solid var(--glass-border);
}

/* Centralized Search Section */
.search-section {
    text-align: center;
    padding: 3rem 2rem;
    margin-bottom: 2rem;
    border-radius: 16px;
    animation: fadeInUp 0.3s ease-out;
}

.search-section h2 {
    font-size: 2.2rem;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
    font-weight: 700;
}

.search-section p {
    color: var(--text-soft);
    margin-bottom: 2rem;
    font-size: 1.1rem;
}

.search-box {
    display: flex;
    align-items: center;
    max-width: 400px;
    gap: 0;
    border-radius: 999px; /* Pill shape for iOS */
    overflow: hidden;
    background: #E3E3E9;
    box-shadow: none; /* No shadow on search pill */
    padding: 0 1rem;
}

html[data-theme="dark"] .search-box {
    background: #2C2C2E; /* iOS dark mode search bar color */
    box-shadow: none;
}

.search-icon-left {
    color: #8E8E93;
    font-size: 1.1rem;
}

.search-input {
    flex: 1;
    padding: 0.8rem 0.5rem;
    border: none;
    font-size: 1rem;
    background: transparent;
    color: var(--color-text);
    outline: none;
    transition: all 0.2s ease;
}

.search-input:focus {
    background: transparent;
}

html[data-theme="dark"] .search-input:focus {
    background: transparent;
}

.search-btn {
    border-radius: 0 999px 999px 0;
    padding: 1.2rem 2rem;
    font-size: 1.1rem;
    font-weight: bold;
    text-transform: uppercase;
    box-shadow: none;
    background: transparent;
    color: var(--color-primary);
}
.search-btn:hover {
    background: rgba(0, 122, 255, 0.1);
    transform: none;
    box-shadow: none;
}

/* Animations for Dashboard Elements */
.anim-fade-in {
    opacity: 0;
    animation: fadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

.stagger-1 { animation-delay: 0.1s; }
.stagger-2 { animation-delay: 0.2s; }
.stagger-3 { animation-delay: 0.3s; }
.stagger-4 { animation-delay: 0.4s; }
.stagger-5 { animation-delay: 0.5s; }

.anim-hover-scale {
    transition: transform 0.3s cubic-bezier(0.25, 0.8, 0.25, 1), box-shadow 0.3s ease;
}

.anim-hover-scale:hover {
    transform: translateY(-4px) scale(1.01);
    box-shadow: 0 12px 28px rgba(0,0,0,0.12);
}

html[data-theme="dark"] .anim-hover-scale:hover {
    box-shadow: 0 12px 28px rgba(0,0,0,0.4);
}

@media (min-width: 921px) {
    .nav-sidebar-toggle {
        display: none !important;
    }
}

@media (max-width: 920px) {
    .nav-sidebar-toggle:not([hidden]) {
        display: inline-flex;
    }

    .navbar {
        margin: 0.5rem;
        padding: 0.75rem 1rem 0.32rem;
        flex-wrap: wrap;
        gap: 0.5rem;
        min-width: 0;
        align-items: center;
    }

    .nav-brand {
        font-size: 1.15rem;
        min-width: 0;
        flex: 1 1 auto;
        gap: 0.5rem;
    }

    .nav-brasilia-clock {
        font-size: 0.6rem;
    }

    .nav-brand .brand-logo-img--navbar {
        height: 48px;
        max-width: min(320px, 68vw);
    }

    .nav-user {
        flex: 0 1 auto;
        min-width: 0;
        max-width: 100%;
        justify-content: flex-end;
        gap: 0.45rem;
        flex-wrap: nowrap;
    }

    .notification-wrapper {
        flex: 0 0 auto;
    }

    .notification-bell {
        flex-shrink: 0;
        padding: 0.4rem !important;
        font-size: 1.15rem !important;
    }

    /*
     * Popover absoluto com largura ~viewport cortava à esquerda (overflow-x: clip no body)
     * e ficava fora da tela em telas estreitas; fixed + inset mantém dentro da área útil.
     */
    .notification-dropdown {
        position: fixed;
        top: max(4.35rem, calc(env(safe-area-inset-top, 0px) + 3.5rem));
        left: max(0.65rem, env(safe-area-inset-left, 0px));
        right: max(0.65rem, env(safe-area-inset-right, 0px));
        width: auto;
        max-width: none;
        transform: translateY(-12px) !important;
        transform-origin: top center;
    }

    .notification-dropdown.notification-dropdown--open {
        transform: translateY(0) !important;
    }

    .profile-menu-wrapper {
        flex: 0 0 auto;
    }

    .profile-menu-trigger {
        padding: 0.35rem 0.45rem;
        gap: 0.45rem;
        max-width: min(100%, 52vw);
    }

    .profile-dropdown {
        right: 0;
        left: auto;
        max-width: min(calc(100vw - 0.75rem), 280px);
        min-width: 0;
    }

    .theme-toggle {
        width: 36px;
        height: 36px;
        flex-shrink: 0;
    }

    .dashboard-container {
        flex-direction: column;
        min-width: 0;
    }

    /* Menu lateral: gaveta + overlay (mobile) — vidro fosco iOS (iosdesign.md) */
    .sidebar-backdrop {
        display: none;
        position: fixed;
        inset: 0;
        z-index: 9500;
        background: rgba(0, 0, 0, 0.22);
        backdrop-filter: blur(12px) saturate(120%);
        -webkit-backdrop-filter: blur(12px) saturate(120%);
        opacity: 0;
        transition: opacity 0.28s ease;
        pointer-events: none;
    }

    html[data-theme="dark"] .sidebar-backdrop {
        background: rgba(0, 0, 0, 0.38);
        backdrop-filter: blur(16px) saturate(120%);
        -webkit-backdrop-filter: blur(16px) saturate(120%);
    }

    .sidebar-backdrop.is-active {
        display: block;
        opacity: 1;
        pointer-events: auto;
    }

    .sidebar-mobile-header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        padding: 0 0.15rem 0.85rem 0;
        margin-bottom: 0.35rem;
        border-bottom: 0.5px solid var(--separator-color);
    }

    .sidebar-mobile-title {
        font-size: 1.05rem;
        font-weight: 700;
        color: var(--color-text);
        letter-spacing: -0.02em;
    }

    .sidebar-mobile-close {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 40px;
        height: 40px;
        padding: 0;
        border: none;
        border-radius: 12px;
        background: rgba(10, 48, 85, 0.07);
        color: var(--color-text);
        cursor: pointer;
        flex-shrink: 0;
        transition: background 0.2s ease, transform 0.1s ease;
        -webkit-tap-highlight-color: transparent;
    }

    html[data-theme="dark"] .sidebar-mobile-close {
        background: rgba(255, 255, 255, 0.12);
    }

    .sidebar-mobile-close:active {
        transform: scale(0.94);
    }

    .sidebar {
        width: min(292px, 88vw);
        min-width: 0;
        height: 100vh;
        height: 100dvh;
        max-height: 100dvh;
        position: fixed;
        left: 0;
        top: 0;
        padding: max(0.85rem, env(safe-area-inset-top)) 1rem 1.25rem
            max(0.85rem, env(safe-area-inset-left));
        flex-direction: column;
        flex-shrink: 0;
        flex-wrap: nowrap;
        border-right: 0.5px solid var(--separator-color);
        border-bottom: none;
        /* Glassmorphism: translucidez + blur (iosdesign.md §C) */
        background-color: rgba(255, 255, 255, 0.72) !important;
        backdrop-filter: saturate(180%) blur(22px) !important;
        -webkit-backdrop-filter: saturate(180%) blur(22px) !important;
        box-shadow: 4px 0 28px rgba(0, 0, 0, 0.06);
        z-index: 9600;
        transform: translate3d(-100%, 0, 0);
        transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
        overflow-x: hidden;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        align-items: stretch;
        gap: 0.35rem;
        white-space: normal;
        visibility: hidden;
        pointer-events: none;
    }

    html[data-theme="dark"] .sidebar {
        background-color: rgba(72, 72, 74, 0.58) !important;
        backdrop-filter: saturate(180%) blur(22px) !important;
        -webkit-backdrop-filter: saturate(180%) blur(22px) !important;
        box-shadow: 4px 0 36px rgba(0, 0, 0, 0.22);
    }

    .sidebar.sidebar--open {
        transform: translate3d(0, 0, 0);
        visibility: visible;
        pointer-events: auto;
    }

    .sidebar-section-label {
        margin-top: 0.65rem;
        margin-bottom: 0.15rem;
        padding: 0.35rem 0.75rem 0.1rem;
        padding-left: 0.75rem;
        width: 100%;
        box-sizing: border-box;
        border-top: 0.5px solid var(--separator-color);
        font-size: 0.72rem;
    }

    .sidebar-section-label:first-of-type {
        margin-top: 0.25rem;
        border-top: none;
        padding-top: 0.15rem;
    }

    .sidebar-item {
        flex: 0 0 auto;
        width: 100%;
        box-sizing: border-box;
        padding: 0.65rem 0.85rem;
        font-size: 0.9rem;
        white-space: normal;
    }

    .sidebar-footer-actions {
        margin-top: 1rem;
        padding-top: 0.85rem;
        width: 100%;
        box-sizing: border-box;
    }

    .dashboard-header {
        flex-direction: column;
        align-items: flex-start;
        min-width: 0;
    }

    .main-content {
        padding: 1rem;
        min-width: 0;
    }

    .dashboard-grid {
        grid-template-columns: 1fr;
    }

    .widget-card {
        min-width: 0;
    }

    .widget-value {
        font-size: 2rem;
    }

    .process-table-panel {
        margin-left: 0;
        margin-right: 0;
        padding: 1rem;
        -webkit-overflow-scrolling: touch;
        overscroll-behavior-x: contain;
    }

    .process-table {
        min-width: 640px;
    }

    .process-table th,
    .process-table td {
        word-break: break-word;
        overflow-wrap: anywhere;
    }

    .nav-user-info {
        display: none;
    }

    .profile-actions {
        flex-direction: column;
    }

    .search-section {
        padding: 1.5rem 1rem;
    }

    .search-box {
        max-width: 100%;
        margin-left: auto;
        margin-right: auto;
    }

    .process-header-section {
        flex-direction: column;
        align-items: stretch;
        gap: 1rem;
    }

    .process-header-section .new-process-btn {
        width: 100%;
        box-sizing: border-box;
        text-align: center;
    }

    .search-filter-row {
        flex-direction: column;
        align-items: stretch;
    }

    .process-search-form {
        flex-direction: column;
        align-items: stretch;
    }

    .search-bar-wrap {
        min-width: 0;
        width: 100%;
    }

    .profile-page-wrap {
        max-width: 100%;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
        box-sizing: border-box;
    }

    .profile-card {
        padding: 1.2rem;
        min-width: 0;
    }
}

@media (max-width: 560px) {
    .navbar {
        position: sticky;
        top: 0;
        z-index: 1000;
        margin: 0.35rem;
        padding: 0.55rem 0.65rem 0.28rem;
        align-items: center;
    }

    .nav-brand {
        font-size: 1.05rem;
    }

    .nav-brand.marca-brand-shimmer {
        max-width: min(260px, 75vw);
    }

    .nav-brasilia-clock {
        font-size: 0.56rem;
    }

    .notification-dropdown {
        top: max(3.85rem, calc(env(safe-area-inset-top, 0px) + 3.1rem));
    }

    .nav-brand .brand-logo-img--navbar {
        height: 40px;
        max-width: min(260px, 75vw);
    }

    .page-title {
        font-size: 1.45rem;
        line-height: 1.15;
        margin-bottom: 0.35rem;
    }

    .dashboard-subtitle {
        font-size: 0.9rem;
        line-height: 1.35;
        margin-top: 0;
    }


    .dashboard-pill-group {
        width: 100%;
    }

    .dashboard-pill {
        font-size: 0.72rem;
    }

    .main-content {
        padding: 0.75rem;
    }

    .messages {
        right: 0.75rem;
        left: 0.75rem;
        bottom: max(1rem, env(safe-area-inset-bottom, 0px));
        max-width: none;
        width: auto;
        align-items: stretch;
    }

    .modal-dialog {
        max-height: min(88dvh, 92vh);
        border-radius: 16px 16px 0 0;
    }

    .modal-header {
        padding: 1.25rem 1rem 1rem;
    }

    .ios-auth-main-col {
        padding-left: max(1rem, env(safe-area-inset-left));
        padding-right: max(1rem, env(safe-area-inset-right));
    }

    .ios-auth-body {
        padding-left: max(1rem, env(safe-area-inset-left));
        padding-right: max(1rem, env(safe-area-inset-right));
    }
}

/* =========================
   Processos List
========================= */

.process-header-section {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2rem;
}

.header-titles .page-title {
    font-size: 1.8rem;
    font-weight: 800;
}

.new-process-btn {
    padding: 0.8rem 1.5rem;
    border-radius: 12px;
    background-color: #1c1c1c; /* Dark color as in the design */
    color: white;
}

html[data-theme="dark"] .new-process-btn {
    background-color: #2a2a2a;
}

.search-filter-row {
    background: var(--surface-soft);
    padding: 1rem;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
}

.process-search-form {
    display: flex;
    gap: 1rem;
    align-items: center;
}

.search-bar-wrap {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}

.search-icon {
    position: absolute;
    left: 1rem;
    color: var(--text-soft);
}

.process-search-input {
    width: 100%;
    padding: 0.8rem 1rem 0.8rem 2.5rem;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    background: var(--color-white);
    color: var(--color-text);
    outline: none;
}

html[data-theme="dark"] .process-search-input {
    background: rgba(15, 24, 40, 0.9);
}

.filter-dropdown-wrap .process-status-select {
    padding: 0.8rem 1rem;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    background: var(--color-white);
    color: var(--color-text);
    outline: none;
    cursor: pointer;
}

html[data-theme="dark"] .process-status-select {
    background: rgba(15, 24, 40, 0.9);
}

.status-cards-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.status-counter-card {
    flex: 1;
    min-width: 120px;
    background: var(--color-white);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: var(--color-text);
    transition: all 0.2s ease;
    box-shadow: 0 2px 10px rgba(0,0,0,0.02);
}

html[data-theme="dark"] .status-counter-card {
    background: rgba(20, 30, 50, 0.8);
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}

.status-counter-card:hover, .status-counter-card.active {
    transform: translateY(-3px);
    box-shadow: 0 6px 15px rgba(0,0,0,0.08);
    border-color: var(--color-primary);
}

.status-count {
    font-size: 1.8rem;
    font-weight: 800;
    margin-bottom: 0.2rem;
}

.status-label {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--text-soft);
    letter-spacing: 0.5px;
}

.process-list {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.process-list--in-panel {
    gap: 0.75rem;
}

.process-recent-panel {
    margin-top: 1.25rem;
    padding: 1.1rem 1.15rem 1.25rem;
    border-radius: 18px;
    max-width: 100%;
    min-width: 0;
    overflow: visible;
}

.process-recent-panel .dash-table-head {
    margin-bottom: 0.85rem;
}

.dash-home .process-recent-panel {
    margin-top: 0;
}

.process-list-item {
    position: relative;
    z-index: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    background: var(--surface-level-1);
    border: 1px solid var(--glass-border);
    border-radius: 16px;
    padding: 1.15rem 1.25rem;
    text-decoration: none;
    color: inherit;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.process-list-item:hover {
    border-color: rgba(0, 122, 255, 0.22);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.07);
}

html[data-theme="dark"] .process-list-item {
    background: rgba(28, 28, 30, 0.92);
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}

html[data-theme="dark"] .process-list-item:hover {
    border-color: rgba(10, 132, 255, 0.35);
}

.process-item-content {
    flex: 1;
    min-width: 0;
}

.process-item-topline {
    position: relative;
    display: block;
    margin-bottom: 0.2rem;
    /* O badge de sigilo não entra no fluxo: evita que a linha fique tão alta quanto o ícone e empurre o assunto para baixo. */
    padding-right: 2.75rem;
}

.process-item-top {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-wrap: wrap;
    min-width: 0;
}

.process-sigilo-badge {
    position: relative;
    flex-shrink: 0;
    width: 2.125rem;
    height: 2.125rem;
    border-radius: 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.92rem;
    line-height: 1;
    border: 0.5px solid var(--glass-border);
    background: var(--surface-level-2);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
    margin-top: 0.05rem;
    cursor: default;
}

/* Sobrepõe position:relative acima: badge fora do fluxo na primeira linha (altura = número + tags). */
.process-item-topline .process-sigilo-badge {
    position: absolute;
    top: 0;
    right: 0;
    margin-top: 0;
}

/* Tooltip iOS: elemento real no DOM (attr() em content é pouco fiável em alguns motores) */
.process-sigilo-tooltip {
    position: absolute;
    z-index: 3000;
    bottom: calc(100% + 11px);
    left: 50%;
    transform: translateX(-50%) translateY(6px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.22s cubic-bezier(0.25, 1, 0.5, 1),
        transform 0.22s cubic-bezier(0.25, 1, 0.5, 1),
        visibility 0.22s;
}

.process-sigilo-tooltip__text {
    display: block;
    min-width: 10rem;
    max-width: min(17.5rem, calc(100vw - 2rem));
    padding: 0.62rem 0.85rem;
    border-radius: 13px;
    font-size: 0.8125rem;
    font-weight: 500;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display",
        "Segoe UI", Inter, system-ui, sans-serif;
    line-height: 1.38;
    letter-spacing: -0.015em;
    text-align: center;
    font-style: normal;
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.92);
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    border: 1px solid rgba(60, 60, 67, 0.14);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1), 0 2px 10px rgba(0, 0, 0, 0.06);
    white-space: normal;
    word-wrap: break-word;
    overflow-wrap: anywhere;
}

.process-sigilo-tooltip__text strong {
    font-weight: 700;
    letter-spacing: -0.02em;
}

[data-theme="dark"] .process-sigilo-tooltip__text {
    color: #f2f2f7;
    background: rgba(44, 44, 46, 0.92);
    border-color: rgba(255, 255, 255, 0.14);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45), 0 2px 12px rgba(0, 0, 0, 0.3);
}

@media (hover: hover) and (pointer: fine) {
    .process-list-item:has(.process-sigilo-badge:hover) {
        z-index: 25;
    }

    .process-sigilo-badge:hover .process-sigilo-tooltip {
        opacity: 1;
        visibility: visible;
        transform: translateX(-50%) translateY(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .process-sigilo-tooltip {
        transition-duration: 0.01ms;
    }
}

.process-sigilo-badge--publico {
    color: #007aff;
    background: rgba(0, 122, 255, 0.1);
    border-color: rgba(0, 122, 255, 0.22);
}

.process-sigilo-badge--sigiloso {
    color: #1c1c1e;
    background: rgba(0, 0, 0, 0.06);
    border-color: rgba(0, 0, 0, 0.12);
}

.process-sigilo-badge--segredo {
    color: #ff3b30;
    background: rgba(255, 59, 48, 0.12);
    border-color: rgba(255, 59, 48, 0.28);
}

[data-theme="dark"] .process-sigilo-badge--publico {
    color: #0a84ff;
    background: rgba(10, 132, 255, 0.18);
    border-color: rgba(10, 132, 255, 0.35);
}

[data-theme="dark"] .process-sigilo-badge--sigiloso {
    color: #f2f2f7;
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.18);
}

[data-theme="dark"] .process-sigilo-badge--segredo {
    color: #ff6961;
    background: rgba(255, 69, 58, 0.2);
    border-color: rgba(255, 105, 97, 0.4);
}

.process-item-number {
    font-weight: 700;
    color: var(--color-primary);
    font-size: 0.92rem;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
    word-break: break-all;
}

.process-tags {
    display: flex;
    gap: 0.5rem;
}

.tag {
    padding: 0.2rem 0.6rem;
    border-radius: 999px;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.5px;
}

.tag-default { background: #e0e0e0; color: #555; }
.tag-class { background: rgba(100, 100, 100, 0.1); color: var(--text-soft); border: 1px solid var(--glass-border); }
.tag-andamento { background: rgba(220, 53, 69, 0.1); color: #dc3545; }
.tag-sentenciado { background: rgba(40, 167, 69, 0.1); color: #28a745; }
.tag-arquivado { background: rgba(108, 117, 125, 0.1); color: #6c757d; }
.tag-suspenso { background: rgba(255, 149, 0, 0.12); color: #c35a00; border: 1px solid rgba(255, 149, 0, 0.28); }
.tag-sigilo { background: rgba(220, 53, 69, 0.1); color: #dc3545; border: 1px solid rgba(220, 53, 69, 0.3); }

html[data-theme="dark"] .tag-suspenso { background: rgba(255, 159, 10, 0.18); color: #ffcc80; border-color: rgba(255, 159, 10, 0.35); }

html[data-theme="dark"] .tag-andamento { background: rgba(255, 99, 112, 0.15); color: #ff6b76; }
html[data-theme="dark"] .tag-sentenciado { background: rgba(46, 212, 85, 0.15); color: #3be063; }
html[data-theme="dark"] .tag-sigilo { background: rgba(255, 99, 112, 0.15); color: #ff6b76; border-color: rgba(255, 99, 112, 0.4); }

.process-item-subject {
    font-size: 1.02rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.4rem;
    line-height: 1.3;
    overflow-wrap: anywhere;
    letter-spacing: -0.01em;
}

.process-item-footer {
    font-size: 0.85rem;
    color: var(--text-soft);
}

.process-item-parties {
    display: block;
    line-height: 1.45;
    overflow-wrap: anywhere;
}

.process-item-parties-sep {
    margin: 0 0.35rem;
    color: var(--text-soft);
    font-weight: 500;
}

.tag-sigilo i {
    margin-right: 0.28rem;
}

.process-item-arrow {
    flex-shrink: 0;
    padding-left: 0.25rem;
    color: var(--text-tertiary);
    font-size: 0.85rem;
}

@media (max-width: 768px) {
    .process-list-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }

    .process-item-arrow {
        display: none;
    }

    .process-item-content {
        min-width: 0;
    }

    .process-header-section {
        flex-direction: column;
        align-items: flex-start;
        gap: 1rem;
    }

    .process-header-section .new-process-btn {
        width: 100%;
        box-sizing: border-box;
        text-align: center;
    }
    
    .process-search-form {
        flex-direction: column;
    }
    
    .status-cards-row {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.75rem;
        margin-bottom: 1.25rem;
    }

    .status-counter-card {
        flex: unset;
        min-width: 0;
        width: auto;
    }
}

/* ==========================================================================
   Formulários e Inputs (Modal / Páginas)
   ========================================================================== */
.form-row {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.2rem;
}
.form-group {
    margin-bottom: 1.2rem;
    width: 100%;
}
.form-group label {
    display: block;
    margin-bottom: 0.5rem;
    font-weight: 700;
    color: var(--color-primary);
}
.form-control {
    width: 100%;
    padding: 0.85rem 1rem;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: var(--surface-soft);
    color: var(--color-text);
    outline: none;
    font-size: 1rem;
    transition: all 0.2s;
    box-sizing: border-box;
}
select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 1em;
}
html[data-theme="dark"] select.form-control {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e4ecff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
}
/* Modal: permissão de cargo externo (passos + alinhamento iOS HIG) */
.perm-ext-step-card {
    border: 1px solid var(--separator-color, rgba(0, 0, 0, 0.08));
    border-radius: 16px;
    padding: 1rem 1.1rem 1.1rem;
    margin-bottom: 1.15rem;
    background: var(--surface-level-1, rgba(255, 255, 255, 0.5));
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
}
html[data-theme="dark"] .perm-ext-step-card {
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
}
.perm-ext-step-kicker {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-soft);
    margin: 0 0 0.5rem 0;
    font-weight: 600;
}
.perm-ext-step-hint {
    font-size: 0.8rem;
    color: var(--text-soft);
    margin: 0 0 1rem 0;
    line-height: 1.45;
}
.perm-ext-label {
    display: block;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.45rem;
}
.perm-ext-field {
    margin-bottom: 0.95rem;
}
.perm-ext-footnote {
    font-size: 0.75rem;
    color: var(--text-soft);
    margin: 0.35rem 0 0 0;
    line-height: 1.4;
}
.perm-ext-error {
    font-size: 0.8rem;
    margin-top: 0.35rem !important;
}
.perm-ext-perms-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.85rem 1rem;
}
.perm-ext-switch-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    cursor: pointer;
    font-weight: normal;
    font-size: 0.85rem;
    color: var(--color-text);
}
.perm-ext-nonfield {
    margin-top: 1rem;
    font-size: 0.85rem;
}
.perm-ext-actions {
    margin-top: 1.5rem;
    display: flex;
    gap: 1rem;
    justify-content: flex-end;
}
.perm-ext-btn-cancel {
    background: transparent;
    border: 1px solid var(--glass-border);
    color: var(--color-text);
    border-radius: 14px;
}
.perm-ext-btn-save {
    border-radius: 14px;
}
select.form-control.ios-form-select {
    border-radius: 14px;
}
@media (max-width: 520px) {
    .perm-ext-perms-grid {
        grid-template-columns: 1fr;
    }
}

/* Painel admin: mapeamentos de cargo externo (iOS HIG — cartão + lista agrupada) */
.orgao-sec-perm-ext {
    margin-top: 1.75rem;
}

.perm-ext-admin-card {
    border-radius: 16px;
    overflow: hidden;
    background: var(--surface-level-1);
    border: 0.5px solid var(--separator-color);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
}

html[data-theme="dark"] .perm-ext-admin-card {
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.22);
}

.perm-ext-admin-header {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.2rem 1.25rem 1.05rem;
    flex-wrap: wrap;
}

.perm-ext-admin-icon {
    flex-shrink: 0;
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary, #007aff);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.05rem;
}

html[data-theme="dark"] .perm-ext-admin-icon {
    background: rgba(10, 132, 255, 0.2);
}

.perm-ext-admin-text {
    flex: 1;
    min-width: min(100%, 14rem);
}

.perm-ext-admin-title {
    margin: 0 0 0.35rem 0;
    font-size: 1.2rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    color: var(--color-text);
    line-height: 1.15;
}

.perm-ext-admin-lede {
    margin: 0;
    font-size: 0.84rem;
    line-height: 1.4;
    color: var(--text-soft);
    max-width: 36rem;
}

.perm-ext-admin-lede strong {
    color: var(--color-text);
    font-weight: 600;
}

/* Botão primário no tamanho mínimo de toque iOS (~44–48pt) */
.perm-ext-admin-cta {
    border-radius: 12px;
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.2;
    padding: 0.7rem 1.35rem;
    min-height: 48px;
    flex-shrink: 0;
    align-self: center;
    box-shadow: 0 2px 10px rgba(0, 122, 255, 0.22);
    border: none;
}

.perm-ext-admin-cta i {
    margin-right: 0.35rem;
    font-size: 0.95em;
}

.perm-ext-admin-list {
    margin: 0;
    border-radius: 0;
    border-top: 0.5px solid var(--separator-color);
}

.perm-ext-admin-list .ios-list-item {
    background: var(--surface-level-1);
}

.perm-ext-map-line {
    font-size: 0.9rem;
}

.perm-ext-map-badges {
    margin-top: 0.35rem;
    display: flex;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.perm-ext-map-badge {
    font-size: 0.65rem;
    color: var(--text-soft);
}

.perm-ext-map-badge .fa-check {
    color: var(--color-success, #34c759);
    margin-right: 0.15rem;
}

.perm-ext-map-actions {
    display: flex;
    gap: 0.5rem;
    align-items: center;
}

.perm-ext-admin-empty {
    padding: 1.35rem 1.25rem 1.5rem;
    text-align: center;
    color: var(--text-soft);
    font-size: 0.875rem;
    line-height: 1.55;
    background: var(--surface-level-1);
}

.perm-ext-admin-empty strong {
    color: var(--color-text);
    font-weight: 600;
}

@media (max-width: 640px) {
    .perm-ext-admin-header {
        padding: 1rem 1rem 0.95rem;
    }

    .perm-ext-admin-cta {
        width: 100%;
        align-self: stretch;
        margin-top: 0.15rem;
    }
}

.form-control:focus {
    border-color: var(--color-primary);
    background: var(--color-white);
}
html[data-theme="dark"] .form-control:focus {
    background: rgba(15, 24, 40, 0.9);
}

/* ==========================================================================
   Custom Select UI
   ========================================================================== */
.custom-select-ui {
    position: relative;
    width: 100%;
}

.select-selected {
    background: var(--surface-soft);
    color: var(--color-text);
    padding: 0.85rem 1rem;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    cursor: pointer;
    user-select: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: all 0.3s ease;
}

.select-selected:hover {
    border-color: var(--color-primary);
}

.custom-select-ui.active .select-selected {
    border-radius: 8px 8px 0 0;
    border-color: var(--color-primary);
    background: var(--color-white);
}

html[data-theme="dark"] .custom-select-ui.active .select-selected {
    background: rgba(15, 24, 40, 0.9);
}

.select-selected i {
    transition: transform 0.3s ease;
    font-size: 0.8rem;
    opacity: 0.7;
}

.select-selected.select-arrow-active i {
    transform: rotate(180deg);
}

.select-items {
    position: absolute;
    background-color: var(--color-white);
    top: 100%;
    left: 0;
    right: 0;
    z-index: 99;
    border: 1px solid var(--color-primary);
    border-top: none;
    border-radius: 0 0 8px 8px;
    box-shadow: 0 8px 16px rgba(0,0,0,0.1);
    max-height: 200px;
    overflow-y: auto;
}

html[data-theme="dark"] .select-items {
    background-color: #1a2235;
    box-shadow: 0 8px 16px rgba(0,0,0,0.4);
}

.select-items div {
    color: var(--color-text);
    padding: 0.75rem 1rem;
    cursor: pointer;
    user-select: none;
    transition: background 0.2s;
}

.select-items div:hover, .same-as-selected {
    background-color: rgba(10, 48, 85, 0.1);
}

html[data-theme="dark"] .select-items div:hover, 
html[data-theme="dark"] .same-as-selected {
    background-color: rgba(255, 255, 255, 0.1);
}

.select-hide {
    display: none;
}

/* Custom scrollbar for select items */
.select-items::-webkit-scrollbar {
    width: 6px;
}
.select-items::-webkit-scrollbar-track {
    background: transparent;
}
.select-items::-webkit-scrollbar-thumb {
    background: rgba(10, 48, 85, 0.2);
    border-radius: 4px;
}
html[data-theme="dark"] .select-items::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
}


.search-reu-box {
    position: relative;
}
.search-results-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    background: var(--color-white);
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0,0,0,0.1);
    z-index: 1000;
    max-height: 250px;
    overflow-y: auto;
}
html[data-theme="dark"] .search-results-dropdown {
    background: #1a2235;
}
.search-result-item {
    padding: 0.8rem 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 0.5px solid var(--separator-color);
}
.search-result-item:hover {
    background: rgba(0,0,0,0.05);
}
html[data-theme="dark"] .search-result-item:hover {
    background: rgba(255,255,255,0.05);
}
.search-result-item img {
    width: 30px;
    height: 30px;
    border-radius: 50%;
}
.selected-user-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: var(--color-primary);
    color: white;
    padding: 0.4rem 0.8rem;
    border-radius: 999px;
    font-size: 0.85rem;
    margin-right: 0.5rem;
    margin-bottom: 0.5rem;
}
.selected-user-pill .remove-user {
    cursor: pointer;
    opacity: 0.7;
}
.selected-user-pill .remove-user:hover {
    opacity: 1;
}

@media (max-width: 768px) {
    .form-row {
        flex-direction: column;
        gap: 0;
    }
}

/* ==========================================================================
   Detalhes do Processo (Visualização)
   ========================================================================== */
.proc-detail-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 0.5px solid var(--separator-color);
    flex-wrap: wrap;
    gap: 1rem;
}

.proc-header-info {
    display: flex;
    flex-direction: column;
}

.proc-header-label {
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-soft);
    letter-spacing: 1px;
}

.proc-header-number {
    font-size: 1.8rem;
    font-weight: 800;
    margin: 0;
    color: var(--color-primary);
}

.proc-header-number--copy {
    cursor: pointer;
    border-radius: 8px;
    padding: 0.15rem 0.35rem;
    margin-left: -0.35rem;
    transition: background 0.2s ease, transform 0.15s ease;
}

.proc-header-number--copy:hover {
    background: var(--surface-level-2);
}

.proc-header-number--copy:active {
    transform: scale(0.98);
}

.proc-header-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.tag-large {
    padding: 0.4rem 1rem;
    font-size: 0.8rem;
}

.proc-btn-header {
    background: var(--surface-soft);
    border: 1px solid var(--glass-border);
    color: var(--color-text);
    transition: all 0.3s ease;
}
.proc-btn-header:hover {
    background: rgba(10, 48, 85, 0.05);
    border-color: var(--color-primary);
}
html[data-theme="dark"] .proc-btn-header:hover {
    background: rgba(255, 255, 255, 0.05);
}

.proc-detail-card {
    background: var(--color-white);
    border: 1px solid var(--glass-border);
    border-radius: 20px;
    padding: 2rem;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 20px rgba(0,0,0,0.03);
}
html[data-theme="dark"] .proc-detail-card {
    background: rgba(20, 30, 50, 0.6);
    box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}

.proc-grid-meta {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1.5rem;
}

.proc-meta-item {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.meta-label {
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--text-soft);
    letter-spacing: 0.5px;
}

.meta-value {
    font-size: 0.95rem;
    color: var(--color-text);
    font-weight: 500;
}

.proc-section-divider {
    height: 1px;
    background: var(--glass-border);
    margin: 2rem 0;
}

.proc-section-title {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: 1.5rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

.proc-section-header-flex {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
}

.proc-section-actions-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

@media (max-width: 768px) {
    .proc-detail-header {
        flex-direction: column;
        align-items: stretch;
    }

    .proc-header-number {
        font-size: clamp(1.05rem, 4.5vw, 1.5rem);
        word-break: break-word;
    }

    .proc-header-actions {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
        gap: 0.65rem;
    }

    .proc-header-actions .proc-btn-header,
    .proc-header-actions > .btn {
        width: 100%;
        justify-content: center;
    }

    .proc-header-actions .tag-large {
        align-self: flex-start;
    }

    .proc-grid-meta {
        grid-template-columns: 1fr;
        gap: 1rem;
    }

    .proc-partes-grid {
        grid-template-columns: 1fr;
    }

    .proc-section-header-flex {
        flex-direction: column;
        align-items: stretch;
        gap: 0.85rem;
    }

    .proc-section-actions-row {
        flex-direction: column;
        align-items: stretch;
    }

    .proc-section-actions-row .proc-btn-header,
    .proc-section-actions-row .btn {
        width: 100%;
        justify-content: center;
    }

    .proc-detail-card {
        padding: 1.15rem;
    }

    .proc-pendencia-row {
        flex-direction: column;
        align-items: stretch;
    }

    .proc-pendencia-row__meta {
        min-width: 0;
    }

    .proc-pendencia-row .btn {
        width: 100%;
    }

    .proc-advogado-item {
        flex-direction: column;
        align-items: stretch;
        gap: 0.75rem;
    }

    .adv-info {
        min-width: 0;
        align-items: flex-start;
    }

    .proc-advogado-item .adv-link {
        justify-content: center;
        padding: 0.55rem 0.75rem;
        border-radius: 12px;
        border: 1px solid var(--glass-border);
        background: var(--surface-level-2);
    }
}

.proc-partes-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.proc-parte-box {
    background: rgba(0,0,0,0.02);
    border-radius: 12px;
    overflow: hidden;
}
html[data-theme="dark"] .proc-parte-box {
    background: rgba(0,0,0,0.2);
}

.parte-box-header {
    background: rgba(0,0,0,0.03);
    padding: 0.6rem 1rem;
    font-size: 0.75rem;
    font-weight: 700;
    color: var(--text-soft);
}
html[data-theme="dark"] .parte-box-header {
    background: rgba(255,255,255,0.02);
}

.parte-box-content {
    padding: 1rem;
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.parte-nome {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--color-text);
}

.parte-id,
.parte-roblox {
    font-weight: normal;
    font-size: 0.8rem;
    color: var(--text-soft);
}

button.parte-roblox--link,
button.roblox-userlink {
    font: inherit;
    font-weight: normal;
    font-size: 0.8rem;
    color: var(--color-primary);
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 2px;
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    display: inline;
    vertical-align: baseline;
}

.proc-interessado-pill button.parte-roblox--link {
    font-size: inherit;
}

.timeline-assinatura-ios__who button.roblox-userlink {
    font-size: inherit;
    font-weight: 600;
}

.roblox-profile-modal__dialog {
    max-width: 420px;
}

/* Handle de arraste: apenas o ::before global de .modal-header (igual aos outros modais folha) */
.roblox-profile-modal .modal-header {
    padding: 1.35rem 1.25rem 1rem;
    align-items: flex-start;
}

.roblox-profile-modal .modal-title {
    margin: 0;
    padding-top: 0.2rem;
    font-size: 1.15rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.roblox-profile-modal .modal-header .modal-close {
    margin-top: 0.1rem;
}

.roblox-profile-modal__body.modal-body {
    padding: 1.15rem 1.25rem 1.5rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(120, 120, 128, 0.42) transparent;
}

.roblox-profile-modal__body.modal-body::-webkit-scrollbar {
    width: 5px;
}

.roblox-profile-modal__body.modal-body::-webkit-scrollbar-track {
    background: transparent;
}

.roblox-profile-modal__body.modal-body::-webkit-scrollbar-thumb {
    background-color: rgba(120, 120, 128, 0.4);
    border-radius: 100px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.roblox-profile-modal__body.modal-body::-webkit-scrollbar-thumb:hover {
    background-color: rgba(120, 120, 128, 0.55);
    border: 2px solid transparent;
    background-clip: padding-box;
}

[data-theme="dark"] .roblox-profile-modal__body.modal-body {
    scrollbar-color: rgba(235, 235, 245, 0.35) transparent;
}

[data-theme="dark"] .roblox-profile-modal__body.modal-body::-webkit-scrollbar-thumb {
    background-color: rgba(235, 235, 245, 0.32);
}

[data-theme="dark"] .roblox-profile-modal__body.modal-body::-webkit-scrollbar-thumb:hover {
    background-color: rgba(235, 235, 245, 0.48);
}

.roblox-profile-modal__loading {
    margin: 0;
    padding: 0.75rem 0 1rem;
    color: var(--text-soft);
}

.roblox-profile-modal__error {
    margin: 0;
    padding: 0.75rem 0;
    color: var(--color-danger, #c00);
}

.roblox-profile-modal__content {
    display: flex;
    flex-direction: column;
    gap: 1.15rem;
}

.roblox-profile-modal__hero {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    margin: 0;
    padding-top: 0.15rem;
}

.roblox-profile-modal__headlines {
    min-width: 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.roblox-profile-modal__avatar {
    width: 96px;
    height: 96px;
    border-radius: 14px;
    object-fit: cover;
    background: var(--surface-level-2);
    flex-shrink: 0;
}

.roblox-profile-modal__dn {
    font-weight: 700;
    font-size: 1.12rem;
    color: var(--color-text);
    line-height: 1.28;
}

.roblox-profile-modal__un {
    font-size: 0.9rem;
    color: var(--color-primary, #007aff);
    font-weight: 500;
    margin: 0;
    line-height: 1.3;
}

.roblox-profile-modal__meta {
    font-size: 0.78rem;
    color: var(--text-soft);
    margin: 0.45rem 0 0;
    line-height: 1.4;
}

.roblox-profile-modal__bio-block {
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.roblox-profile-modal__bio-label {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    margin: 0;
}

.roblox-profile-modal__bio {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.45;
    color: var(--color-text);
    white-space: pre-wrap;
    max-height: 11rem;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-right: 0.2rem;
    scrollbar-width: thin;
    scrollbar-color: rgba(120, 120, 128, 0.42) transparent;
}

.roblox-profile-modal__bio::-webkit-scrollbar {
    width: 5px;
}

.roblox-profile-modal__bio::-webkit-scrollbar-track {
    background: transparent;
}

.roblox-profile-modal__bio::-webkit-scrollbar-thumb {
    background-color: rgba(120, 120, 128, 0.4);
    border-radius: 100px;
    border: 2px solid transparent;
    background-clip: padding-box;
}

.roblox-profile-modal__bio::-webkit-scrollbar-thumb:hover {
    background-color: rgba(120, 120, 128, 0.55);
    border: 2px solid transparent;
    background-clip: padding-box;
}

[data-theme="dark"] .roblox-profile-modal__bio {
    scrollbar-color: rgba(235, 235, 245, 0.35) transparent;
}

[data-theme="dark"] .roblox-profile-modal__bio::-webkit-scrollbar-thumb {
    background-color: rgba(235, 235, 245, 0.32);
}

[data-theme="dark"] .roblox-profile-modal__bio::-webkit-scrollbar-thumb:hover {
    background-color: rgba(235, 235, 245, 0.48);
}

.roblox-profile-modal__open {
    width: 100%;
    justify-content: center;
    text-align: center;
    box-sizing: border-box;
    border-radius: 14px;
    margin-top: 0.15rem;
}

.proc-interessados-list {
    display: flex;
    flex-direction: column;
    gap: 0.8rem;
}

.proc-interessado-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(0,0,0,0.04);
    padding: 0.6rem 1rem;
    border-radius: 12px;
    font-size: 0.9rem;
    color: var(--color-text);
    width: fit-content;
    max-width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
}
html[data-theme="dark"] .proc-interessado-pill {
    background: rgba(255,255,255,0.05);
}

.proc-info-adicional {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.info-block {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.meta-value-bold {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--color-text);
}

.meta-text {
    font-size: 0.95rem;
    color: var(--color-text);
    line-height: 1.6;
}

.proc-advogado-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border: 1px solid var(--glass-border);
    border-radius: 12px;
    background: rgba(40, 167, 69, 0.03);
    margin-bottom: 0.8rem;
}
html[data-theme="dark"] .proc-advogado-item {
    background: rgba(46, 212, 85, 0.05);
}

.adv-info {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.adv-icon {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(40, 167, 69, 0.15);
    color: #28a745;
    display: flex;
    align-items: center;
    justify-content: center;
}
html[data-theme="dark"] .adv-icon {
    background: rgba(46, 212, 85, 0.2);
    color: #3be063;
}

.adv-name {
    font-weight: 700;
    color: var(--color-text);
    font-size: 0.95rem;
}

.adv-role {
    font-size: 0.8rem;
    color: var(--text-soft);
}

.adv-link {
    color: var(--color-text);
    text-decoration: none;
    font-size: 0.85rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    transition: opacity 0.2s;
}
.adv-link:hover {
    opacity: 0.7;
}

/* Segmented Control (iOS Style Tabs) */
.proc-tabs-container {
    background: transparent;
    border: none;
    border-radius: 0;
    overflow: visible;
    margin-bottom: 2rem;
    box-shadow: none;
    min-width: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}
html[data-theme="dark"] .proc-tabs-container {
    background: transparent;
    box-shadow: none;
}

.proc-tabs-header {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    background: rgba(118, 118, 128, 0.12); /* System gray background */
    border-radius: 8px;
    padding: 2px;
    margin-bottom: 1.5rem;
    border: none;
    gap: 2px;
    min-width: 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    /* Mobile-first: rolar abas em vez de comprimir texto (body/html usam overflow-x: clip) */
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    overscroll-behavior-x: contain;
    touch-action: pan-x;
    -ms-overflow-style: auto;
    scroll-snap-type: x proximity;
}
html[data-theme="dark"] .proc-tabs-header {
    background: rgba(118, 118, 128, 0.24);
}

.proc-tab {
    flex: 0 0 auto;
    flex-shrink: 0;
    justify-content: center;
    padding: 0.6rem 1rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-soft);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    border-radius: 6px;
    border-bottom: none;
    transition: all 0.2s ease;
    white-space: nowrap;
    scroll-snap-align: start;
}

.proc-tab:hover {
    color: var(--color-text);
}

.proc-tab.active {
    color: var(--color-text);
    background: var(--color-white);
    box-shadow: 0 3px 8px rgba(0,0,0,0.12), 0 3px 1px rgba(0,0,0,0.04);
}
html[data-theme="dark"] .proc-tab.active {
    background: #636366;
    color: #FFFFFF;
    box-shadow: 0 3px 8px rgba(0,0,0,0.2);
}

.proc-tabs-content {
    padding: 0;
    min-width: 0;
    max-width: 100%;
    box-sizing: border-box;
    /* Nunca clip horizontal: ícones da timeline usam left negativo (.timeline-dot--icon) */
    overflow-x: visible;
    overflow-y: visible;
}

.proc-detail-layout {
    align-items: flex-start;
    min-width: 0;
    max-width: 100%;
}

.proc-detail-main {
    min-width: 0;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
}

@media (min-width: 921px) {
    .proc-tabs-header {
        overflow-x: visible;
        touch-action: manipulation;
        scroll-snap-type: none;
    }

    .proc-tab {
        flex: 1;
        scroll-snap-align: unset;
    }
}

@media (max-width: 920px) {
    /* Recua a linha do tempo para os círculos não ficarem sob html/body overflow-x: clip */
    .proc-tabs-content .proc-timeline {
        padding-left: 1rem;
        box-sizing: border-box;
    }
}

.proc-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.proc-timeline-item {
    position: relative;
    padding-left: 2.5rem;
    border-left: 0.5px solid var(--separator-color);
    padding-bottom: 2rem;
}

.proc-timeline-item:last-child {
    padding-bottom: 0;
}

.timeline-dot {
    position: absolute;
    left: -4px;
    top: 5px;
    width: 7px;
    height: 7px;
    background: var(--color-text);
    border-radius: 50%;
}

.timeline-dot--icon {
    width: 1.75rem;
    height: 1.75rem;
    left: calc(-0.875rem - 2px);
    top: 0.05rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--glass-bg, rgba(255, 255, 255, 0.85));
    border: 2px solid var(--separator-color);
    color: var(--color-text);
    font-size: 0.75rem;
    box-sizing: border-box;
}

.timeline-dot--icon > i {
    font-style: normal;
    line-height: 1;
    display: block;
    font-size: inherit;
}

html[data-theme="dark"] .timeline-dot--icon {
    background: rgba(44, 44, 46, 0.95);
    color: var(--color-text);
}

.timeline-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.5rem;
}

.timeline-header__left {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.45rem;
    min-width: 0;
}

.timeline-mov-num {
    flex-shrink: 0;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    color: var(--ios-blue, #007aff);
}

.timeline-tag {
    background: rgba(0,0,0,0.04);
    padding: 0.2rem 0.6rem;
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 700;
    color: var(--text-soft);
    letter-spacing: 0.5px;
}
html[data-theme="dark"] .timeline-tag {
    background: rgba(255,255,255,0.05);
}

.timeline-date {
    font-size: 0.8rem;
    color: var(--text-soft);
}

.timeline-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.5rem;
}

.timeline-text {
    font-size: 0.9rem;
    color: var(--color-text);
    line-height: 1.5;
    margin-bottom: 1rem;
}

.timeline-files {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1rem;
}

.files-label {
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--text-soft);
}

.timeline-file-link {
    font-size: 0.9rem;
    color: var(--color-text);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    max-width: 100%;
    border-radius: 10px;
    padding: 0.2rem 0.35rem;
    margin: -0.2rem -0.35rem;
    transition: background 0.15s ease;
}
.timeline-file-link:hover {
    text-decoration: none;
    background: rgba(0, 122, 255, 0.08);
}
.timeline-file-link__ico {
    flex-shrink: 0;
    font-size: 1rem;
    opacity: 0.85;
}
.timeline-file-link__text {
    min-width: 0;
    word-break: break-word;
}
.timeline-file-link--pdf {
    color: var(--ios-blue, #007aff);
    font-weight: 500;
}

.timeline-footer {
    font-size: 0.75rem;
    color: var(--text-soft);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.timeline-item-main {
    display: flex;
    align-items: flex-start;
    gap: 0.45rem;
    min-width: 0;
    flex: 1;
}

.timeline-item-main > .timeline-content {
    flex: 1;
    min-width: 0;
}

.proc-timeline-assin-icn {
    flex-shrink: 0;
    width: 1.85rem;
    height: 1.85rem;
    padding: 0;
    margin: 0.15rem 0 0;
    border: none;
    border-radius: 8px;
    background: rgba(0, 122, 255, 0.12);
    color: var(--ios-blue, #007aff);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    line-height: 1;
    transition: background 0.15s ease, transform 0.12s ease, color 0.15s ease;
}

html[data-theme="dark"] .proc-timeline-assin-icn {
    background: rgba(10, 132, 255, 0.18);
    color: #64b5ff;
}

.proc-timeline-assin-icn:hover {
    background: rgba(0, 122, 255, 0.22);
    transform: scale(1.04);
}

html[data-theme="dark"] .proc-timeline-assin-icn:hover {
    background: rgba(10, 132, 255, 0.3);
}

.timeline-footer-inserido,
.timeline-footer-assinado {
    font-size: 0.75rem;
    color: var(--text-soft);
    display: flex;
    align-items: flex-start;
    gap: 0.4rem;
    margin-top: 0.35rem;
    line-height: 1.35;
}

.timeline-footer-assinado {
    margin-top: 0.5rem;
}

.timeline-meta--muted {
    opacity: 0.65;
}

.timeline-doc-inserido {
    margin: 0.35rem 0 0;
    padding: 0;
    font-size: 0.72rem;
    color: var(--text-soft);
    display: flex;
    align-items: center;
    gap: 0.35rem;
    line-height: 1.35;
}

.timeline-doc-card__row--file {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.timeline-doc-card__row--file .timeline-file-link {
    flex: 1;
    min-width: 0;
}

.pdf-viewer-modal__head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.5rem;
    flex-wrap: nowrap;
}

.pdf-viewer-modal__title-block {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex: 1;
    min-width: 0;
}

.pdf-viewer-modal__title-block .pdf-viewer-modal__title {
    flex: 1;
    min-width: 0;
    margin: 0;
}

.proc-pdf-viewer-assin-btn {
    margin-top: 0.1rem;
}

/* Documentos na timeline + assinaturas por anexo */
.timeline-files--docs {
    margin-bottom: 1rem;
}

.timeline-doc-stack {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 0.5rem;
}

.timeline-doc-card {
    border-radius: 14px;
    border: 1px solid var(--glass-border, rgba(0, 0, 0, 0.08));
    background: var(--glass-bg, rgba(255, 255, 255, 0.55));
    padding: 0.75rem 0.9rem;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

html[data-theme="dark"] .timeline-doc-card {
    background: rgba(44, 44, 46, 0.45);
    border-color: rgba(255, 255, 255, 0.08);
}

.timeline-doc-card__row {
    margin-bottom: 0.35rem;
}

.timeline-doc-card__row .timeline-file-link {
    width: 100%;
    box-sizing: border-box;
}

.timeline-doc-assinaturas {
    margin-top: 0.45rem;
    padding: 0.38rem 0.5rem;
    border-radius: 10px;
    background: rgba(0, 122, 255, 0.06);
    border: 1px solid rgba(0, 122, 255, 0.12);
}

html[data-theme="dark"] .timeline-doc-assinaturas {
    background: rgba(10, 132, 255, 0.08);
    border-color: rgba(10, 132, 255, 0.22);
}

.timeline-doc-assinaturas--collapsible > .timeline-doc-assinaturas__summary {
    list-style: none;
    cursor: pointer;
    margin: 0;
    padding: 0;
    border-radius: 8px;
}

.timeline-doc-assinaturas--collapsible > .timeline-doc-assinaturas__summary::-webkit-details-marker {
    display: none;
}

.timeline-doc-assinaturas__summary-inner {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.35rem 0.45rem;
    border-radius: 8px;
    font-size: 0.62rem;
    font-weight: 750;
    letter-spacing: 0.055em;
    text-transform: uppercase;
    color: var(--ios-blue, #007aff);
    line-height: 1.2;
    transition: background 0.15s ease;
}

.timeline-doc-assinaturas--collapsible .timeline-doc-assinaturas__summary:hover .timeline-doc-assinaturas__summary-inner {
    background: rgba(0, 122, 255, 0.08);
}

html[data-theme="dark"] .timeline-doc-assinaturas--collapsible .timeline-doc-assinaturas__summary:hover .timeline-doc-assinaturas__summary-inner {
    background: rgba(10, 132, 255, 0.12);
}

.timeline-doc-assinaturas__summary-label {
    flex: 1;
    min-width: 0;
    text-align: left;
}

.timeline-doc-assinaturas__sig-icn {
    font-size: 0.62rem;
}

.timeline-doc-assinaturas--st-ok .timeline-doc-assinaturas__sig-icn {
    color: var(--ios-blue, #007aff);
}

.timeline-doc-assinaturas--st-pendente .timeline-doc-assinaturas__sig-icn {
    color: #ff9500;
}

.timeline-doc-assinaturas--st-recusou .timeline-doc-assinaturas__sig-icn {
    color: #ff453a;
}

.timeline-doc-assinaturas__chev {
    font-size: 0.55rem;
    opacity: 0.75;
    transition: transform 0.2s ease;
}

.timeline-doc-assinaturas--collapsible[open] .timeline-doc-assinaturas__chev {
    transform: rotate(180deg);
}

.timeline-doc-assinaturas__panel {
    padding: 0.35rem 0 0;
}

.timeline-doc-assinaturas__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.timeline-doc-assinaturas__list--ios {
    gap: 0.28rem;
}

/* Pré-visualização PDF na timeline — cartão cheio estilo iOS (HIG: squircle, sombra difusa, sem contorno) */
.timeline-pdf-preview-pop {
    position: fixed;
    z-index: 12500;
    display: flex;
    flex-direction: column;
    width: min(340px, 90vw);
    height: min(420px, 54vh);
    min-height: 200px;
    padding: 0;
    border-radius: 18px;
    overflow: hidden;
    background: #ffffff;
    border: none;
    outline: none;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition:
        opacity 0.22s cubic-bezier(0.25, 0.8, 0.25, 1),
        visibility 0.22s ease,
        transform 0.22s cubic-bezier(0.25, 0.8, 0.25, 1);
    transform: translateY(6px) scale(0.98);
}

.timeline-pdf-preview-pop--visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
}

html[data-theme="dark"] .timeline-pdf-preview-pop {
    background: rgba(28, 28, 30, 0.97);
    border: none;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}

/* Área única: iframe até contorno; corta barra de scroll do visualizador incorporado. */
.timeline-pdf-preview-pop__frame-clip {
    flex: 1;
    min-height: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
    background: #ffffff;
    border-radius: inherit;
    border: none;
    outline: none;
}

html[data-theme="dark"] .timeline-pdf-preview-pop__frame-clip {
    background: #1c1c1e;
}

.timeline-pdf-preview-pop__frame {
    position: absolute;
    top: 0;
    left: 0;
    width: calc(100% + 48px);
    height: 100%;
    max-width: none;
    border: 0;
    outline: none;
    margin: 0;
    padding: 0;
    background: #fff;
    display: block;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none;
    /* Recorte do “chrome” do visualizador PDF (bordas escuras, cantos, barra). Ordem: topo direita fundo esquerda. */
    clip-path: inset(10px 42px 8px 10px);
    -webkit-clip-path: inset(10px 42px 8px 10px);
}

/* Cartão compacto por solicitante (assinaturas no documento) */
.timeline-assinatura-ios {
    margin: 0;
    padding: 0.28rem 0.4rem;
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(0, 0, 0, 0.055);
    list-style: none;
}

html[data-theme="dark"] .timeline-assinatura-ios {
    background: rgba(58, 58, 60, 0.55);
    border-color: rgba(255, 255, 255, 0.06);
}

.timeline-assinatura-ios__main {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    line-height: 1.25;
}

.timeline-assinatura-ios__who {
    font-size: 0.74rem;
    font-weight: 600;
    color: var(--color-text);
    min-width: 0;
    flex: 1 1 auto;
    word-break: break-word;
}

.timeline-assinatura-ios__badge {
    flex-shrink: 0;
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.1rem 0.32rem;
    border-radius: 999px;
    line-height: 1.2;
}

.timeline-assinatura-ios__badge--pendente {
    background: rgba(255, 159, 10, 0.18);
    color: #b25d00;
}

html[data-theme="dark"] .timeline-assinatura-ios__badge--pendente {
    color: #ffcc66;
}

.timeline-assinatura-ios__badge--assinou {
    background: rgba(52, 199, 89, 0.18);
    color: #1b6b32;
}

html[data-theme="dark"] .timeline-assinatura-ios__badge--assinou {
    color: #7ef29a;
}

.timeline-assinatura-ios__badge--recusou {
    background: rgba(255, 69, 58, 0.16);
    color: #b32d24;
}

html[data-theme="dark"] .timeline-assinatura-ios__badge--recusou {
    color: #ff8a82;
}

.timeline-assinatura-ios__meta {
    margin: 0.18rem 0 0;
    padding: 0;
    font-size: 0.65rem;
    line-height: 1.35;
    color: var(--text-soft);
    font-weight: 400;
    font-variant-numeric: tabular-nums;
}

.timeline-assinatura-ios__meta-bit {
    display: inline;
}

.timeline-assinatura-ios__meta-sep {
    display: inline;
    margin: 0 0.2rem;
    opacity: 0.55;
    user-select: none;
}

.timeline-assinatura-ios__note {
    margin: 0.2rem 0 0;
    padding: 0;
    font-size: 0.64rem;
    line-height: 1.3;
    font-style: italic;
    color: var(--text-soft);
    opacity: 0.92;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}

.timeline-assinatura-chip {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.35rem 0.75rem;
    padding: 0.45rem 0.55rem;
    border-radius: 8px;
    font-size: 0.82rem;
    line-height: 1.35;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

html[data-theme="dark"] .timeline-assinatura-chip {
    background: rgba(58, 58, 60, 0.75);
    border-color: rgba(255, 255, 255, 0.06);
}

.timeline-assinatura-chip--pendente {
    border-left: 3px solid #ff9f0a;
}

.timeline-assinatura-chip--assinou {
    border-left: 3px solid #34c759;
}

.timeline-assinatura-chip--recusou {
    border-left: 3px solid #ff453a;
}

.timeline-assinatura-chip__who {
    font-weight: 600;
    color: var(--color-text);
    min-width: 0;
    word-break: break-word;
}

.timeline-assinatura-chip__meta {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    font-size: 0.78rem;
    color: var(--text-soft);
}

.timeline-assinatura-chip__badge {
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    padding: 0.12rem 0.4rem;
    border-radius: 999px;
}

.timeline-assinatura-chip__badge--pend {
    background: rgba(255, 159, 10, 0.2);
    color: #c77c00;
}

html[data-theme="dark"] .timeline-assinatura-chip__badge--pend {
    color: #ffcc66;
}

.timeline-assinatura-chip__badge--ok {
    background: rgba(52, 199, 89, 0.2);
    color: #248a3d;
}

html[data-theme="dark"] .timeline-assinatura-chip__badge--ok {
    color: #7ef29a;
}

.timeline-assinatura-chip__badge--no {
    background: rgba(255, 69, 58, 0.18);
    color: #c9342a;
}

html[data-theme="dark"] .timeline-assinatura-chip__badge--no {
    color: #ff8a82;
}

.timeline-assinatura-chip__time {
    font-variant-numeric: tabular-nums;
}

.timeline-assinatura-chip__note {
    flex-basis: 100%;
    font-style: italic;
    opacity: 0.9;
}

.timeline-assinatura-acoes--doc {
    margin-top: 0.65rem;
    padding: 0.65rem 0.85rem;
    border-radius: 10px;
}

.timeline-assinatura-acoes--doc .timeline-assinatura-acoes__label {
    margin: 0 0 0.5rem;
    font-size: 0.85rem;
    line-height: 1.45;
}

/* Modal solicitar assinatura (documento) — sheet iOS */
/* Acima do visualizador PDF (.pdf-viewer-modal = 11000) quando aberto a partir dele */
.proc-assinatura-modal-wrap.modal-overlay {
    z-index: 13000;
}

.proc-assinatura-modal-dialog {
    max-width: 440px;
}

/* Um único “risco” de arraste: o .proc-assinatura-sheet__handle (o ::before global do header duplicava o efeito). */
.proc-assinatura-sheet .modal-header::before {
    display: none;
}

.proc-assinatura-sheet .modal-header {
    padding-top: 0.35rem;
    cursor: grab;
}

.proc-assinatura-sheet .modal-header:active {
    cursor: grabbing;
}

.proc-assinatura-sheet .modal-close {
    cursor: pointer;
}

.proc-assinatura-sheet__handle {
    width: 36px;
    height: 5px;
    border-radius: 3px;
    background: rgba(0, 0, 0, 0.2);
    margin: 0.65rem auto 0;
    flex-shrink: 0;
    cursor: grab;
    touch-action: none;
}

.proc-assinatura-sheet__handle:active {
    cursor: grabbing;
}

html[data-theme="dark"] .proc-assinatura-sheet__handle {
    background: rgba(255, 255, 255, 0.28);
}

/* Alvo do documento / movimentação — large title + hierarquia SF (HIG) */
.proc-assinatura-doc-banner {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    margin: 0 0 0.85rem;
    padding: 0.72rem 0.85rem;
    border-radius: 16px;
    background: linear-gradient(
        145deg,
        rgba(255, 255, 255, 0.82) 0%,
        rgba(242, 242, 247, 0.95) 100%
    );
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}

html[data-theme="dark"] .proc-assinatura-doc-banner {
    background: linear-gradient(
        145deg,
        rgba(58, 58, 60, 0.72) 0%,
        rgba(44, 44, 46, 0.88) 100%
    );
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 6px 28px rgba(0, 0, 0, 0.35);
}

.proc-assinatura-doc-banner__kind {
    display: block;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--ios-blue, #007aff);
    line-height: 1.2;
}

.proc-assinatura-doc-banner__name {
    display: block;
    font-size: 1.05rem;
    font-weight: 650;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: var(--color-text);
    word-break: break-word;
}

.proc-assinatura-help-choose {
    margin: 0 0 1rem;
    font-size: 0.88rem;
    line-height: 1.45;
    color: var(--text-soft, #8e8e93);
}

.proc-assinatura-choice-row {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.proc-assinatura-choice-row .btn {
    border-radius: 14px;
    font-weight: 600;
    padding: 0.62rem 1rem;
    width: 100%;
    justify-content: center;
}

.proc-assinatura-btn-assinar-eu {
    box-shadow: 0 4px 18px rgba(0, 122, 255, 0.25);
}

.proc-assinatura-btn-solicitar-outrem {
    border-width: 1.5px;
    border-radius: 14px;
    font-weight: 600;
}

.proc-assinatura-modal-actions--choose-only {
    margin-top: 1.1rem;
    justify-content: center;
}

.proc-assinatura-help-solicitar {
    margin: 0 0 0.65rem;
    padding: 0.5rem 0.62rem;
    font-size: 0.81rem;
    line-height: 1.4;
    color: var(--text-soft, #8e8e93);
    border-radius: 12px;
    background: rgba(142, 142, 147, 0.1);
    border: none;
}

html[data-theme="dark"] .proc-assinatura-help-solicitar {
    background: rgba(142, 142, 147, 0.15);
    color: rgba(235, 235, 245, 0.72);
}

.proc-assinatura-help-solicitar strong {
    color: var(--color-text);
    font-weight: 600;
}

html[data-theme="dark"] .proc-assinatura-help-solicitar strong {
    color: rgba(255, 255, 255, 0.92);
}

.proc-assinatura-search-wrap {
    position: relative;
    display: flex;
    align-items: center;
    margin-bottom: 0.15rem;
}

.proc-assinatura-search-wrap__ico {
    position: absolute;
    left: 0.95rem;
    font-size: 0.78rem;
    color: var(--text-soft, #8e8e93);
    pointer-events: none;
    opacity: 0.85;
}

.proc-assinatura-search-ios {
    border-radius: 999px !important;
    border: none !important;
    background: rgba(142, 142, 147, 0.14) !important;
    padding: 0.55rem 1rem 0.55rem 2.35rem !important;
    font-size: 0.92rem;
}

html[data-theme="dark"] .proc-assinatura-search-ios {
    background: rgba(142, 142, 147, 0.22) !important;
}

.proc-assinatura-doc-line {
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.35rem;
    word-break: break-word;
}

.proc-assinatura-help {
    margin-bottom: 0.75rem;
    line-height: 1.45;
}

.proc-assinatura-results {
    max-height: 220px;
    overflow-y: auto;
    margin-top: 0.5rem;
}

.proc-assinatura-pick {
    display: block;
    width: 100%;
    text-align: left;
    margin: 0.3rem 0;
    border-radius: 10px;
    padding: 0.45rem 0.55rem;
}

.proc-assinatura-pick small {
    opacity: 0.85;
}

.proc-assinatura-pick--in-list {
    opacity: 0.72;
    pointer-events: none;
}

.proc-assinatura-pick__added {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.65rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #34c759;
}

html[data-theme="dark"] .proc-assinatura-pick__added {
    color: #7ef29a;
}

.proc-assinatura-selected-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.35rem;
}

.proc-assinatura-selected-chip {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    max-width: 100%;
    padding: 0.2rem 0.35rem 0.2rem 0.5rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 500;
    line-height: 1.25;
    background: rgba(0, 122, 255, 0.12);
    border: 1px solid rgba(0, 122, 255, 0.2);
    color: var(--color-text);
}

html[data-theme="dark"] .proc-assinatura-selected-chip {
    background: rgba(10, 132, 255, 0.22);
    border-color: rgba(10, 132, 255, 0.35);
}

.proc-assinatura-selected-chip__text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 200px;
}

.proc-assinatura-selected-chip__rm {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.06);
    color: inherit;
    cursor: pointer;
    font-size: 0.55rem;
}

html[data-theme="dark"] .proc-assinatura-selected-chip__rm {
    background: rgba(255, 255, 255, 0.12);
}

.proc-assinatura-pick-summary--multi {
    margin-top: 0.5rem;
}

.proc-assinatura-clear-all {
    margin-top: 0.4rem;
    padding: 0 !important;
    font-size: 0.78rem !important;
}

.proc-assinatura-pick-summary {
    margin-top: 0.75rem;
    padding: 0.55rem 0.65rem;
    border-radius: 10px;
    border: 1px solid var(--glass-border);
    background: rgba(0, 122, 255, 0.06);
}

.proc-assinatura-pick-summary__label {
    display: block;
    font-size: 0.65rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-soft);
    margin-bottom: 0.25rem;
}

.proc-assinatura-pick-summary__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
}

.proc-assinatura-pick-summary__name {
    min-width: 0;
    word-break: break-word;
}

.proc-assinatura-modal-actions {
    display: flex;
    gap: 0.75rem;
    justify-content: flex-end;
    margin-top: 1rem;
}

/* Cartões de ato / audiência / prazo — estilo iOS (processo detalhe) */
.proc-tab-stack {
    display: flex;
    flex-direction: column;
    gap: 0.62rem;
}

.proc-ios-ato-card {
    border-radius: 16px;
    padding: 0.82rem 1rem;
    text-align: left;
    border: 1px solid var(--glass-border);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
}

.proc-ios-ato-card--tab {
    margin-bottom: 0;
}

.proc-ios-ato-card__head {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.4rem 0.75rem;
    margin-bottom: 0.62rem;
    padding-bottom: 0.55rem;
    border-bottom: 0.5px solid var(--separator-color);
}

.proc-ios-ato-card__head-actions {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
}

.proc-ios-ato-edit {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    padding: 0;
    border: none;
    border-radius: 10px;
    background: rgba(0, 122, 255, 0.12);
    color: #007aff;
    cursor: pointer;
    transition: background 0.18s ease, transform 0.12s ease;
}

.proc-ios-ato-edit:hover {
    background: rgba(0, 122, 255, 0.2);
}

.proc-ios-ato-edit:active {
    transform: scale(0.96);
}

[data-theme="dark"] .proc-ios-ato-edit {
    background: rgba(10, 132, 255, 0.22);
    color: #0a84ff;
}

[data-theme="dark"] .proc-ios-ato-edit:hover {
    background: rgba(10, 132, 255, 0.32);
}

.proc-ios-ato-edit .fa-regular,
.proc-ios-ato-edit .fa-solid {
    font-size: 0.95rem;
}

.proc-ios-ato-kind {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--color-primary);
}

.proc-ios-ato-card--audiencia .proc-ios-ato-kind {
    color: #af52de;
}

[data-theme="dark"] .proc-ios-ato-card--audiencia .proc-ios-ato-kind {
    color: #bf5af2;
}

/* Bloco principal data/hora — aba Audiências (iOS: hierarquia forte, System Blue) */
.proc-ios-audiencia-hero {
    display: flex;
    align-items: center;
    gap: 0.85rem;
    margin: 0 0 0.85rem 0;
    padding: 1rem 1.05rem;
    border-radius: 14px;
    background: rgba(0, 122, 255, 0.09);
    border: 0.5px solid rgba(0, 122, 255, 0.22);
}

[data-theme="dark"] .proc-ios-audiencia-hero {
    background: rgba(10, 132, 255, 0.16);
    border-color: rgba(10, 132, 255, 0.3);
}

.proc-ios-audiencia-hero__icon {
    flex-shrink: 0;
    width: 2.65rem;
    height: 2.65rem;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.65);
    color: #007aff;
    font-size: 1.2rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .proc-ios-audiencia-hero__icon {
    background: rgba(44, 44, 46, 0.9);
    color: #0a84ff;
    box-shadow: none;
}

.proc-ios-audiencia-hero__main {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
    min-width: 0;
}

.proc-ios-audiencia-hero__date {
    display: block;
    margin: 0;
    font-size: clamp(1.28rem, 4.2vw, 1.55rem);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.15;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.proc-ios-audiencia-hero__time {
    font-size: 1.12rem;
    font-weight: 750;
    color: var(--ios-blue, #007aff);
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}

.proc-ios-audiencia-hero__badge {
    display: inline-block;
    margin-top: 0.35rem;
    font-size: 0.68rem;
    font-weight: 650;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-soft);
}

/* Audiência já ocorreu — tratamento secundário (System Gray) */
.proc-ios-ato-card--audiencia-passada .proc-ios-audiencia-hero {
    background: rgba(142, 142, 147, 0.12);
    border-color: rgba(142, 142, 147, 0.32);
}

[data-theme="dark"] .proc-ios-ato-card--audiencia-passada .proc-ios-audiencia-hero {
    background: rgba(72, 72, 74, 0.55);
    border-color: rgba(99, 99, 102, 0.55);
}

.proc-ios-ato-card--audiencia-passada .proc-ios-audiencia-hero__time {
    color: var(--text-soft);
}

.proc-ios-ato-card--audiencia-passada .proc-ios-audiencia-hero__date {
    color: var(--text-soft);
}

.proc-ios-ato-card--audiencia-passada .proc-ios-audiencia-hero__icon {
    background: rgba(142, 142, 147, 0.2);
    color: var(--text-soft);
    box-shadow: none;
}

.proc-ios-ato-card--audiencia-passada .proc-ios-ato-kind {
    color: #636366 !important;
}

[data-theme="dark"] .proc-ios-ato-card--audiencia-passada .proc-ios-ato-kind {
    color: #98989d !important;
}

.proc-ios-ato-card--audiencia-passada {
    opacity: 0.97;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.04);
}

.proc-ios-ato-card--audiencia-passada .proc-ios-kv-value,
.proc-ios-ato-card--audiencia-passada .proc-ios-ato-body {
    color: var(--text-soft);
}

.proc-ios-kv-value--audiencia-datetime {
    font-size: 1.12rem;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
    line-height: 1.35;
}

.proc-ios-kv-value__time {
    color: var(--ios-blue, #007aff);
    font-weight: 750;
    white-space: nowrap;
}

.proc-ios-ato-card--audiencia-passada .proc-ios-kv-value__time {
    color: var(--text-soft);
}

.proc-ios-ato-card--audiencia-passada .proc-ios-kv-value--audiencia-datetime {
    color: var(--text-soft);
    font-weight: 700;
}

.proc-ios-kv-note {
    display: block;
    margin-top: 0.3rem;
    font-size: 0.72rem;
    font-weight: 650;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-soft);
}

.proc-ios-kv-note--past {
    color: #8e8e93;
}

[data-theme="dark"] .proc-ios-kv-note--past {
    color: #98989d;
}

.proc-ios-ato-card--demanda .proc-ios-ato-kind {
    color: var(--color-accent);
}

/* Demanda / prazo: hero, countdown e fluxo ciência → cumprimento */
.proc-ios-ato-card__head--demanda-tab {
    margin-bottom: 0.35rem;
}

.proc-demanda-hero {
    margin: 0.15rem 0 1rem;
    padding: 1rem 1.15rem 1.1rem;
    border-radius: 16px;
    background: linear-gradient(
        135deg,
        rgba(255, 149, 0, 0.12) 0%,
        rgba(0, 122, 255, 0.08) 50%,
        rgba(88, 86, 214, 0.06) 100%
    );
    border: 1px solid rgba(255, 149, 0, 0.22);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .proc-demanda-hero {
    background: linear-gradient(
        135deg,
        rgba(255, 159, 10, 0.14) 0%,
        rgba(10, 132, 255, 0.1) 55%,
        rgba(94, 92, 230, 0.08) 100%
    );
    border-color: rgba(255, 159, 10, 0.28);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.35);
}

.proc-demanda-hero--compact {
    padding: 0.85rem 0.95rem 0.95rem;
    margin-bottom: 0.85rem;
}

.proc-demanda-hero--past {
    opacity: 0.92;
    filter: saturate(0.88);
}

.proc-demanda-hero__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.45rem;
}

.proc-demanda-hero__eyebrow {
    font-size: 0.68rem;
    font-weight: 750;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-soft);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.proc-demanda-hero__pill {
    font-size: 0.65rem;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    background: var(--surface-level-2);
    color: var(--text-soft);
}

.proc-demanda-hero__pill--past {
    background: rgba(142, 142, 147, 0.25);
    color: var(--text-soft);
}

.proc-demanda-hero__pill--ok {
    background: rgba(52, 199, 89, 0.22);
    color: #1e7e34;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

[data-theme="dark"] .proc-demanda-hero__pill--ok {
    background: rgba(52, 199, 89, 0.28);
    color: #5bd37f;
}

.proc-demanda-hero--concluida {
    border-color: rgba(52, 199, 89, 0.35);
    background: linear-gradient(
        135deg,
        rgba(52, 199, 89, 0.12) 0%,
        rgba(0, 122, 255, 0.06) 100%
    );
}

[data-theme="dark"] .proc-demanda-hero--concluida {
    border-color: rgba(52, 199, 89, 0.4);
    background: linear-gradient(
        135deg,
        rgba(52, 199, 89, 0.14) 0%,
        rgba(10, 132, 255, 0.08) 100%
    );
}

.proc-demanda-hero__datetime {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 0.85rem;
    margin: 0 0 0.65rem;
    line-height: 1.05;
}

.proc-demanda-hero__date {
    font-size: clamp(1.55rem, 3.5vw, 2.05rem);
    font-weight: 820;
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
    color: var(--color-text);
}

.proc-demanda-hero__time {
    font-size: 1.15rem;
    font-weight: 750;
    font-variant-numeric: tabular-nums;
    color: var(--ios-blue, #007aff);
}

.proc-demanda-hero--past .proc-demanda-hero__time {
    color: var(--text-soft);
}

.proc-demanda-hero__sem-prazo {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-soft);
}

.proc-demanda-countdown {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: 0.55rem 0.65rem;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.45);
    border: 1px solid rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .proc-demanda-countdown {
    background: rgba(28, 28, 30, 0.55);
    border-color: rgba(255, 255, 255, 0.08);
}

.proc-demanda-countdown__label {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: var(--text-soft);
}

.proc-demanda-countdown__value {
    font-size: 0.98rem;
    font-weight: 750;
    font-variant-numeric: tabular-nums;
    color: var(--color-accent);
    line-height: 1.35;
}

.proc-demanda-countdown--urgent .proc-demanda-countdown__value {
    color: var(--color-danger);
}

.proc-demanda-countdown--expired-static {
    margin: 0;
    font-size: 0.82rem;
    font-weight: 650;
    color: var(--text-soft);
    line-height: 1.45;
}

.proc-demanda-countdown--cumprida {
    border-color: rgba(52, 199, 89, 0.35);
    background: rgba(52, 199, 89, 0.08);
}

[data-theme="dark"] .proc-demanda-countdown--cumprida {
    background: rgba(52, 199, 89, 0.12);
    border-color: rgba(52, 199, 89, 0.4);
}

.proc-demanda-flow--concluida {
    border-color: rgba(52, 199, 89, 0.22);
}

.proc-demanda-flow__hint--done {
    color: var(--color-text);
    margin-bottom: 0.65rem;
}

.proc-ios-ato-card--demanda-concluida .proc-ios-ato-kind {
    color: var(--color-success, #34c759);
}

.proc-demanda-countdown__sub {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.74rem;
    font-weight: 550;
    color: var(--text-soft);
    line-height: 1.4;
}

/* Demanda concluída: cartão baixo + acordeões */
.proc-demanda-done-shell {
    margin: 0.2rem 0 0.85rem;
}

.proc-demanda-done-shell--tab {
    margin-bottom: 0.65rem;
}

.proc-demanda-done-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 1rem;
    padding: 0.55rem 0.65rem;
    border-radius: 12px;
    background: var(--surface-level-2);
    border: 1px solid rgba(52, 199, 89, 0.22);
}

.proc-demanda-done-bar__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    font-size: 0.78rem;
    color: var(--text-soft);
    line-height: 1.35;
}

.proc-demanda-done-bar__bit strong {
    font-weight: 750;
    color: var(--color-text);
    font-variant-numeric: tabular-nums;
}

.proc-demanda-done-bar__sep {
    opacity: 0.55;
}

.proc-demanda-done-accordions {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    margin-top: 0.5rem;
}

.proc-demanda-disk {
    border-radius: 12px;
    border: 1px solid rgba(0, 0, 0, 0.08);
    background: var(--surface-level-1, rgba(255, 255, 255, 0.45));
    overflow: hidden;
}

[data-theme="dark"] .proc-demanda-disk {
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(44, 44, 46, 0.45);
}

.proc-demanda-disk__summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 0.75rem;
    font-size: 0.8rem;
    font-weight: 700;
    color: var(--color-text);
    background: transparent;
    transition: background 0.15s ease;
}

.proc-demanda-disk__summary::-webkit-details-marker {
    display: none;
}

.proc-demanda-disk__summary:hover {
    background: rgba(0, 0, 0, 0.04);
}

[data-theme="dark"] .proc-demanda-disk__summary:hover {
    background: rgba(255, 255, 255, 0.06);
}

.proc-demanda-disk[open] .proc-demanda-disk__summary {
    border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .proc-demanda-disk[open] .proc-demanda-disk__summary {
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

.proc-demanda-disk__body {
    padding: 0.65rem 0.75rem 0.75rem;
}

.proc-demanda-disk__body .proc-demanda-hero {
    margin-top: 0;
}

.proc-demanda-disk__body .proc-demanda-flow {
    margin-bottom: 0.35rem;
}

.proc-demanda-movs-stack {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.proc-demanda-mov-card {
    padding: 0.65rem 0.75rem;
    border-radius: 12px;
    margin: 0;
}

.proc-demanda-mov-card__head {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    justify-content: space-between;
    gap: 0.35rem 0.75rem;
    margin-bottom: 0.35rem;
}

.proc-demanda-mov-card__evento {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 750;
    color: var(--color-text);
    line-height: 1.25;
}

.proc-demanda-mov-card__when {
    font-size: 0.72rem;
    font-weight: 650;
    color: var(--text-soft);
    font-variant-numeric: tabular-nums;
}

.proc-demanda-mov-card__autor {
    margin: 0 0 0.4rem;
    font-size: 0.76rem;
    color: var(--text-soft);
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.proc-demanda-mov-card__desc {
    font-size: 0.8rem;
    line-height: 1.45;
    color: var(--color-text);
    margin-bottom: 0.45rem;
}

.proc-demanda-mov-card__anexos-label {
    display: block;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    margin-bottom: 0.35rem;
}

.proc-demanda-mov-card__file-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
}

.proc-demanda-movs-extras {
    margin: 0.5rem 0 0;
}

.proc-demanda-btn-timeline {
    font-size: 0.78rem;
    font-weight: 650;
    padding: 0.4rem 0.75rem;
}

.proc-demanda-movs-empty {
    margin: 0;
    font-size: 0.8rem;
    color: var(--text-soft);
}

.proc-demanda-flow {
    margin: 0.5rem 0 1rem;
    padding: 0.95rem 1rem;
    border-radius: 14px;
    background: var(--surface-level-2);
    border: 1px solid rgba(0, 0, 0, 0.05);
}

[data-theme="dark"] .proc-demanda-flow {
    border-color: rgba(255, 255, 255, 0.07);
}

.proc-demanda-flow--compact {
    padding: 0.75rem 0.85rem;
    margin-bottom: 0.75rem;
}

.proc-demanda-flow__hint {
    margin: 0 0 0.85rem;
    font-size: 0.8rem;
    line-height: 1.5;
    color: var(--color-text);
}

.proc-demanda-steps {
    list-style: none;
    margin: 0 0 0.85rem;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.55rem;
}

.proc-demanda-step {
    display: flex;
    gap: 0.65rem;
    align-items: flex-start;
    padding: 0.55rem 0.65rem;
    border-radius: 12px;
    background: var(--surface-level-1, rgba(255, 255, 255, 0.5));
    border: 1px solid transparent;
}

[data-theme="dark"] .proc-demanda-step {
    background: rgba(44, 44, 46, 0.65);
}

.proc-demanda-step__num {
    flex-shrink: 0;
    width: 1.65rem;
    height: 1.65rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    font-size: 0.8rem;
    font-weight: 800;
    background: var(--text-soft);
    color: var(--surface-level-1, #fff);
    opacity: 0.55;
}

.proc-demanda-step--current {
    border-color: rgba(0, 122, 255, 0.35);
    box-shadow: 0 0 0 1px rgba(0, 122, 255, 0.12);
}

.proc-demanda-step--current .proc-demanda-step__num {
    opacity: 1;
    background: var(--ios-blue, #007aff);
    color: #fff;
}

.proc-demanda-step--done .proc-demanda-step__num {
    opacity: 1;
    background: var(--color-success, #34c759);
    color: #fff;
}

.proc-demanda-step--done {
    border-color: rgba(52, 199, 89, 0.25);
}

.proc-demanda-step--pending {
    opacity: 0.88;
}

.proc-demanda-step--blocked {
    border-color: rgba(142, 142, 147, 0.35);
    opacity: 0.92;
}

.proc-demanda-step--blocked .proc-demanda-step__num {
    background: #8e8e93;
    opacity: 0.75;
    color: #fff;
}

.proc-demanda-step__title {
    display: block;
    font-size: 0.82rem;
    font-weight: 780;
    margin-bottom: 0.15rem;
}

.proc-demanda-step__detail {
    font-size: 0.74rem;
    font-weight: 550;
    color: var(--text-soft);
    line-height: 1.35;
}

.proc-demanda-flow__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.proc-demanda-flow__btn-ciencia,
.proc-demanda-btn-cumprir {
    font-weight: 700;
}

.proc-demanda-flow__done {
    margin: 0;
    font-size: 0.8rem;
    font-weight: 650;
    color: var(--color-success, #34c759);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.proc-demanda-tab-meta {
    margin-top: 0.25rem;
}

.modal-demanda-cumprimento-banner {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 0.9rem 1rem;
    margin-bottom: 1rem;
    border-radius: 14px;
    background: linear-gradient(
        120deg,
        rgba(255, 149, 0, 0.14),
        rgba(0, 122, 255, 0.1)
    );
    border: 1px solid rgba(255, 149, 0, 0.28);
}

[data-theme="dark"] .modal-demanda-cumprimento-banner {
    background: linear-gradient(
        120deg,
        rgba(255, 159, 10, 0.16),
        rgba(10, 132, 255, 0.12)
    );
    border-color: rgba(255, 159, 10, 0.32);
}

.modal-demanda-cumprimento-banner__icon {
    flex-shrink: 0;
    width: 2.35rem;
    height: 2.35rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.55);
    color: var(--color-accent);
    font-size: 1.1rem;
}

[data-theme="dark"] .modal-demanda-cumprimento-banner__icon {
    background: rgba(44, 44, 46, 0.9);
}

.modal-demanda-cumprimento-banner__text {
    min-width: 0;
}

.modal-demanda-cumprimento-banner__text strong {
    display: block;
    font-size: 0.88rem;
    margin-bottom: 0.25rem;
}

.modal-demanda-cumprimento-banner__text p {
    margin: 0;
    font-size: 0.78rem;
    line-height: 1.45;
    color: var(--color-text);
}

.proc-ios-ato-card--notificacao .proc-ios-ato-kind {
    color: var(--color-primary);
}

.proc-ios-ato-card--status .proc-ios-ato-kind {
    color: var(--color-success);
}

.proc-ios-ato-kind .fas {
    font-size: 0.95em;
    font-weight: 900;
}

.proc-ios-ato-stamp {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-soft);
    white-space: nowrap;
}

.proc-ios-ato-stamp--alert {
    color: var(--color-danger);
    font-variant-numeric: tabular-nums;
}

.proc-ios-kv-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 0.45rem 1rem;
    margin-bottom: 0.55rem;
}

.proc-ios-kv-grid--inline {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.35rem 0.85rem;
    margin-bottom: 0.4rem;
}

.proc-ios-kv--emphasis .proc-ios-kv-value {
    font-weight: 700;
}

.proc-ios-dest-list {
    margin: 0.25rem 0 0 1.05rem;
    padding: 0;
    list-style: disc;
}

.proc-ios-kv-label {
    display: block;
    font-size: 0.65rem;
    font-weight: 650;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    margin-bottom: 0.25rem;
}

.proc-ios-kv-value {
    font-size: 0.95rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.4;
}

.proc-ios-kv-value--alert {
    color: var(--color-danger);
    font-size: 1.05rem;
}

.proc-ios-ato-body {
    font-size: 0.875rem;
    line-height: 1.45;
    color: var(--color-text);
}

.proc-ios-ato-target {
    margin-top: 0.48rem;
    padding: 0.52rem 0.72rem;
    border-radius: 12px;
    background: var(--surface-level-2);
    border: 0.5px solid var(--glass-border);
}

.proc-ios-ato-target--compact {
    margin-top: 0.4rem;
    padding: 0.45rem 0.62rem;
}

.proc-ios-dest-list--compact {
    margin: 0.18rem 0 0 1rem !important;
}

.proc-ios-dest-list--compact li {
    margin: 0.08rem 0 !important;
    font-size: 0.82rem;
    line-height: 1.35;
}

.proc-ios-ato-footer {
    margin-top: 0.58rem;
    padding-top: 0.55rem;
    border-top: 0.5px solid var(--separator-color);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
}

.proc-ios-ato-footer--compact {
    margin-top: 0.5rem;
    padding-top: 0.48rem;
}

.proc-ios-ato-issuer {
    font-size: 0.78rem;
    color: var(--text-soft);
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.proc-ios-ato-issuer .fas {
    font-weight: 900;
    opacity: 0.85;
}

.proc-ios-ciencia-ok {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-success);
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.proc-ios-btn-ciencia {
    border-radius: 999px !important;
    padding: 0.38rem 1rem !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

.proc-ios-ciencia-list {
    margin-top: 0.58rem;
    padding: 0.52rem 0.72rem;
    border-radius: 12px;
    display: grid;
    gap: 0.48rem;
    border: 0.5px solid var(--glass-border);
    background: var(--surface-level-2);
}

.proc-ios-ciencia-list__block {
    font-size: 0.78rem;
}

.proc-ios-ciencia-list__label {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-weight: 700;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-success);
    margin-bottom: 0.22rem;
}

.proc-ios-ciencia-list__block--pending .proc-ios-ciencia-list__label {
    color: var(--color-warning, #ff9500);
}

.proc-ios-ciencia-list__names {
    margin: 0;
    padding-left: 1.15rem;
    color: var(--color-text);
    line-height: 1.5;
}

.proc-ios-ciencia-list__notice {
    margin: 0 0 0.12rem 0;
    padding: 0.45rem 0.55rem;
    font-size: 0.76rem;
    line-height: 1.45;
    color: var(--text-soft);
    font-weight: 500;
    border-radius: 10px;
    background: rgba(142, 142, 147, 0.14);
}

.proc-ios-ciencia-list__notice strong {
    color: var(--color-text);
    font-weight: 700;
}

[data-theme="dark"] .proc-ios-ciencia-list__notice {
    background: rgba(72, 72, 74, 0.55);
}

.proc-ios-ciencia-list--encerrada .proc-ios-ciencia-list__block--pending .proc-ios-ciencia-list__label {
    color: var(--text-soft);
}

.proc-ios-ato-card--demanda-passada {
    opacity: 0.97;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.04);
}

.proc-ios-ato-card--demanda-passada .proc-ios-ato-kind {
    color: #636366 !important;
}

[data-theme="dark"] .proc-ios-ato-card--demanda-passada .proc-ios-ato-kind {
    color: #98989d !important;
}

.proc-ios-ato-card--demanda-passada .proc-ios-ato-stamp--alert {
    color: var(--text-soft);
    font-weight: 600;
}

.proc-tab-empty {
    border-radius: 16px;
    padding: 2.25rem 1.5rem;
    text-align: center;
    border: 1px solid var(--glass-border);
}

.proc-tab-empty__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    margin-bottom: 1rem;
    border-radius: 14px;
    background: var(--surface-level-2);
    color: var(--text-soft);
    font-size: 1.35rem;
}

.proc-tab-empty__icon .fas {
    font-weight: 900;
}

.proc-tab-empty__title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-text);
    margin: 0 0 0.35rem 0;
    letter-spacing: -0.02em;
}

.proc-tab-empty__sub {
    font-size: 0.88rem;
    color: var(--text-soft);
    line-height: 1.45;
    margin: 0;
    max-width: 22rem;
    margin-left: auto;
    margin-right: auto;
}

.proc-notice-box {
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
    padding: 1rem 1.15rem;
    border-radius: 14px;
    font-size: 0.88rem;
    color: var(--color-text);
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
    margin-bottom: 1.5rem;
    line-height: 1.45;
}

.proc-notice-box__icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary);
}

.proc-notice-box__icon .fas {
    font-weight: 900;
    font-size: 1rem;
}

.proc-notice-box__text {
    margin: 0;
    color: var(--text-soft);
    font-size: 0.88rem;
}

@media (max-width: 768px) {
    .proc-partes-grid {
        grid-template-columns: 1fr;
    }
}

/* Formulário cargo: bloco responsável geral (estilo Ajustes iOS) */
.cargo-form-resp-card {
    background: var(--surface-level-2);
    border: 0.5px solid var(--separator-color);
    border-radius: 14px;
    padding: 0.7rem 0.9rem;
    margin-bottom: 1.25rem;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.03);
}

html[data-theme="dark"] .cargo-form-resp-card {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.18);
}

.cargo-form-resp-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
}

.cargo-form-resp-icon {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: rgba(255, 149, 0, 0.14);
    color: var(--color-accent, #ff9500);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
}

.cargo-form-resp-copy {
    flex: 1;
    min-width: 0;
}

.cargo-form-resp-title {
    margin: 0 0 0.15rem 0;
    font-size: 0.9rem;
    font-weight: 650;
    letter-spacing: -0.015em;
    color: var(--color-text);
}

.cargo-form-resp-hint {
    margin: 0;
    font-size: 0.76rem;
    line-height: 1.4;
    color: var(--text-soft);
}

.cargo-form-resp-hint strong {
    color: var(--color-text);
    font-weight: 600;
}

.cargo-form-resp-row .ios-switch {
    align-self: center;
}

/* iOS Toggle Switch */
.ios-switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 30px;
    flex-shrink: 0;
}

/* Área clicável = track inteiro (input 0×0 quebrava o toque no modal) */
.ios-switch input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    opacity: 0;
    z-index: 2;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
}

.ios-switch .slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    pointer-events: none;
    background-color: #E9E9EA;
    transition: .3s;
    border-radius: 34px;
}
html[data-theme="dark"] .ios-switch .slider {
    background-color: #39393D;
}

.ios-switch .slider:before {
    position: absolute;
    content: "";
    height: 26px;
    width: 26px;
    left: 2px;
    bottom: 2px;
    background-color: white;
    transition: .3s;
    border-radius: 50%;
    box-shadow: 0 3px 8px rgba(0,0,0,0.15), 0 3px 1px rgba(0,0,0,0.06);
    pointer-events: none;
}

.ios-switch input:checked + .slider {
    background-color: var(--color-success); /* #34C759 */
}

.ios-switch input:checked + .slider:before {
    transform: translateX(20px);
}

/* Animations */
@keyframes pulseDot {
    0% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.5); opacity: 0.5; }
    100% { transform: scale(1); opacity: 1; }
}

.pulse-dot {
    animation: pulseDot 2s infinite;
}

/* iOS Style Lists */
.ios-list-group {
    background: var(--surface-level-1);
    border-radius: 12px;
    overflow: hidden;
    margin-bottom: 1.5rem;
}

.ios-list-item {
    display: flex;
    align-items: center;
    padding: 1rem 1.2rem;
    background: var(--surface-level-1);
    border-bottom: 0.5px solid var(--separator-color);
    color: var(--color-text);
    transition: background 0.2s ease;
}

.ios-list-item:last-child {
    border-bottom: none;
}

.ios-list-item-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    margin-right: 1rem;
    object-fit: cover;
    background: var(--surface-level-2);
}

.ios-list-item-content {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.ios-list-item-title {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 0.2rem;
}

.ios-list-item-subtitle {
    font-size: 0.85rem;
    color: var(--text-soft);
}

.ios-list-item-action {
    margin-left: 1rem;
}

/* Cartão de sentença (ato judicial): coluna única — evita flex horizontal do .ios-list-item */
.ios-list-item.sentenca-imputacao-card {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0.75rem;
    padding: 1rem 1.1rem;
    border-radius: 14px;
    background: var(--surface-level-2);
    border: 0.5px solid var(--glass-border);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    border-bottom: 0.5px solid var(--glass-border);
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__head {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__reu {
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-text);
    line-height: 1.25;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__norma {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.35;
    letter-spacing: 0.01em;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__detalhe {
    font-size: 0.84rem;
    color: var(--text-soft);
    line-height: 1.45;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__fase label,
.ios-list-item.sentenca-imputacao-card .sentenca-card__obs-block label {
    font-size: 0.78rem;
    color: var(--text-soft);
    display: block;
    margin-bottom: 0.28rem;
    font-weight: 500;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__fase select {
    width: 100%;
    border-radius: 10px;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__pena-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__pena-grid .form-group-mini {
    min-width: 0;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__pena-grid input {
    width: 100%;
    border-radius: 10px;
}

.ios-list-item.sentenca-imputacao-card .sentenca-card__obs-block textarea {
    width: 100%;
    border-radius: 10px;
    min-height: 3.25rem;
    resize: vertical;
}

@media (max-width: 520px) {
    .ios-list-item.sentenca-imputacao-card .sentenca-card__pena-grid {
        grid-template-columns: 1fr;
    }
}

.form-control.sentenca-campo-sugerido {
    border-color: color-mix(in srgb, var(--ios-blue, #007aff) 45%, var(--glass-border));
    background: color-mix(in srgb, var(--ios-blue, #007aff) 6%, var(--surface-level-1));
}

/* ——— Dashboard do Órgão ——— */
.org-dash-main {
    max-width: 1400px;
    margin: 0 auto;
    padding-bottom: 2.5rem;
}

.org-dash-hero {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1.25rem;
    padding: 1.5rem 1.75rem;
    margin-bottom: 1.25rem;
}

.org-dash-logo {
    width: 72px;
    height: 72px;
    object-fit: contain;
    border-radius: 18px;
    background: var(--surface-level-2);
    padding: 0.35rem;
}

.org-dash-logo-fallback {
    width: 72px;
    height: 72px;
    border-radius: 18px;
    background: linear-gradient(145deg, var(--color-primary), var(--color-secondary));
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.75rem;
}

.org-dash-title {
    margin-bottom: 0.15rem;
    font-size: 1.75rem;
    font-weight: 700;
    letter-spacing: -0.02em;
}

.org-dash-meta {
    font-size: 0.9rem;
    color: var(--text-soft);
    margin-top: 0.35rem;
}

.org-dash-meta strong {
    color: var(--color-text);
}

/* Galeria horizontal (órgão público; widget dentro do layout padrão do dashboard) */
.org-dash-gallery-scroller {
    margin: 0 -0.25rem;
    padding-bottom: 0.15rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.org-dash-gallery-track {
    display: flex;
    gap: 0.85rem;
    padding: 0.2rem 0.25rem 0.35rem;
    min-height: 100px;
    align-items: stretch;
}

.org-dash-gallery-card {
    flex: 0 0 auto;
    margin: 0;
    width: min(260px, 72vw);
    border-radius: 16px;
    overflow: hidden;
    background: var(--surface-level-2);
    border: 0.5px solid var(--separator-color);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05);
}

[data-theme="dark"] .org-dash-gallery-card {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
}

.org-dash-gallery-thumb-wrap {
    position: relative;
    aspect-ratio: 16 / 11;
    background: var(--surface-level-3, #e8e8ed);
}

.org-dash-gallery-thumb {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.org-dash-gallery-remove {
    position: absolute;
    top: 8px;
    right: 8px;
    margin: 0;
}

.org-dash-gallery-remove-btn {
    width: 32px;
    height: 32px;
    border-radius: 10px;
    border: none;
    background: rgba(0, 0, 0, 0.45);
    color: #fff;
    backdrop-filter: blur(12px);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    transition: background 0.15s ease;
}

.org-dash-gallery-remove-btn:hover {
    background: rgba(255, 59, 48, 0.92);
}

.org-dash-gallery-caption {
    margin: 0;
    padding: 0.5rem 0.65rem 0.65rem;
    font-size: 0.82rem;
    color: var(--text-soft);
    line-height: 1.35;
}

.org-dash-galeria-empty {
    align-self: center;
    padding: 0.75rem 0.5rem;
    margin: 0 auto;
    max-width: 28rem;
    text-align: center;
}

.org-dash-hero-actions {
    display: flex;
    gap: 0.75rem;
}

.org-dash-pill-btn {
    border-radius: 999px;
    padding: 0.45rem 1rem;
    font-weight: 600;
    font-size: 0.875rem;
}

/* CTA principal órgão — System Blue (iosdesign.md) */
.org-dash-admin-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem 1.15rem;
    border-radius: 14px;
    background: #007aff;
    color: #fff !important;
    font-weight: 600;
    font-size: 0.875rem;
    letter-spacing: -0.015em;
    text-decoration: none;
    border: none;
    box-shadow:
        0 2px 8px rgba(0, 122, 255, 0.28),
        0 4px 20px rgba(0, 122, 255, 0.12);
    transition:
        transform 0.16s ease,
        box-shadow 0.2s ease,
        filter 0.15s ease;
}

.org-dash-admin-cta:hover {
    filter: brightness(1.06);
    box-shadow:
        0 4px 14px rgba(0, 122, 255, 0.35),
        0 8px 28px rgba(0, 122, 255, 0.14);
    color: #fff !important;
    text-decoration: none;
}

.org-dash-admin-cta:active {
    transform: scale(0.97);
    filter: brightness(0.98);
}

.org-dash-admin-cta__icon {
    display: flex;
    font-size: 0.92rem;
    opacity: 0.95;
}

.org-dash-admin-cta__label {
    line-height: 1.2;
}

[data-theme="dark"] .org-dash-admin-cta {
    background: #0a84ff;
    box-shadow:
        0 2px 10px rgba(10, 132, 255, 0.35),
        0 4px 22px rgba(10, 132, 255, 0.14);
}

[data-theme="dark"] .org-dash-admin-cta:hover {
    box-shadow:
        0 4px 16px rgba(10, 132, 255, 0.42),
        0 8px 32px rgba(10, 132, 255, 0.16);
}

/* Pastas — CTA secundário (outline System Blue, iosdesign.md) */
.org-dash-pastas-cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.5rem 1.15rem;
    border-radius: 14px;
    background: rgba(0, 122, 255, 0.08);
    color: #007aff !important;
    font-weight: 600;
    font-size: 0.875rem;
    letter-spacing: -0.015em;
    text-decoration: none;
    border: 1.5px solid rgba(0, 122, 255, 0.45);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05);
    transition:
        background 0.15s ease,
        transform 0.12s ease;
}

.org-dash-pastas-cta:hover {
    background: rgba(0, 122, 255, 0.14);
    color: #007aff !important;
    text-decoration: none;
}

.org-dash-pastas-cta:active {
    transform: scale(0.97);
}

[data-theme="dark"] .org-dash-pastas-cta {
    background: rgba(10, 132, 255, 0.12);
    color: #0a84ff !important;
    border-color: rgba(10, 132, 255, 0.55);
}

[data-theme="dark"] .org-dash-pastas-cta:hover {
    background: rgba(10, 132, 255, 0.2);
    color: #0a84ff !important;
}

/* —— Pastas institucionais (órgão) — UI tipo iOS —— */
.org-pastas-page {
    max-width: min(920px, 100%);
    margin-inline: auto;
}

.org-pastas-breadcrumb {
    font-size: 0.78rem;
    color: var(--text-soft);
    padding: 0.55rem 0.85rem;
    border-radius: 12px;
    margin-bottom: 0.75rem;
}

.org-pastas-breadcrumb a {
    color: var(--color-primary);
    text-decoration: none;
    font-weight: 500;
}

.org-pastas-breadcrumb a:hover {
    text-decoration: underline;
}

.org-pastas-bc-sep {
    margin: 0 0.28rem;
    opacity: 0.45;
}

.org-pastas-bc-current {
    font-weight: 600;
    color: var(--color-text);
}

.org-pastas-hero {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.15rem;
    border-radius: 18px;
    margin-bottom: 1rem;
}

.org-pastas-hero__logo {
    border-radius: 12px;
    object-fit: cover;
}

.org-pastas-hero__icon {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary);
}

.org-pastas-large-title {
    margin: 0;
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.04em;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", sans-serif;
}

.org-pastas-caption {
    margin: 0.25rem 0 0;
    font-size: 0.85rem;
    color: var(--text-soft);
}

.org-pastas-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
    padding: 0.75rem 0.9rem;
    border-radius: 16px;
    margin-bottom: 0.85rem;
}

.org-pastas-search-pill {
    flex: 1 1 200px;
    min-width: 160px;
    display: flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.42rem 0.72rem;
    border-radius: 999px;
    background: rgba(142, 142, 147, 0.14);
}

.org-pastas-search-pill i {
    color: var(--text-soft);
    font-size: 0.82rem;
}

.org-pastas-search-input {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--color-text);
    font-size: 0.9rem;
    outline: none;
}

.org-pastas-select {
    padding: 0.42rem 0.55rem;
    border-radius: 10px;
    border: 0.5px solid var(--separator-color);
    background: var(--bg-elevated, rgba(255, 255, 255, 0.92));
    color: var(--color-text);
    font-size: 0.84rem;
}

[data-theme="dark"] .org-pastas-select {
    background: rgba(40, 40, 46, 0.85);
}

.org-pastas-btn {
    padding: 0.45rem 0.95rem;
    border-radius: 12px;
    border: none;
    font-size: 0.86rem;
    font-weight: 600;
    cursor: pointer;
    background: rgba(142, 142, 147, 0.2);
    color: var(--color-text);
    transition: background 0.15s ease, transform 0.1s ease;
}

.org-pastas-btn:hover {
    background: rgba(142, 142, 147, 0.28);
}

.org-pastas-btn--primary {
    background: #007aff;
    color: #fff !important;
}

.org-pastas-btn--primary:hover {
    filter: brightness(1.06);
}

.org-pastas-btn--gold {
    background: transparent;
    color: #b8860b !important;
    border: 1.5px solid rgba(184, 134, 11, 0.55);
}

.org-pastas-btn--gold:hover {
    background: rgba(184, 134, 11, 0.1);
}

.org-pastas-btn--danger {
    background: rgba(255, 59, 48, 0.14);
    color: var(--com-ios-accent, #ff3b30) !important;
}

.org-pastas-nova-folder-bar {
    margin-bottom: 0.85rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.org-pastas-nova-pasta-open {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
}

.org-pastas-nova-modal-lead {
    margin: 0 0 1rem;
    font-size: 0.9rem;
    line-height: 1.45;
    color: var(--color-text-secondary, #8e8e93);
}

.org-pastas-nova-modal-lead strong {
    color: var(--color-text);
    font-weight: 650;
}

.org-pastas-folder-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    padding: 0.65rem 0.85rem;
    border-radius: 16px;
    margin-bottom: 0.85rem;
}

.org-pastas-folder-actions .org-pastas-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
}

.org-pastas-btn--settings {
    background: rgba(142, 142, 147, 0.12);
    color: var(--color-text) !important;
    border: 0.5px solid var(--separator-color);
}

.org-pastas-btn--settings:hover {
    background: rgba(142, 142, 147, 0.18);
}

.org-pastas-partilha-sheet.modal-dialog {
    max-width: min(720px, calc(100vw - 1.5rem));
}

/* Seletor de ficheiro estilo iOS (modal) */
.org-pastas-ios-file-picker {
    display: block;
    position: relative;
    margin: 0.35rem 0 1.1rem;
    border-radius: 14px;
    cursor: pointer;
    outline: none;
}

.org-pastas-ios-file-picker:focus-visible {
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.45);
    border-radius: 16px;
}

.org-pastas-ios-file-picker__native {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    z-index: 2;
    font-size: 0.001px;
}

.org-pastas-ios-file-picker__cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 1.35rem 1.1rem;
    border-radius: 14px;
    background: rgba(142, 142, 147, 0.12);
    border: 1.5px dashed rgba(142, 142, 147, 0.42);
    pointer-events: none;
    transition:
        background 0.2s ease,
        border-color 0.2s ease,
        transform 0.2s ease;
}

[data-theme="dark"] .org-pastas-ios-file-picker__cell {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.2);
}

.org-pastas-ios-file-picker:hover .org-pastas-ios-file-picker__cell,
.org-pastas-ios-file-picker:focus-within .org-pastas-ios-file-picker__cell {
    background: rgba(10, 132, 255, 0.1);
    border-color: rgba(10, 132, 255, 0.45);
}

.org-pastas-ios-file-picker--active .org-pastas-ios-file-picker__cell {
    background: rgba(10, 132, 255, 0.16);
    border-color: var(--color-primary, #007aff);
    border-style: solid;
    transform: scale(1.01);
}

.org-pastas-ios-file-picker__glyph {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(245, 245, 247, 0.88));
    color: #007aff;
    font-size: 1.35rem;
    box-shadow:
        0 2px 8px rgba(0, 0, 0, 0.07),
        inset 0 1px 0 rgba(255, 255, 255, 0.85);
}

[data-theme="dark"] .org-pastas-ios-file-picker__glyph {
    background: linear-gradient(180deg, rgba(58, 58, 60, 0.95), rgba(44, 44, 46, 0.88));
    color: #0a84ff;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.4);
}

.org-pastas-ios-file-picker__title {
    font-size: 1.02rem;
    font-weight: 650;
    letter-spacing: -0.02em;
    color: var(--color-text);
}

.org-pastas-ios-file-picker__sub {
    font-size: 0.82rem;
    color: var(--text-soft);
    text-align: center;
    line-height: 1.35;
    max-width: 16rem;
}

.org-pastas-ios-file-picker__filename {
    font-size: 0.8rem;
    color: var(--color-primary);
    font-weight: 600;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin-top: 0.25rem;
    padding: 0 0.5rem;
}

.org-pastas-list-wrap--can-drop {
    transition:
        box-shadow 0.2s ease,
        border-color 0.2s ease;
}

.org-pastas-list-wrap--can-drop.org-pastas-list-wrap--drag-active {
    box-shadow:
        0 0 0 2px rgba(10, 132, 255, 0.5),
        0 8px 28px rgba(10, 132, 255, 0.12);
    border-color: rgba(10, 132, 255, 0.45) !important;
}

.org-pastas-gerir-form {
    margin-bottom: 0;
}

.org-pastas-gerir-divider {
    height: 0;
    margin: 1.1rem 0;
    border: 0;
    border-top: 0.5px solid var(--separator-color);
}

.org-pastas-gerir-delete-form .org-pastas-nova-modal-lead {
    margin-bottom: 0.65rem;
}

.org-pastas-modal-danger-btn.ios-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    width: 100%;
    box-sizing: border-box;
    margin-top: 0.35rem;
    background: rgba(255, 59, 48, 0.12);
    color: var(--com-ios-accent, #ff3b30) !important;
    border: 1px solid rgba(255, 59, 48, 0.35);
    font-weight: 600;
}

.org-pastas-modal-danger-btn.ios-btn:hover {
    background: rgba(255, 59, 48, 0.18);
}

.org-pastas-share__hint--modal {
    margin-top: 0;
}

.org-pastas-partilha-actions {
    margin-top: 1rem;
}

.org-pastas-upload {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
    padding: 0.75rem 0.95rem;
    border-radius: 16px;
    margin-bottom: 0.85rem;
}

.org-pastas-upload__label {
    font-weight: 600;
    font-size: 0.88rem;
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.org-pastas-admin-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    align-items: flex-end;
    padding: 0.75rem 0.95rem;
    border-radius: 16px;
    margin-bottom: 0.85rem;
}

.org-pastas-inline-form {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.org-pastas-list-wrap {
    border-radius: 18px;
    padding: 0.35rem 0.5rem;
    margin-bottom: 1rem;
}

.org-pastas-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.org-pastas-row {
    border-radius: 14px;
    margin-bottom: 0.35rem;
    background: rgba(255, 255, 255, 0.55);
    border: 0.5px solid var(--separator-color);
}

[data-theme="dark"] .org-pastas-row {
    background: rgba(255, 255, 255, 0.06);
}

.org-pastas-row__link {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.72rem 0.85rem;
    text-decoration: none;
    color: inherit;
}

.org-pastas-file-row-hit {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    width: 100%;
    margin: 0;
    padding: 0.72rem 0.85rem;
    border: none;
    border-radius: 14px;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
    box-sizing: border-box;
    transition: background 0.15s ease;
}

.org-pastas-file-row-hit:hover,
.org-pastas-file-row-hit:focus-visible {
    background: rgba(0, 122, 255, 0.08);
    outline: none;
}

[data-theme="dark"] .org-pastas-file-row-hit:hover {
    background: rgba(10, 132, 255, 0.12);
}

.org-pastas-file-row-hit__name {
    word-break: break-word;
}

.org-pastas-file-row-chevron {
    margin-left: auto;
    flex-shrink: 0;
    font-size: 0.72rem;
    opacity: 0.35;
    padding-left: 0.25rem;
}

.org-pastas-arquivo-sheet-title {
    word-break: break-word;
}

.org-pastas-arquivo-dialog.modal-dialog {
    max-width: min(920px, calc(100vw - 1rem));
}

.org-pastas-arquivo-modal-body {
    max-height: min(90vh, 820px);
}

/*
 * Scroll fino estilo iOS nas zonas do sheet que nós controlamos (corpo do modal, viewport do PDF).
 * Nota: o leitor PDF integrado do Chrome/Edge corre dentro do iframe; as barras desse UI interno
 * não são personalizáveis por CSS da página (só com PDF.js ou abrir o ficheiro noutro separador).
 */
.org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll {
    scrollbar-width: thin;
    scrollbar-color: rgba(10, 48, 85, 0.22) transparent;
}

.org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

.org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll::-webkit-scrollbar-thumb {
    background: rgba(10, 48, 85, 0.2);
    border-radius: 4px;
}

.org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(10, 48, 85, 0.38);
}

[data-theme="dark"] .org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll {
    scrollbar-color: rgba(255, 255, 255, 0.22) transparent;
}

[data-theme="dark"] .org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
}

[data-theme="dark"] .org-pastas-arquivo-dialog .org-pastas-arquivo-ios-scroll::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.35);
}

.org-pastas-arquivo-preview-wrap {
    margin: 0 0 1rem;
    border-radius: 14px;
    overflow: hidden;
    background: var(--surface-level-2, rgba(142, 142, 147, 0.08));
    border: 0.5px solid var(--separator-color);
    min-height: 140px;
    max-height: min(48vh, 440px);
    min-width: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    box-sizing: border-box;
}

.org-pastas-arquivo-preview-panel {
    width: 100%;
    min-width: 0;
    min-height: 140px;
    max-height: min(48vh, 440px);
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    flex: 1 1 auto;
}

.org-pastas-arquivo-preview-panel--pdf {
    display: block;
    padding: 0;
    overflow: hidden;
    height: min(48vh, 440px);
    min-height: 220px;
    max-height: min(48vh, 440px);
    flex: 0 0 auto;
}

/*
 * Vídeo: sem position:absolute nem object-fit no <video> (Chromium/WebKit
 * frequentemente não pintam o frame). Fluxo normal + caixa limitada.
 */
.org-pastas-arquivo-preview-panel.org-pastas-arquivo-preview-panel--video {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    padding: 0;
    overflow: hidden;
    flex: 0 0 auto;
    align-self: stretch;
    width: 100%;
    min-height: 200px;
    max-height: min(48vh, 440px);
    box-sizing: border-box;
    background: #000;
    border-radius: 12px;
}

.org-pastas-arquivo-preview-panel.org-pastas-arquivo-preview-panel--audio {
    display: block;
    flex: 0 0 auto;
    align-self: stretch;
    width: 100%;
    padding: 0.65rem 0.35rem 0.85rem;
    box-sizing: border-box;
    min-height: 0;
    max-height: none;
    align-items: unset;
    justify-content: unset;
}

.org-pastas-arquivo-preview-audio-el {
    display: block;
    width: 100%;
    min-height: 48px;
}

.org-pastas-arquivo-preview-pdf-viewport {
    width: 100%;
    height: 100%;
    max-height: 100%;
    overflow: hidden;
    border-radius: 12px;
}

.org-pastas-arquivo-preview-iframe {
    width: 100%;
    height: min(48vh, 440px);
    min-height: 220px;
    border: 0;
    display: block;
    background: #1c1c1e;
}

.org-pastas-arquivo-preview-panel--video .org-pastas-arquivo-preview-video-el {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    max-height: min(48vh, 440px);
    min-height: 200px;
    margin: 0;
    background: #000;
    border-radius: 0;
}

.org-pastas-arquivo-preview-none {
    padding: 1.35rem 1.1rem;
    text-align: center;
    color: var(--text-soft);
    max-width: 20rem;
    margin: 0 auto;
}

.org-pastas-arquivo-preview-none__icon {
    display: block;
    font-size: 1.85rem;
    opacity: 0.45;
    margin-bottom: 0.45rem;
    color: var(--color-text);
}

.org-pastas-arquivo-preview-none__title {
    margin: 0 0 0.35rem;
    font-size: 0.95rem;
    font-weight: 650;
    color: var(--color-text);
}

.org-pastas-arquivo-preview-none__hint {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
}

.org-pastas-arquivo-meta {
    margin-bottom: 1rem;
}

.org-pastas-arquivo-meta__text {
    margin: 0;
    font-size: 0.88rem;
    color: var(--text-soft);
    line-height: 1.4;
    text-align: center;
}

.org-pastas-arquivo-download {
    width: 100%;
    box-sizing: border-box;
    justify-content: center;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin-bottom: 1.15rem;
    text-decoration: none;
}

.org-pastas-arquivo-edit-block {
    border-top: 0.5px solid var(--separator-color);
    padding-top: 1.05rem;
    margin-top: 0.25rem;
}

.org-pastas-arquivo-rename-form {
    margin-bottom: 0.75rem;
}

.org-pastas-arquivo-save-name {
    width: 100%;
    margin-top: 0.5rem;
    justify-content: center;
}

.org-pastas-arquivo-open-delete {
    width: 100%;
    justify-content: center;
}

.org-pastas-row--file {
    padding: 0;
    overflow: hidden;
}

.org-pastas-row--file .org-pastas-file-row-hit {
    border-radius: inherit;
}

.org-pastas-row__icon {
    color: #b8860b;
    width: 1.25rem;
    text-align: center;
}

.org-pastas-row--file .org-pastas-row__icon {
    color: var(--color-primary);
}

.org-pastas-row__name {
    font-weight: 650;
    flex: 1 1 auto;
}

.org-pastas-row__meta {
    font-size: 0.8rem;
    color: var(--text-soft);
}

.org-pastas-row__actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    margin-left: auto;
}

.org-pastas-chip {
    font-size: 0.78rem;
    font-weight: 600;
    padding: 0.28rem 0.55rem;
    border-radius: 999px;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary);
    text-decoration: none;
    border: none;
    cursor: pointer;
}

.org-pastas-chip--danger {
    background: rgba(255, 59, 48, 0.12);
    color: var(--com-ios-accent, #ff3b30);
}

.org-pastas-empty {
    text-align: center;
    padding: 2rem 1rem 2.25rem;
    color: var(--text-soft);
}

.org-pastas-empty__icon {
    display: flex;
    justify-content: center;
    margin-bottom: 0.65rem;
    font-size: 2rem;
    opacity: 0.5;
    color: var(--color-text);
}

.org-pastas-empty__text {
    margin: 0;
    font-size: 0.98rem;
}

.org-pastas-empty__hint {
    margin: 0.85rem 0 0;
    font-size: 0.82rem;
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.45rem;
    flex-wrap: wrap;
    line-height: 1.4;
}

.org-pastas-empty--droppable {
    padding: 2.25rem 1rem 2.5rem;
}

.org-pastas-list-wrap--drag-active .org-pastas-empty__hint {
    font-weight: 650;
}

.org-pastas-share {
    padding: 1rem 1.1rem;
    border-radius: 18px;
}

.org-pastas-share__title {
    margin: 0 0 0.35rem;
    font-size: 1.1rem;
}

.org-pastas-share__hint {
    font-size: 0.85rem;
    color: var(--text-soft);
    margin: 0 0 1rem;
}

.org-pastas-share__sub {
    font-size: 0.92rem;
    margin: 1rem 0 0.5rem;
}

.org-pastas-share__sub--ios {
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    margin: 1.35rem 0 0.45rem;
}

.org-pastas-share__micro {
    font-size: 0.78rem;
    color: var(--text-soft);
    margin: -0.2rem 0 0.55rem;
    line-height: 1.35;
}

.org-pastas-partilha-sheet .org-pastas-share__sub--ios:first-of-type {
    margin-top: 0.35rem;
}

.org-pastas-perm-group--ios {
    border-radius: 12px;
    overflow: hidden;
    border: 0.5px solid var(--separator-color);
    background: var(--surface-level-2, rgba(142, 142, 147, 0.08));
    margin-bottom: 0.35rem;
}

[data-theme="dark"] .org-pastas-perm-group--ios {
    background: rgba(255, 255, 255, 0.06);
}

.org-pastas-perm-row-ios {
    padding: 0.85rem 0.95rem;
    border-bottom: 0.5px solid var(--separator-color);
}

.org-pastas-perm-row-ios:last-child {
    border-bottom: none;
}

.org-pastas-perm-row-ios__head {
    margin-bottom: 0.65rem;
}

.org-pastas-perm-master {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    cursor: pointer;
    margin: 0;
}

.org-pastas-perm-master__input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.org-pastas-perm-master__box {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    margin-top: 0.1rem;
    border-radius: 6px;
    border: 2px solid rgba(142, 142, 147, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.62rem;
    color: transparent;
    transition:
        border-color 0.15s ease,
        background 0.15s ease,
        color 0.15s ease;
}

.org-pastas-perm-master__input:checked + .org-pastas-perm-master__box {
    background: var(--color-primary, #007aff);
    border-color: var(--color-primary, #007aff);
    color: #fff;
}

.org-pastas-perm-master__input:focus-visible + .org-pastas-perm-master__box {
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.35);
}

.org-pastas-perm-master__label {
    flex: 1;
    min-width: 0;
    font-size: 0.95rem;
    font-weight: 650;
    letter-spacing: -0.02em;
    line-height: 1.35;
    color: var(--color-text);
}

.org-pastas-perm-master__sigla {
    font-weight: 750;
}

.org-pastas-perm-master__sep {
    margin: 0 0.35rem;
    opacity: 0.4;
    font-weight: 400;
}

.org-pastas-perm-master__nome {
    font-weight: 500;
    font-size: 0.86rem;
    color: var(--text-soft);
}

.org-pastas-perm-row-ios__flags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
}

.org-pastas-perm-chip {
    position: relative;
    cursor: pointer;
    margin: 0;
}

.org-pastas-perm-chip__input {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.org-pastas-perm-chip__face {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.38rem 0.75rem;
    border-radius: 999px;
    font-size: 0.74rem;
    font-weight: 650;
    letter-spacing: -0.01em;
    background: rgba(142, 142, 147, 0.14);
    color: var(--text-soft);
    border: 1px solid transparent;
    transition:
        background 0.15s ease,
        color 0.15s ease,
        border-color 0.15s ease,
        box-shadow 0.15s ease;
}

.org-pastas-perm-chip__input:focus-visible + .org-pastas-perm-chip__face {
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.35);
}

.org-pastas-perm-chip__input:checked + .org-pastas-perm-chip__face {
    background: rgba(0, 122, 255, 0.18);
    color: var(--color-primary, #007aff);
    border-color: rgba(0, 122, 255, 0.35);
}

[data-theme="dark"] .org-pastas-perm-chip__input:checked + .org-pastas-perm-chip__face {
    background: rgba(232, 232, 232, 0.09);
    color: #0a84ff;
    border-color: rgba(10, 132, 255, 0.45);
}

.org-pastas-switch-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.55rem 0;
    font-size: 0.88rem;
}

.org-ios-switch {
    position: relative;
    width: 50px;
    height: 30px;
    flex-shrink: 0;
}

.org-ios-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.org-ios-switch__slider {
    position: absolute;
    inset: 0;
    border-radius: 999px;
    background: rgba(142, 142, 147, 0.45);
    transition: background 0.2s ease;
    cursor: pointer;
}

.org-ios-switch__slider::before {
    content: "";
    position: absolute;
    width: 26px;
    height: 26px;
    left: 2px;
    top: 2px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
    transition: transform 0.2s ease;
}

.org-ios-switch input:checked + .org-ios-switch__slider {
    background: #34c759;
}

.org-ios-switch input:checked + .org-ios-switch__slider::before {
    transform: translateX(20px);
}

.org-pastas-perm-table {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.org-pastas-perm-row {
    display: grid;
    grid-template-columns: 1.4fr repeat(3, auto);
    gap: 0.5rem 0.75rem;
    align-items: center;
    font-size: 0.82rem;
    padding: 0.45rem 0.55rem;
    border-radius: 10px;
    background: rgba(142, 142, 147, 0.08);
}

@media (max-width: 640px) {
    .org-pastas-perm-row {
        grid-template-columns: 1fr;
    }
}

.org-pastas-perm-check {
    display: flex;
    align-items: center;
    gap: 0.35rem;
}

.org-dash-alert {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    padding: 0.85rem 1.1rem;
    margin-bottom: 1rem;
    border-radius: 14px;
    background: rgba(255, 149, 0, 0.12);
    border: 1px solid rgba(255, 149, 0, 0.35);
    color: var(--color-text);
    font-size: 0.9rem;
}

[data-theme="dark"] .org-dash-alert {
    background: rgba(255, 159, 10, 0.15);
    border-color: rgba(255, 159, 10, 0.4);
}

.org-dash-alert i {
    color: var(--color-accent);
    font-size: 1.1rem;
}

.org-dash-alert-link {
    margin-left: auto;
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
}

.org-dash-alert-link:hover {
    text-decoration: underline;
}

.org-stats-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.85rem;
    margin-bottom: 1rem;
}

@media (max-width: 900px) {
    .org-stats-strip {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 480px) {
    .org-stats-strip {
        grid-template-columns: 1fr;
    }
}

.org-stat-tile {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 1rem 1.15rem;
    border-radius: 16px;
    text-decoration: none;
    color: inherit;
    background: var(--surface-level-1);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.org-stat-tile:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

.org-stat-tile__icon {
    font-size: 1.1rem;
    opacity: 0.85;
    margin-bottom: 0.5rem;
}

.org-stat-tile--tramitacao .org-stat-tile__icon { color: var(--color-primary); }
.org-stat-tile--julgado .org-stat-tile__icon { color: #AF52DE; }
.org-stat-tile--arquivado .org-stat-tile__icon { color: var(--text-soft); }
.org-stat-tile--suspenso .org-stat-tile__icon { color: var(--color-accent); }

.org-stat-tile__value {
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.1;
}

.org-stat-tile__label {
    font-size: 0.82rem;
    color: var(--text-soft);
    margin-top: 0.25rem;
    font-weight: 500;
}

.org-sigilo-strip {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem 1rem;
    padding: 0.9rem 1.15rem;
    margin-bottom: 1.25rem;
    font-size: 0.88rem;
}

.org-sigilo-strip__title {
    font-weight: 600;
    margin-right: 0.25rem;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.org-sigilo-pill {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    background: var(--surface-level-2);
    color: var(--color-text);
}

.org-sigilo-pill--pub i { color: var(--color-primary); }
.org-sigilo-pill--sig i { color: #AF52DE; }
.org-sigilo-pill--seg i { color: var(--color-danger); }

.org-dash-two-col {
    display: grid;
    grid-template-columns: 1fr minmax(280px, 380px);
    gap: 1.25rem;
    align-items: start;
}

@media (max-width: 1024px) {
    .org-dash-two-col {
        grid-template-columns: 1fr;
    }
}

.org-dash-col--main .widget-card,
.org-dash-col--side .widget-card {
    margin-bottom: 1.25rem;
}

.org-comunicados-scroll {
    max-height: 440px;
    overflow-y: auto;
    padding-right: 0.35rem;
}

/* —— Comunicados: referência visual + materiais iOS (SF, vidro, cantos) —— */
.ios-comunicados-panel {
    --com-ios-accent: #ff3b30;
    --com-ios-accent-dim: rgba(255, 59, 48, 0.18);
    padding: 1rem 1.12rem 1.08rem;
    border-radius: 18px;
}

[data-theme="dark"] .ios-comunicados-panel {
    --com-ios-accent: #ff453a;
    --com-ios-accent-dim: rgba(255, 69, 58, 0.28);
}

.ios-comunicados-head__top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.62rem;
}

.ios-comunicados-head__brand {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 0;
}

.ios-comunicados-mega {
    width: 40px;
    height: 40px;
    border-radius: 11px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--com-ios-accent-dim);
    color: var(--com-ios-accent);
    font-size: 1.05rem;
    flex-shrink: 0;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
}

.ios-comunicados-title {
    margin: 0;
    font-size: 1.14rem;
    font-weight: 700;
    letter-spacing: -0.032em;
    color: var(--com-ios-accent);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", sans-serif;
}

.ios-comunicados-add {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: rgba(142, 142, 147, 0.16);
    color: var(--color-text);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.15s ease, transform 0.12s ease;
    flex-shrink: 0;
}

.ios-comunicados-add:hover {
    background: rgba(142, 142, 147, 0.28);
}

.ios-comunicados-add:active {
    transform: scale(0.94);
}

.ios-comunicados-head__sub {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding-bottom: 0.72rem;
    border-bottom: 0.5px solid var(--separator-color);
    margin-bottom: 0.62rem;
}

.ios-comunicados-count {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-soft);
}

.ios-comunicados-seeall {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--com-ios-accent);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.ios-comunicados-seeall:hover {
    text-decoration: underline;
}

.ios-comunicados-seeall i {
    font-size: 0.62rem;
    opacity: 0.88;
}

.ios-comunicados-list {
    display: flex;
    flex-direction: column;
    gap: 0.52rem;
}

/* —— Lista completa de comunicados (pesquisa, filtros, paginação) —— */
.org-com-list-page {
    max-width: min(920px, 100%);
    margin-inline: auto;
}

.org-com-list-meta-accent {
    color: var(--color-primary);
    font-weight: 600;
}

.org-com-list-panel .ios-comunicados-head__top {
    margin-bottom: 0.35rem;
}

.org-com-list-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem 1rem;
    padding: 0.85rem 0.95rem;
    margin: 0 0 0.85rem;
    border-radius: 14px;
    background: rgba(142, 142, 147, 0.1);
    border: 0.5px solid var(--separator-color);
}

[data-theme="dark"] .org-com-list-toolbar {
    background: rgba(255, 255, 255, 0.06);
}

.org-com-list-toolbar__search {
    flex: 1 1 220px;
    min-width: 180px;
    position: relative;
}

.org-com-list-toolbar__search-icon {
    position: absolute;
    left: 0.72rem;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-soft);
    font-size: 0.85rem;
    pointer-events: none;
}

.org-com-list-search-input {
    width: 100%;
    padding: 0.55rem 0.75rem 0.55rem 2.35rem;
    border-radius: 10px;
    border: 0.5px solid var(--separator-color);
    background: var(--bg-elevated, rgba(255, 255, 255, 0.92));
    color: var(--color-text);
    font-size: 0.9rem;
}

[data-theme="dark"] .org-com-list-search-input {
    background: rgba(30, 30, 32, 0.72);
}

.org-com-list-search-input::placeholder {
    color: var(--text-soft);
    opacity: 0.85;
}

.org-com-list-search-input:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.25);
    border-color: var(--color-primary);
}

.org-com-list-toolbar__selects {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem 1rem;
    align-items: flex-end;
}

.org-com-list-field {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    min-width: 0;
}

.org-com-list-field__label {
    font-size: 0.68rem;
    font-weight: 650;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-soft);
}

.org-com-list-select {
    min-width: 11.5rem;
    padding: 0.48rem 0.65rem;
    border-radius: 10px;
    border: 0.5px solid var(--separator-color);
    background: var(--bg-elevated, rgba(255, 255, 255, 0.92));
    color: var(--color-text);
    font-size: 0.86rem;
    cursor: pointer;
}

[data-theme="dark"] .org-com-list-select {
    background: rgba(30, 30, 32, 0.72);
}

.org-com-list-toolbar__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.org-com-list-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    padding: 0.48rem 0.85rem;
    border-radius: 10px;
    font-size: 0.86rem;
    font-weight: 650;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition:
        background 0.15s ease,
        transform 0.1s ease;
}

.org-com-list-btn--primary {
    background: var(--color-primary);
    color: #fff;
}

.org-com-list-btn--primary:hover {
    filter: brightness(1.05);
}

.org-com-list-btn--primary:active {
    transform: scale(0.97);
}

.org-com-list-btn--ghost {
    background: transparent;
    color: var(--color-primary);
    font-weight: 600;
}

.org-com-list-btn--ghost:hover {
    text-decoration: underline;
}

.org-com-list-results-meta {
    margin: 0 0 0.65rem;
    font-size: 0.8rem;
    color: var(--text-soft);
}

.org-com-list-scroll {
    min-height: 120px;
    max-height: min(58vh, 640px);
    overflow-y: auto;
    padding-right: 0.2rem;
}

.org-com-list-empty-filter {
    text-align: center;
    padding: 2rem 1.25rem;
    border-radius: 16px;
    border: 0.5px dashed var(--separator-color);
    color: var(--text-soft);
}

.org-com-list-empty-filter > .fa-magnifying-glass {
    font-size: 1.75rem;
    opacity: 0.55;
    margin-bottom: 0.65rem;
    display: block;
}

.org-com-list-empty-filter p {
    margin: 0.25rem 0;
}

.org-com-list-empty-filter__hint {
    font-size: 0.88rem;
    max-width: 28rem;
    margin-inline: auto !important;
}

.org-com-list-empty-filter__cta {
    margin-top: 1rem;
}

.org-com-list-pager {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.65rem 1rem;
    margin-top: 1rem;
    padding-top: 0.85rem;
    border-top: 0.5px solid var(--separator-color);
}

.org-com-list-pager__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.86rem;
    font-weight: 650;
    color: var(--color-primary);
    text-decoration: none;
}

.org-com-list-pager__link:hover:not(.org-com-list-pager__link--disabled) {
    text-decoration: underline;
}

.org-com-list-pager__link--disabled {
    color: var(--text-soft);
    opacity: 0.6;
    cursor: not-allowed;
}

.org-com-list-pager__status {
    font-size: 0.82rem;
    color: var(--text-soft);
    font-weight: 500;
}

.ios-comunicado-row.org-com-article-card {
    overflow: visible;
}

.ios-comunicado-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.72rem;
    padding: 0.62rem 0.72rem !important;
    margin-bottom: 0 !important;
    border-radius: 16px !important;
    border: 0.5px solid var(--separator-color) !important;
    box-shadow: 0 2px 14px rgba(0, 0, 0, 0.05);
    transition:
        background 0.12s ease,
        box-shadow 0.15s ease;
}

[data-theme="light"] .ios-comunicado-row {
    background: rgba(255, 255, 255, 0.78);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}

[data-theme="dark"] .ios-comunicado-row {
    background: rgba(255, 255, 255, 0.055);
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

.ios-comunicado-row:hover {
    box-shadow: 0 5px 22px rgba(0, 0, 0, 0.09);
}

.ios-comunicado-row--pressing {
    box-shadow:
        inset 0 1px 6px rgba(0, 0, 0, 0.14),
        0 3px 14px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.08s ease, background 0.08s ease;
}

[data-theme="light"] .ios-comunicado-row--pressing {
    background: rgba(0, 0, 0, 0.04) !important;
    box-shadow:
        inset 0 2px 8px rgba(0, 0, 0, 0.07),
        0 4px 16px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .ios-comunicado-row--pressing {
    background: rgba(255, 255, 255, 0.09) !important;
    box-shadow:
        inset 0 2px 10px rgba(0, 0, 0, 0.35),
        0 4px 18px rgba(0, 0, 0, 0.2);
}

.ios-comunicado-row.unread {
    border-left: 3px solid var(--com-ios-accent) !important;
    box-shadow:
        0 2px 14px rgba(0, 0, 0, 0.05),
        0 0 0 1px rgba(255, 59, 48, 0.1);
}

.ios-comunicado-row__thumb {
    width: 56px;
    height: 56px;
    border-radius: 12px;
    overflow: hidden;
    flex-shrink: 0;
    background: var(--surface-level-2, #e8e8ed);
}

.ios-comunicado-row__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.ios-comunicado-row__ph {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-soft);
    font-size: 1.22rem;
}

.ios-comunicado-row__main {
    flex: 1;
    min-width: 0;
}

.ios-comunicado-row__title {
    margin: 0 0 0.18rem;
    font-size: 0.94rem;
    font-weight: 650;
    letter-spacing: -0.02em;
    line-height: 1.28;
    color: var(--color-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;
}

.ios-comunicado-row__meta-line {
    margin: 0;
    font-size: 0.72rem;
    color: var(--text-soft);
    font-weight: 450;
    line-height: 1.35;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.28rem 0.32rem;
}

.ios-comunicado-row__org {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    font-weight: 600;
    color: var(--com-ios-accent);
}

.ios-comunicado-row__org i {
    font-size: 0.68rem;
    opacity: 0.9;
}

.ios-comunicado-row__meta-sep {
    opacity: 0.45;
    user-select: none;
}

.ios-comunicado-row__date {
    color: var(--text-soft);
    font-weight: 450;
}

.ios-comunicado-row__aside {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    gap: 0.32rem;
    flex-shrink: 0;
}

.ios-comunicado-row__admin {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.28rem;
}

.ios-comunicado-icon-btn {
    width: 30px;
    height: 30px;
    padding: 0;
    border: none;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 0.78rem;
    color: var(--color-primary);
    background: rgba(10, 132, 255, 0.12);
    transition: background 0.15s ease, opacity 0.12s ease;
}

.ios-comunicado-icon-btn:hover {
    background: rgba(10, 132, 255, 0.2);
}

.ios-comunicado-icon-btn:active {
    opacity: 0.88;
}

.ios-comunicado-icon-btn--danger {
    color: var(--com-ios-accent, #ff3b30);
    background: var(--com-ios-accent-dim, rgba(255, 59, 48, 0.18));
}

.ios-comunicado-icon-btn--danger:hover {
    background: rgba(255, 59, 48, 0.28);
}

.ios-comunicado-badge {
    font-size: 0.6rem;
    font-weight: 750;
    letter-spacing: 0.07em;
    padding: 0.26rem 0.42rem;
    border-radius: 6px;
    background: var(--com-ios-accent);
    color: #fff;
    line-height: 1;
}

.ios-comunicado-chevron {
    color: var(--text-soft);
    font-size: 0.72rem;
    opacity: 0.5;
}

.modal-body .ios-com-sheet,
.ios-comunicados-panel {
    --com-ios-accent: #ff3b30;
    --com-ios-accent-dim: rgba(255, 59, 48, 0.18);
}

[data-theme="dark"] .modal-body .ios-com-sheet,
[data-theme="dark"] .ios-comunicados-panel {
    --com-ios-accent: #ff453a;
    --com-ios-accent-dim: rgba(255, 69, 58, 0.28);
}

.ios-com-sheet {
    margin: -0.2rem 0 0;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "Segoe UI", sans-serif;
}

.ios-com-sheet__hero-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 0.5rem;
    box-shadow: 0 4px 26px rgba(0, 0, 0, 0.08);
}

.ios-com-sheet__hero-card::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    border-radius: inherit;
    background: linear-gradient(
        180deg,
        transparent 38%,
        rgba(0, 0, 0, 0.22) 72%,
        rgba(0, 0, 0, 0.5) 100%
    );
}

[data-theme="light"] .ios-com-sheet__hero-card::after {
    background: linear-gradient(
        180deg,
        transparent 42%,
        rgba(255, 255, 255, 0.35) 75%,
        rgba(255, 255, 255, 0.9) 100%
    );
}

.ios-com-sheet__hero {
    width: 100%;
    max-height: min(22vh, 168px);
    object-fit: cover;
    display: block;
}

.ios-com-sheet__hero--empty {
    min-height: 96px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(165deg, var(--surface-level-2), var(--surface-level-1));
    color: var(--text-soft);
    font-size: 2rem;
}

.ios-com-sheet__glass {
    background: rgba(142, 142, 147, 0.12);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 14px;
    border: 0.5px solid var(--separator-color);
}

.ios-com-sheet__toolbar {
    padding: 0.52rem 0.72rem;
    margin-bottom: 0.62rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.72rem;
}

.ios-com-sheet__toolbar--compact {
    padding: 0.35rem 0.55rem;
    margin-bottom: 0.42rem;
    gap: 0.4rem 0.65rem;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
}

.ios-com-sheet__toolbar-start {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
    min-width: 0;
    flex: 1;
}

.ios-com-sheet__toolbar-end {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 0.4rem 0.55rem;
    flex-shrink: 0;
    min-width: 0;
    max-width: min(48%, 420px);
    text-align: right;
}

.ios-com-sheet__admin-actions {
    display: flex;
    align-items: center;
    gap: 0.28rem;
    flex-shrink: 0;
}

.ios-com-sheet__icon-btn {
    width: 32px;
    height: 32px;
    padding: 0;
    border: none;
    border-radius: 9px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 0.82rem;
    color: var(--color-primary);
    background: rgba(10, 132, 255, 0.12);
    transition: background 0.15s ease;
}

.ios-com-sheet__icon-btn:hover {
    background: rgba(10, 132, 255, 0.2);
}

.ios-com-sheet__icon-btn:active {
    opacity: 0.88;
}

.ios-com-sheet__icon-btn--danger {
    color: var(--com-ios-accent, #ff3b30);
    background: var(--com-ios-accent-dim, rgba(255, 59, 48, 0.18));
}

.ios-com-sheet__icon-btn--danger:hover {
    background: rgba(255, 59, 48, 0.28);
}

.ios-com-sheet__toolbar-author {
    display: flex;
    align-items: center;
    gap: 0.38rem;
    justify-content: flex-end;
    min-width: 0;
}

.ios-com-sheet__toolbar-author .ios-com-sheet__avatar,
.ios-com-sheet__toolbar-author .ios-com-sheet__avatar--fallback {
    width: 28px;
    height: 28px;
}

.ios-com-sheet__toolbar-author .ios-com-sheet__avatar--fallback {
    font-size: 0.72rem;
}

.ios-com-sheet__author-text--toolbar {
    align-items: flex-end;
    text-align: right;
}

.ios-com-sheet__author-text--toolbar .ios-com-sheet__author-name {
    font-size: 0.78rem;
    line-height: 1.25;
    max-width: 14rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ios-com-sheet__author-text--toolbar .ios-com-sheet__author-meta {
    font-size: 0.65rem;
    line-height: 1.3;
}

.ios-com-sheet__toolbar-pub-meta {
    font-size: 0.68rem;
    color: var(--text-soft);
    white-space: nowrap;
}

.ios-com-sheet__pill {
    font-size: 0.7rem;
    font-weight: 650;
    padding: 0.3rem 0.52rem;
    border-radius: 8px;
    background: var(--com-ios-accent-dim);
    color: var(--com-ios-accent);
}

.ios-com-sheet__toolbar--compact .ios-com-sheet__pill {
    font-size: 0.62rem;
    padding: 0.2rem 0.4rem;
    border-radius: 6px;
    flex-shrink: 0;
}

.ios-com-sheet__stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 0.95rem;
    align-items: center;
    flex: 1;
    min-width: 0;
}

.ios-com-sheet__toolbar--compact .ios-com-sheet__stats {
    gap: 0.45rem 0.65rem;
    flex-wrap: nowrap;
    min-width: 0;
}

.ios-com-sheet__stat {
    font-size: 0.74rem;
    color: var(--text-soft);
    display: inline-flex;
    align-items: center;
    gap: 0.32rem;
}

.ios-com-sheet__toolbar--compact .ios-com-sheet__stat {
    font-size: 0.68rem;
    gap: 0.28rem;
}

.ios-com-sheet__stat--truncate {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.ios-com-sheet__stat--nowrap {
    flex-shrink: 0;
    white-space: nowrap;
}

.ios-com-sheet__stat i {
    opacity: 0.72;
}

.ios-com-sheet__stat--accent {
    color: var(--com-ios-accent);
    font-weight: 600;
}

.ios-com-sheet__kind--chip {
    display: inline-block;
    font-size: 0.55rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.18rem 0.38rem;
    border-radius: 5px;
    background: var(--com-ios-accent);
    color: #fff;
    line-height: 1.2;
    flex-shrink: 0;
}

@media (max-width: 540px) {
    .ios-com-sheet__toolbar--compact {
        flex-wrap: wrap;
        align-items: flex-start;
    }

    .ios-com-sheet__toolbar-end {
        max-width: none;
        width: 100%;
        justify-content: flex-end;
        padding-top: 0.1rem;
    }
}

.ios-com-sheet__header {
    margin-bottom: 0.82rem;
}

.ios-com-sheet__header--compact {
    margin-bottom: 0.42rem;
}

.ios-com-sheet__title {
    margin: 0 0 0.32rem;
    font-size: 1.32rem;
    font-weight: 700;
    letter-spacing: -0.035em;
    line-height: 1.18;
    color: var(--com-ios-accent);
}

.ios-com-sheet__header--compact .ios-com-sheet__title {
    font-size: 1.1rem;
    margin: 0 0 0.12rem;
    line-height: 1.22;
}

.ios-com-sheet__subtitle {
    margin: 0;
    font-size: 0.83rem;
    color: var(--text-soft);
}

.ios-com-sheet__header--compact .ios-com-sheet__subtitle {
    font-size: 0.76rem;
}

.ios-com-sheet__author {
    display: flex;
    align-items: center;
    gap: 0.62rem;
    padding: 0.62rem 0.75rem;
    margin-bottom: 0.95rem;
}

.ios-com-sheet__avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.ios-com-sheet__avatar--fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--surface-level-2);
    font-size: 1rem;
    font-weight: 700;
    color: var(--color-text);
}

.ios-com-sheet__author-text {
    display: flex;
    flex-direction: column;
    gap: 0.12rem;
    min-width: 0;
}

.ios-com-sheet__author-name {
    font-weight: 650;
    font-size: 0.93rem;
    color: var(--color-text);
}

.ios-com-sheet__author-meta {
    font-size: 0.77rem;
    color: var(--text-soft);
}

.ios-com-sheet__content-card {
    padding: 0.95rem 1.05rem 1.05rem;
    border-radius: 16px;
    background: rgba(142, 142, 147, 0.09);
    border: 0.5px solid var(--separator-color);
    margin-bottom: 0.35rem;
    max-height: min(58vh, 520px);
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: rgba(10, 48, 85, 0.22) transparent;
}

.ios-com-sheet__content-card::-webkit-scrollbar {
    width: 6px;
}

.ios-com-sheet__content-card::-webkit-scrollbar-track {
    background: transparent;
}

.ios-com-sheet__content-card::-webkit-scrollbar-thumb {
    background: rgba(10, 48, 85, 0.2);
    border-radius: 4px;
}

.ios-com-sheet__content-card::-webkit-scrollbar-thumb:hover {
    background: rgba(10, 48, 85, 0.38);
}

[data-theme="dark"] .ios-com-sheet__content-card {
    scrollbar-color: rgba(255, 255, 255, 0.22) transparent;
}

[data-theme="dark"] .ios-com-sheet__content-card::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2);
}

[data-theme="dark"] .ios-com-sheet__content-card::-webkit-scrollbar-thumb:hover {
    background: rgba(255, 255, 255, 0.35);
}

.ios-com-prose {
    font-size: 0.93rem;
    line-height: 1.56;
}

.org-com-card {
    padding: 1rem 1.1rem;
    border-radius: 14px;
    margin-bottom: 0.85rem;
    border: 1px solid var(--glass-border);
    background: var(--surface-level-1);
    position: relative;
}

.org-com-card.unread {
    border-left: 3px solid var(--color-primary);
}

.org-com-dot {
    position: absolute;
    top: 1rem;
    right: 1rem;
}

.org-com-title {
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 0.35rem;
    padding-right: 1.25rem;
}

.org-com-meta {
    font-size: 0.8rem;
    color: var(--text-soft);
    margin-bottom: 0.5rem;
}

.unread .org-com-meta {
    font-weight: 500;
}

.org-com-body {
    font-size: 0.92rem;
    line-height: 1.45;
    color: var(--color-text);
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.org-com-article-card {
    overflow: hidden;
    padding: 0;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
}

.org-com-article-card.unread {
    border-left: 3px solid var(--color-primary);
}

.org-com-card-cover {
    position: relative;
    width: 100%;
    aspect-ratio: 21 / 9;
    max-height: 200px;
    overflow: hidden;
    background: var(--surface-level-2, #e8e8ed);
}

.org-com-card-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.org-com-card-inner {
    position: relative;
    padding: 1rem 1.15rem 1.1rem;
}

.org-com-article-card .org-com-title {
    font-size: 1.05rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.25;
    margin-bottom: 0.4rem;
}

.org-com-card-actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 1rem;
}

.org-com-card--compact {
    cursor: pointer;
    transition: transform 0.16s ease, box-shadow 0.2s ease;
    margin-bottom: 0.75rem;
}

.org-com-card--compact:hover {
    box-shadow: 0 6px 28px rgba(0, 0, 0, 0.08);
}

.org-com-card--compact:focus-visible {
    outline: 3px solid rgba(10, 132, 255, 0.45);
    outline-offset: 2px;
}

.org-com-card--compact:active {
    transform: scale(0.995);
}

.org-com-card-cover--compact {
    aspect-ratio: 2.5 / 1;
    max-height: 118px;
}

.org-com-card-cover--placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 86px;
    max-height: 118px;
    color: var(--text-soft);
    font-size: 1.65rem;
    background: linear-gradient(
        145deg,
        var(--surface-level-2, #e8e8ed),
        var(--surface-level-1, #f2f2f7)
    );
}

.org-com-card-inner--compact {
    padding: 0.72rem 1rem 0.8rem;
}

.org-com-title--compact {
    font-size: 0.98rem;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom: 0.28rem;
    padding-right: 1rem;
}

.org-com-meta--compact {
    font-size: 0.74rem;
    margin-bottom: 0.25rem;
    line-height: 1.35;
}

.org-com-card-hint {
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--color-primary);
    margin: 0.2rem 0 0;
    letter-spacing: 0.02em;
    display: flex;
    align-items: center;
    gap: 0.3rem;
}

.org-com-card-actions--compact {
    margin-top: 0.5rem;
}

.org-com-card--compact .org-com-dot {
    top: 0.62rem;
    right: 0.62rem;
}

.org-com-detail-sheet {
    margin: -0.5rem 0 0;
}

.org-com-detail-cover {
    width: calc(100% + 0rem);
    margin: 0 0 0.75rem;
    border-radius: 14px;
    overflow: hidden;
    background: var(--surface-level-2);
    max-height: min(38vh, 260px);
}

.org-com-detail-cover img {
    width: 100%;
    height: auto;
    max-height: min(38vh, 260px);
    object-fit: cover;
    display: block;
}

.org-com-detail-inner {
    padding: 0 0.15rem 0.35rem;
}

.org-com-detail-title {
    font-size: 1.28rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.22;
    margin: 0 0 0.45rem;
    color: var(--color-text);
}

.org-com-detail-meta {
    font-size: 0.84rem;
    color: var(--text-soft);
    margin: 0 0 1rem;
    line-height: 1.45;
}

.org-com-prose--detail {
    max-height: min(54vh, 520px);
    overflow-y: auto;
    padding-right: 0.35rem;
}

.org-com-detail-actions {
    margin-top: 1.15rem;
    padding-top: 1rem;
    border-top: 0.5px solid var(--separator-color);
    display: flex;
    justify-content: flex-end;
}

.org-com-prose {
    font-size: 0.94rem;
    line-height: 1.55;
    color: var(--color-text);
    word-wrap: break-word;
}

.org-com-prose--plain {
    color: var(--text-soft);
}

.org-com-prose p {
    margin: 0 0 0.75em;
}

.org-com-prose p:last-child {
    margin-bottom: 0;
}

.org-com-prose h1,
.org-com-prose h2,
.org-com-prose h3 {
    font-weight: 700;
    margin: 1.1em 0 0.45em;
    line-height: 1.25;
    letter-spacing: -0.02em;
}

.org-com-prose h1 {
    font-size: 1.28rem;
}

.org-com-prose h2 {
    font-size: 1.1rem;
}

.org-com-prose h3 {
    font-size: 1.02rem;
}

.org-com-prose pre {
    margin: 0.75em 0;
    padding: 0.75rem 0.9rem;
    border-radius: 12px;
    background: var(--surface-level-2, rgba(0, 0, 0, 0.05));
    border: 0.5px solid var(--separator-color);
    font-family: "SF Mono", "Menlo", "Consolas", monospace;
    font-size: 0.84em;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
}

.org-com-prose code {
    font-family: "SF Mono", "Menlo", "Consolas", monospace;
    font-size: 0.88em;
    padding: 0.12em 0.35em;
    border-radius: 6px;
    background: rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .org-com-prose code {
    background: rgba(255, 255, 255, 0.08);
}

.org-com-prose mark {
    border-radius: 3px;
    padding: 0.06em 0.12em;
}

.org-com-prose table.org-com-prose-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0.9em 0;
    font-size: 0.92em;
    border-radius: 12px;
    overflow: hidden;
    border: 0.5px solid var(--separator-color);
}

.org-com-prose table.org-com-prose-table th,
.org-com-prose table.org-com-prose-table td {
    border: 0.5px solid var(--separator-color);
    padding: 0.48rem 0.58rem;
    vertical-align: top;
}

.org-com-prose table.org-com-prose-table th {
    background: rgba(0, 0, 0, 0.04);
    font-weight: 650;
    text-align: left;
}

[data-theme="dark"] .org-com-prose table.org-com-prose-table th {
    background: rgba(255, 255, 255, 0.06);
}

/* Tabelas inseridas no contenteditable não ficam dentro de .org-com-prose */
.org-com-rich-editor table.org-com-prose-table {
    width: 100%;
    border-collapse: collapse;
    margin: 0.9em 0;
    font-size: 0.92em;
    border-radius: 12px;
    overflow: hidden;
    border: 0.5px solid var(--separator-color);
    table-layout: fixed;
    min-height: 4.5rem;
}

.org-com-rich-editor table.org-com-prose-table th,
.org-com-rich-editor table.org-com-prose-table td {
    border: 0.5px solid var(--separator-color);
    padding: 0.48rem 0.58rem;
    vertical-align: top;
    min-width: 2rem;
    min-height: 2.25rem;
    box-sizing: border-box;
}

.org-com-rich-editor table.org-com-prose-table th {
    background: rgba(0, 0, 0, 0.04);
    font-weight: 650;
    text-align: left;
}

[data-theme="dark"] .org-com-rich-editor table.org-com-prose-table th {
    background: rgba(255, 255, 255, 0.06);
}

.org-com-embed-wrap {
    position: relative;
    width: 100%;
    margin: 1rem 0;
    border-radius: 14px;
    overflow: hidden;
    background: #000;
    aspect-ratio: 16 / 9;
    max-height: min(52vh, 440px);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.12);
}

.org-com-embed-frame {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 200px;
    border: 0;
}

.org-com-prose hr {
    border: none;
    border-top: 0.5px solid var(--separator-color);
    margin: 1.1em 0;
}

.org-com-prose ul,
.org-com-prose ol {
    margin: 0.5em 0 0.75em;
    padding-left: 1.35em;
}

.org-com-prose li {
    margin: 0.25em 0;
}

.org-com-prose blockquote {
    margin: 0.75em 0;
    padding: 0.65rem 0.9rem;
    border-left: 3px solid var(--color-primary);
    background: rgba(10, 132, 255, 0.06);
    border-radius: 0 12px 12px 0;
    font-style: italic;
    color: var(--text-soft);
}

.org-com-prose a {
    color: var(--color-primary);
    font-weight: 600;
    text-decoration: none;
}

.org-com-prose a:hover {
    text-decoration: underline;
}

.org-com-prose strong,
.org-com-prose b {
    font-weight: 700;
}

.org-com-rich-editor .org-com-align-center,
.org-com-prose .org-com-align-center {
    text-align: center;
}

.org-com-rich-editor .org-com-align-left,
.org-com-prose .org-com-align-left {
    text-align: left;
}

.org-com-rich-editor .org-com-align-right,
.org-com-prose .org-com-align-right {
    text-align: right;
}

.org-com-rich-editor .org-com-align-justify,
.org-com-prose .org-com-align-justify {
    text-align: justify;
    text-wrap: pretty;
}

.org-com-rich-editor td.org-com-align-center,
.org-com-rich-editor th.org-com-align-center,
.org-com-prose td.org-com-align-center,
.org-com-prose th.org-com-align-center {
    text-align: center;
}

.org-com-rich-editor td.org-com-align-right,
.org-com-rich-editor th.org-com-align-right,
.org-com-prose td.org-com-align-right,
.org-com-prose th.org-com-align-right {
    text-align: right;
}

.org-com-rich-editor td.org-com-align-left,
.org-com-rich-editor th.org-com-align-left,
.org-com-prose td.org-com-align-left,
.org-com-prose th.org-com-align-left {
    text-align: left;
}

.org-com-rich-editor td.org-com-align-justify,
.org-com-rich-editor th.org-com-align-justify,
.org-com-prose td.org-com-align-justify,
.org-com-prose th.org-com-align-justify {
    text-align: justify;
}

.org-com-prose img,
.org-com-prose .org-com-inline-img {
    max-width: 100%;
    height: auto;
    border-radius: 12px;
    margin: 0.65rem 0;
    display: block;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .org-com-prose blockquote {
    background: rgba(10, 132, 255, 0.12);
}

[data-theme="dark"] .org-com-card-cover {
    background: var(--surface-level-2, #2c2c2e);
}

.org-com-modal-form .ios-label {
    display: block;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-soft);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.4rem;
}

.org-com-modal-lead {
    color: var(--text-soft);
    margin: 0 0 1.1rem;
    font-size: 0.92rem;
    line-height: 1.45;
}

.org-com-editor-hint {
    font-size: 0.8rem;
    color: var(--text-muted, var(--text-soft));
    margin: 0 0 0.5rem;
    line-height: 1.35;
}

.org-com-video-box {
    margin: 0 0 0.5rem;
    padding: 0.65rem 0.75rem;
    border-radius: 12px;
    background: var(--surface-level-1);
    border: 0.5px solid var(--separator-color);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

.org-com-video-box__label {
    margin: 0 0 0.4rem;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-soft);
}

.org-com-video-box__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
}

.org-com-video-box__input {
    flex: 1;
    min-width: 180px;
    font-size: 0.88rem;
}

.org-com-video-box__btn {
    flex-shrink: 0;
    border-radius: 10px;
}

.org-com-video-box__hint {
    margin: 0.45rem 0 0;
    font-size: 0.72rem;
    color: var(--text-muted, var(--text-soft));
    line-height: 1.35;
}

.org-com-editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem;
    padding: 0.4rem 0.5rem;
    margin-bottom: 0.35rem;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.04);
    border: 0.5px solid var(--separator-color);
}

[data-theme="dark"] .org-com-editor-toolbar {
    background: rgba(255, 255, 255, 0.06);
}

.org-com-editor-toolbar--docs {
    flex-direction: column;
    align-items: stretch;
    gap: 0.38rem;
    padding: 0.45rem 0.5rem;
}

.org-com-tb-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.22rem;
    min-width: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 1px;
    scrollbar-width: thin;
}

.org-com-tb-select {
    height: 34px;
    padding: 0 2.1rem 0 0.55rem;
    border-radius: 10px;
    border: 0.5px solid var(--separator-color);
    background: var(--surface-level-1);
    color: var(--color-text);
    font-size: 0.78rem;
    font-weight: 500;
    max-width: 11.5rem;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 12 12'%3E%3Cpath fill='%238e8e93' d='M3 4.5L6 8l3-3.5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.45rem center;
}

.org-com-tb-color-hit {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 34px;
    border-radius: 10px;
    cursor: pointer;
    background: var(--surface-level-1);
    border: 0.5px solid var(--separator-color);
}

.org-com-modal-form .org-com-editor-toolbar--docs .org-com-tb-color-hit {
    width: 40px;
    height: 38px;
}

.org-com-tb-color-hit:hover {
    background: rgba(0, 0, 0, 0.04);
}

[data-theme="dark"] .org-com-tb-color-hit:hover {
    background: rgba(255, 255, 255, 0.06);
}

.org-com-tb-color-icon {
    position: absolute;
    font-size: 0.72rem;
    opacity: 0.55;
    pointer-events: none;
}

.org-com-tb-color {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    cursor: pointer;
    padding: 0;
    border: none;
}

.org-com-tb-btn {
    width: 36px;
    height: 34px;
    border: none;
    border-radius: 8px;
    background: transparent;
    color: var(--color-text);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.85rem;
    transition: background 0.15s ease;
}

.org-com-tb-btn:hover {
    background: rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .org-com-tb-btn:hover {
    background: rgba(255, 255, 255, 0.08);
}

.org-com-tb-sep {
    width: 1px;
    height: 20px;
    background: var(--separator-color);
    margin: 0 0.15rem;
}

.org-com-rich-editor {
    min-height: 140px;
    max-height: 280px;
    overflow-y: auto;
    padding: 0.75rem 0.9rem;
    border-radius: 12px;
    border: 0.5px solid var(--separator-color);
    background: var(--surface-level-1);
    color: var(--color-text);
    font-size: 0.94rem;
    line-height: 1.5;
    outline: none;
}

.org-com-rich-editor:focus {
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.22);
    border-color: var(--color-primary);
}

.org-com-rich-editor .org-com-video-embed {
    min-height: 104px;
    margin: 0.6rem 0;
    border-radius: 12px;
    border: 2px dashed var(--separator-color);
    background: rgba(10, 132, 255, 0.07);
    box-sizing: border-box;
}

.org-com-rich-editor .org-com-video-embed::after {
    content: "Pré-visualização: vídeo incorporado ao publicar";
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 104px;
    padding: 0.5rem;
    text-align: center;
    font-size: 0.78rem;
    color: var(--text-soft);
    font-weight: 500;
}

.org-com-conteudo-source {
    position: absolute;
    left: -9999px;
    width: 1px;
    height: 1px;
    overflow: hidden;
    opacity: 0;
}

.org-com-capa-preview {
    margin-top: 0.65rem;
    border-radius: 12px;
    overflow: hidden;
    max-height: 140px;
    border: 0.5px solid var(--separator-color);
}

.org-com-capa-preview img {
    width: 100%;
    height: 100%;
    max-height: 140px;
    object-fit: cover;
    display: block;
}

.org-com-form-actions {
    margin-top: 1.25rem;
    display: flex;
    gap: 0.65rem;
    justify-content: flex-end;
    flex-wrap: wrap;
    align-items: center;
}

.org-com-btn-secondary {
    background: transparent !important;
    border: 1px solid var(--glass-border) !important;
    color: var(--color-text) !important;
    border-radius: 999px !important;
    padding: 0.5rem 1rem !important;
}

.org-com-btn-primary {
    border-radius: 999px !important;
}

#processosListPage .ios-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 2.25rem 1.75rem 2.5rem;
    border-radius: 20px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    border: 0.5px solid var(--separator-color, var(--glass-border));
    background: var(--surface-level-1);
    max-width: 420px;
    margin: 2rem auto;
}

#processosListPage .ios-empty-state__icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: rgba(0, 122, 255, 0.1);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.25rem;
}

#processosListPage .ios-empty-state__icon {
    font-size: 2rem;
    color: var(--color-primary);
    opacity: 0.9;
}

#processosListPage .ios-empty-state__title {
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: var(--color-text);
    margin: 0 0 0.5rem;
    line-height: 1.2;
}

#processosListPage .ios-empty-state__caption {
    font-size: 0.95rem;
    line-height: 1.45;
    color: var(--text-soft);
    margin: 0;
    max-width: 34ch;
}

[data-theme="dark"] #processosListPage .ios-empty-state__icon-wrap {
    background: rgba(10, 132, 255, 0.18);
}

.org-empty-msg {
    color: var(--text-soft);
    font-size: 0.95rem;
    padding: 0.5rem 0;
}

.org-dash-text-link {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
}

.org-dash-text-link:hover {
    text-decoration: underline;
}

.org-proc-compact {
    flex-direction: column;
    align-items: flex-start !important;
    gap: 0.35rem;
}

.org-proc-sub {
    font-size: 0.82rem;
    color: var(--text-soft);
}

.org-mov-list {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.org-mov-row {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding: 0.75rem 0.85rem;
    border-radius: 12px;
    text-decoration: none;
    color: inherit;
    border: 1px solid transparent;
    transition: background 0.15s ease, border-color 0.15s ease;
}

.org-mov-row:hover {
    background: var(--surface-level-2);
    border-color: var(--glass-border);
}

.org-mov-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    margin-top: 0.45rem;
    flex-shrink: 0;
    background: var(--color-primary);
}

.org-mov-row--seen .org-mov-dot {
    display: none;
}

.org-mov-body {
    flex: 1;
    min-width: 0;
}

.org-mov-event {
    font-weight: 600;
    font-size: 0.92rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.org-mov-meta {
    font-size: 0.78rem;
    color: var(--text-soft);
    margin-top: 0.2rem;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.org-mov-chevron {
    color: var(--text-tertiary);
    font-size: 0.75rem;
    margin-top: 0.35rem;
}

/* Mini-calendário */
.org-cal-widget {
    overflow: hidden;
}

.org-cal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.85rem;
}

.org-cal-title {
    font-size: 1rem;
    font-weight: 700;
    margin: 0;
}

.org-cal-slide-viewport {
    overflow: hidden;
}

.org-cal-slide-inner {
    transition: transform 0.34s cubic-bezier(0.32, 0.72, 0, 1), opacity 0.28s ease;
}

.org-cal-slide-inner.org-cal--out-left {
    transform: translate3d(-32px, 0, 0);
    opacity: 0;
}

.org-cal-slide-inner.org-cal--out-right {
    transform: translate3d(32px, 0, 0);
    opacity: 0;
}

.org-cal-slide-inner.org-cal--in-from-right {
    transition: none;
    transform: translate3d(40px, 0, 0);
    opacity: 0;
}

.org-cal-slide-inner.org-cal--in-from-left {
    transition: none;
    transform: translate3d(-40px, 0, 0);
    opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
    .org-cal-slide-inner {
        transition-duration: 0.01ms !important;
    }
}

.org-cal-nav {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    color: var(--color-primary);
    background: var(--surface-level-2);
    text-decoration: none;
    transition: opacity 0.15s;
    border: none;
    padding: 0;
    cursor: pointer;
    font: inherit;
}

.org-cal-nav:hover {
    opacity: 0.85;
}

.org-cal-nav:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.org-cal-weekdays {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
    margin-bottom: 0.35rem;
    font-size: 0.65rem;
    font-weight: 600;
    color: var(--text-soft);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.org-cal-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 3px;
}

.org-cal-cell {
    aspect-ratio: 1;
    max-height: none;
    min-height: 0;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 0.8rem;
    font-weight: 600;
    background: var(--surface-level-2);
    border: 1px solid transparent;
    position: relative;
    padding: 2px;
}

.org-cal-cell--empty {
    background: transparent;
    border: none;
}

.org-cal-cell--today {
    border-color: var(--color-primary);
    box-shadow: inset 0 0 0 1px var(--color-primary);
}

.org-cal-cell--events {
    background: rgba(0, 122, 255, 0.08);
}

[data-theme="dark"] .org-cal-cell--events {
    background: rgba(10, 132, 255, 0.12);
}

.org-cal-daynum {
    line-height: 1;
}

.org-cal-dots {
    display: flex;
    gap: 2px;
    margin-top: 2px;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 100%;
}

.org-cal-dot {
    width: 5px;
    height: 5px;
    border-radius: 50%;
    display: inline-block;
    vertical-align: middle;
    font-style: normal;
    font-size: 0;
}

.org-cal-dot--a,
.org-cal-dot.a {
    background: #AF52DE;
}

.org-cal-dot--p,
.org-cal-dot.p {
    background: var(--color-accent);
}

.org-cal-cell--tap {
    cursor: pointer;
    transition: transform 0.12s ease, background 0.15s ease;
}

.org-cal-cell--tap:hover {
    transform: scale(1.04);
    background: rgba(0, 122, 255, 0.06);
}

.org-cal-cell--tap:focus-visible {
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
}

[data-theme="dark"] .org-cal-cell--tap:hover {
    background: rgba(10, 132, 255, 0.14);
}

/* Modal agenda do dia — iOS HIG / iosdesign.md (squircles, sombra suave, sem barra lateral) */
.ios-cal-day-modal {
    padding: 0.25rem 0.15rem 0.65rem;
    max-width: 100%;
}

.ios-cal-day-modal__empty {
    text-align: center;
    padding: 1.5rem 1rem 1rem;
    color: var(--text-soft);
}

.ios-cal-day-modal__empty i {
    font-size: 2.25rem;
    opacity: 0.38;
    display: block;
    margin-bottom: 0.65rem;
}

.ios-cal-day-modal__empty p {
    margin: 0;
    font-size: 0.94rem;
    font-weight: 500;
    letter-spacing: -0.01em;
}

.ios-cal-day-modal__card {
    border-radius: 18px;
    padding: 1rem 1.15rem;
    margin-bottom: 0.65rem;
    border: 0.5px solid rgba(60, 60, 67, 0.12);
    background: var(--color-white, #ffffff);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.045);
}

[data-theme="dark"] .ios-cal-day-modal__card {
    background: rgba(44, 44, 46, 0.92);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.28);
}

.ios-cal-day-modal__card:last-of-type {
    margin-bottom: 0.35rem;
}

.ios-cal-day-modal__card--a .ios-cal-day-modal__badge {
    background: rgba(175, 82, 222, 0.12);
    color: #9842c8;
}

.ios-cal-day-modal__card--p .ios-cal-day-modal__badge {
    background: rgba(255, 149, 0, 0.14);
    color: #c35a00;
}

[data-theme="dark"] .ios-cal-day-modal__card--a .ios-cal-day-modal__badge {
    background: rgba(191, 90, 242, 0.18);
    color: #dab4ff;
}

[data-theme="dark"] .ios-cal-day-modal__card--p .ios-cal-day-modal__badge {
    background: rgba(255, 159, 10, 0.18);
    color: #ffcc80;
}

.ios-cal-day-modal__badge {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    padding: 0.22rem 0.55rem;
    border-radius: 8px;
    font-size: 0.65rem;
    font-weight: 650;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.5rem;
}

.ios-cal-day-modal__when {
    font-weight: 650;
    font-size: 1rem;
    letter-spacing: -0.02em;
    margin-bottom: 0.3rem;
    color: var(--color-text);
}

.ios-cal-day-modal__numero {
    font-size: 0.84rem;
    color: #007aff;
    font-weight: 600;
    margin-bottom: 0.35rem;
    word-break: break-all;
    letter-spacing: -0.01em;
}

[data-theme="dark"] .ios-cal-day-modal__numero {
    color: #0a84ff;
}

.ios-cal-day-modal__assunto {
    font-size: 0.875rem;
    line-height: 1.38;
    margin-bottom: 0.4rem;
    color: var(--color-text);
    font-weight: 500;
    letter-spacing: -0.01em;
}

.ios-cal-day-modal__meta,
.ios-cal-day-modal__detail {
    font-size: 0.8125rem;
    color: var(--text-soft);
    line-height: 1.42;
    margin-bottom: 0.5rem;
}

.ios-cal-day-modal__link {
    display: inline-flex;
    align-items: center;
    margin-top: 0.45rem;
    border-radius: 14px;
    font-size: 0.875rem;
    font-weight: 600;
    text-decoration: none;
    padding: 0.5rem 1rem;
}

.ios-cal-day-modal__foot {
    margin-top: 0.65rem;
    padding-top: 0.15rem;
}

.ios-cal-day-modal__close {
    width: 100%;
    border-radius: 14px;
    padding: 0.7rem 1rem;
    font-weight: 600;
    font-size: 0.9375rem;
    border: none;
    background: rgba(120, 120, 128, 0.12);
    color: var(--color-text);
}

.ios-cal-day-modal__close:hover {
    background: rgba(120, 120, 128, 0.18);
}

[data-theme="dark"] .ios-cal-day-modal__close {
    background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .ios-cal-day-modal__close:hover {
    background: rgba(255, 255, 255, 0.16);
}

.ios-dash-audiencias-card .ios-subsection-title {
    margin-bottom: 0.65rem;
}

.ios-dash-audiencias-list {
    gap: 0.5rem;
}

.ios-dash-audiencia-row {
    gap: 0.35rem !important;
    position: relative;
    padding-left: 0.85rem;
    border-left: 3px solid rgba(175, 82, 222, 0.85);
}

.ios-dash-audiencia-badge {
    font-size: 0.65rem;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #af52de;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

[data-theme="dark"] .ios-dash-audiencia-row {
    border-left-color: rgba(191, 90, 242, 0.9);
}

[data-theme="dark"] .ios-dash-audiencia-badge {
    color: #bf5af2;
}

.ios-dash-audiencia-assunto {
    font-size: 0.78rem;
    color: var(--text-soft);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ios-dash-audiencias-empty {
    text-align: center;
    padding: 1.15rem 0.75rem 1.25rem;
    border-radius: 14px;
    background: rgba(120, 120, 128, 0.06);
    border: 0.5px dashed var(--glass-border);
}

.ios-dash-audiencias-empty__icon {
    font-size: 2rem;
    opacity: 0.35;
    margin-bottom: 0.5rem;
}

.ios-dash-audiencias-empty__title {
    margin: 0 0 0.35rem;
    font-size: 0.95rem;
    font-weight: 650;
    color: var(--color-text);
}

.ios-dash-audiencias-empty__caption {
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--text-soft);
}

@media (max-width: 640px) {
    .org-cal-widget {
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
        max-width: 100%;
        min-width: 0;
    }

    .org-cal-header {
        gap: 0.35rem;
        min-width: 0;
    }

    .org-cal-title {
        flex: 1 1 auto;
        min-width: 0;
        font-size: 0.86rem;
        line-height: 1.2;
        text-align: center;
    }

    .org-cal-nav {
        width: 32px;
        height: 32px;
        flex-shrink: 0;
    }

    .org-cal-slide-viewport {
        overflow: visible;
        width: 100%;
        min-width: 0;
    }

    .org-cal-slide-inner {
        min-width: 0;
        width: 100%;
    }

    .org-cal-weekdays,
    .org-cal-grid {
        gap: 2px;
        width: 100%;
        min-width: 0;
    }

    .org-cal-weekdays {
        font-size: 0.56rem;
    }

    .org-cal-cell {
        font-size: 0.62rem;
        border-radius: 7px;
        padding: 1px;
    }

    .org-cal-daynum {
        font-size: 0.65rem;
    }
}

.org-cal-legend {
    display: flex;
    gap: 1rem;
    margin-top: 0.85rem;
    font-size: 0.75rem;
    color: var(--text-soft);
    flex-wrap: wrap;
}

.org-cal-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

/* Agenda */
.org-agenda-list {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    max-height: 360px;
    overflow-y: auto;
}

.org-agenda-item {
    display: flex;
    gap: 0.75rem;
    padding: 0.75rem 0.85rem;
    border-radius: 14px;
    text-decoration: none;
    color: inherit;
    background: var(--surface-level-2);
    border: 1px solid var(--glass-border);
    transition: transform 0.12s ease, border-color 0.12s ease;
}

.org-agenda-item:hover {
    transform: translateX(2px);
    border-color: var(--color-primary);
}

.org-agenda-badge {
    flex-shrink: 0;
    align-self: flex-start;
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    padding: 0.28rem 0.45rem;
    border-radius: 8px;
    white-space: nowrap;
}

.org-agenda-badge--aud {
    background: rgba(175, 82, 222, 0.18);
    color: #AF52DE;
}

.org-agenda-badge--prz {
    background: rgba(255, 149, 0, 0.18);
    color: var(--color-accent);
}

[data-theme="dark"] .org-agenda-badge--aud {
    color: #BF5AF2;
}

.org-agenda-content {
    flex: 1;
    min-width: 0;
}

.org-agenda-when {
    font-weight: 700;
    font-size: 0.85rem;
}

.org-agenda-proc {
    font-size: 0.82rem;
    color: var(--color-primary);
    font-weight: 600;
    margin-top: 0.15rem;
}

.org-agenda-extra {
    font-size: 0.78rem;
    color: var(--text-soft);
    margin-top: 0.2rem;
}

.org-agenda-msg {
    font-size: 0.8rem;
    color: var(--text-soft);
    margin-top: 0.35rem;
    line-height: 1.35;
}

/* ——— Painel inicial (dashboard global) ——— */
.dash-home {
    max-width: 1280px;
    margin: 0 auto;
    padding-bottom: 2rem;
}

.dash-hero {
    display: grid;
    grid-template-columns: 1fr minmax(280px, 420px);
    gap: 1.5rem;
    align-items: start;
    padding: 1.5rem 1.75rem;
    margin-bottom: 1rem;
}

@media (max-width: 960px) {
    .dash-hero {
        grid-template-columns: 1fr;
    }
}

.dash-hello {
    font-size: 0.9rem;
    color: var(--text-soft);
    margin-bottom: 0.25rem;
}

.dash-hero-title {
    font-size: 1.85rem;
    margin-bottom: 0.35rem;
}

.dash-hero-sub {
    max-width: 36rem;
    line-height: 1.45;
}

.dash-search-form {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.dash-search-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-soft);
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.dash-search-box {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 0.5rem;
    padding: 0.5rem 0.65rem;
    background: var(--surface-level-2);
    border-radius: 14px;
    border: 1px solid var(--glass-border);
}

.dash-search-box .search-input {
    flex: 1;
    min-width: 180px;
    border: none;
    background: transparent;
}

.dash-search-submit {
    border-radius: 11px;
    padding: 0.45rem 1rem;
    font-weight: 600;
    flex-shrink: 0;
}

.dash-search-hint {
    font-size: 0.75rem;
    color: var(--text-soft);
    line-height: 1.35;
}

.dash-privacy-hint {
    display: flex;
    gap: 0.85rem;
    align-items: flex-start;
    padding: 0.9rem 1.1rem;
    margin-bottom: 1rem;
    font-size: 0.88rem;
    line-height: 1.45;
    border-radius: 14px;
}

.dash-privacy-hint i {
    color: var(--color-primary);
    margin-top: 0.15rem;
}

.dash-widgets.dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.dash-two-col {
    display: grid;
    grid-template-columns: 1fr minmax(260px, 320px);
    gap: 1.25rem;
    align-items: start;
    margin-top: 0.25rem;
}

@media (max-width: 1024px) {
    .dash-two-col {
        grid-template-columns: 1fr;
    }
}

.dash-col {
    min-width: 0;
}

.dash-col-aside .widget-card.org-cal-widget {
    max-width: 100%;
}

.dash-table-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.dash-mini-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.dash-mini-link {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    text-decoration: none;
    color: inherit;
    padding: 0.6rem 0.65rem;
    border-radius: 12px;
    background: var(--surface-level-2);
    border: 1px solid var(--glass-border);
    transition: border-color 0.15s ease, transform 0.12s ease;
}

.dash-mini-link:hover {
    border-color: var(--color-primary);
    transform: translateX(2px);
}

.dash-mini-date {
    font-weight: 700;
    font-size: 0.82rem;
}

.dash-mini-proc {
    font-size: 0.8rem;
    color: var(--color-primary);
    font-weight: 600;
}

.dash-mini-meta {
    font-size: 0.75rem;
    color: var(--text-soft);
}

.dash-org-shortcuts {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.dash-org-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.35rem 0.75rem;
    border-radius: 999px;
    font-size: 0.82rem;
    font-weight: 600;
    text-decoration: none;
    background: var(--surface-level-2);
    color: var(--color-text);
    border: 1px solid var(--glass-border);
}

.dash-org-pill:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.dash-org-pill--pub {
    background: rgba(0, 122, 255, 0.08);
}

/* ——— Dashboard iOS (Human Interface) ——— */
.ios-dash {
    --ios-search-bg: #e3e3e8;
}

[data-theme="dark"] .ios-dash {
    --ios-search-bg: rgba(58, 58, 60, 0.85);
}

.ios-dash-header {
    margin-bottom: 1rem;
}

.ios-dash-eyebrow {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text-soft);
    margin-bottom: 0.2rem;
}

.ios-dash-large-title {
    font-size: 2.125rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.1;
    margin: 0 0 0.35rem 0;
    color: var(--color-text);
}

.ios-dash-caption {
    font-size: 0.95rem;
    color: var(--text-soft);
    line-height: 1.4;
    max-width: 40rem;
    margin: 0;
}

.ios-dash-search-form {
    margin-bottom: 0.65rem;
    width: 100%;
}

.ios-dash-search-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem 1rem;
    width: 100%;
}

.ios-dash-search-row .ios-search-pill {
    flex: 1 1 260px;
    max-width: min(560px, 100%);
}

.ios-dash-quick-links {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem 0.55rem;
    margin-left: auto;
}

.ios-dash-quick-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
    padding: 0.48rem 0.95rem;
    border-radius: 999px;
    background: var(--surface-level-1);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
    white-space: nowrap;
    cursor: pointer;
    font-family: inherit;
    line-height: 1.2;
    transition: border-color 0.15s ease, opacity 0.15s ease;
}

.ios-dash-quick-link:hover {
    border-color: var(--color-primary);
    opacity: 0.95;
}

.ios-dash-quick-link--accent {
    background: var(--color-primary);
    border-color: transparent;
    color: #fff;
}

.ios-dash-quick-link--accent:hover {
    opacity: 0.92;
    border-color: transparent;
}

.ios-dash-quick-link .fas,
.ios-dash-quick-link .fa-solid {
    font-size: 0.88em;
    font-weight: 900;
}

@media (max-width: 768px) {
    .ios-dash-quick-links {
        margin-left: 0;
        width: 100%;
        flex-direction: column;
        align-items: stretch;
        gap: 0.5rem;
    }

    .ios-dash-quick-link {
        width: 100%;
        justify-content: center;
        white-space: normal;
        text-align: center;
    }

    .ios-dash-search-row .ios-search-pill {
        max-width: none;
    }

    .ios-dash-privacy-note {
        margin-left: 0;
        margin-right: 0;
        max-width: none;
    }

    .ios-dash-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.65rem;
    }
}

.ios-search-pill {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.35rem 0.45rem 0.35rem 1rem;
    background: var(--ios-search-bg);
    border-radius: 999px;
    border: none;
    box-shadow: none;
}

.ios-search-pill__input {
    flex: 1;
    min-width: 0;
    border: none;
    background: transparent;
    font-size: 1rem;
    color: var(--color-text);
    padding: 0.55rem 0;
    outline: none;
}

.ios-search-pill__input::placeholder {
    color: var(--text-soft);
}

.ios-search-pill__submit {
    flex-shrink: 0;
    border: none;
    border-radius: 999px;
    padding: 0.5rem 1.15rem;
    font-size: 0.9rem;
    font-weight: 600;
    background: var(--color-primary);
    color: #fff;
    cursor: pointer;
    transition: opacity 0.15s ease, transform 0.12s ease;
}

.ios-search-pill__submit:hover {
    opacity: 0.92;
}

.ios-search-pill__submit:active {
    transform: scale(0.98);
}

.ios-search-footnote {
    font-size: 0.78rem;
    color: var(--text-soft);
    line-height: 1.35;
    max-width: 520px;
    margin: 0.5rem 0 0 0;
}

.ios-dash-privacy-note {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    font-size: 0.8rem;
    color: var(--text-soft);
    line-height: 1.4;
    max-width: 42rem;
    margin: 0 0 1.25rem 1rem;
    padding: 0;
}

.ios-dash-privacy-note i {
    margin-top: 0.12rem;
    color: var(--color-primary);
    opacity: 0.85;
}

.ios-dash-section {
    margin-bottom: 1.35rem;
}

.ios-dash-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.65rem;
    padding-left: 0.25rem;
}

.ios-dash-section-title {
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0;
}

.ios-badge {
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    background: var(--color-danger);
    color: #fff;
}

.ios-grouped-stack {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.ios-card {
    border-radius: 16px;
    padding: 0;
    overflow: hidden;
    box-shadow: var(--glass-shadow);
}

.ios-card--warn {
    border-left: 3px solid var(--color-accent);
}

.ios-card--orange {
    border-left: 3px solid var(--color-accent);
}

.ios-card--pendencias-acao {
    border-left: 4px solid var(--color-danger);
}

[data-theme="dark"] .ios-card--pendencias-acao {
    border-left-color: #ff453a;
}

.ios-pendencias-hint {
    font-size: 0.78rem;
    line-height: 1.35;
    color: var(--text-soft);
    padding: 0 1rem 0.6rem;
    margin: 0;
}

.ios-pendencia-shell {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    padding: 0.65rem 1rem 0.75rem;
}

.ios-pendencia-shell--notif {
    align-items: stretch;
}

.ios-pendencia-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.ios-pendencia-body--fill {
    min-width: 0;
}

.ios-inset-link--pendencia {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.15rem 0.75rem;
    padding: 0;
    text-decoration: none;
    color: inherit;
    align-items: start;
    transition: background 0.12s ease;
    border-radius: 8px;
    margin: 0;
    min-width: 0;
}

.ios-inset-link--pendencia:hover {
    background: var(--surface-level-2);
}

.ios-pendencia-badge {
    font-size: 0.62rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    padding: 0.18rem 0.45rem;
    border-radius: 6px;
    align-self: flex-start;
    line-height: 1.2;
}

.ios-pendencia-badge--warn {
    background: rgba(255, 149, 0, 0.18);
    color: var(--color-accent);
}

.ios-pendencia-badge--ciencia {
    background: rgba(0, 122, 255, 0.16);
    color: #007aff;
}

[data-theme="dark"] .ios-pendencia-badge--ciencia {
    color: #64b5ff;
}

.ios-pendencia-badge--prazo {
    background: rgba(255, 59, 48, 0.14);
    color: var(--color-danger);
}

.ios-dash-dismiss-btn {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: var(--surface-level-2);
    color: var(--text-soft);
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.ios-dash-dismiss-btn:hover {
    background: var(--separator-color);
    color: var(--color-text);
}

.ios-pendencia-shell .ios-ciencia-row__inner {
    padding: 0.35rem 0 0;
    width: 100%;
}

.ios-card--ciencia-pendente {
    border: 1px solid rgba(0, 122, 255, 0.32);
    border-left-width: 4px;
    border-left-color: #007aff;
    background: linear-gradient(
        160deg,
        rgba(0, 122, 255, 0.1) 0%,
        var(--glass-bg) 42%,
        var(--glass-bg) 100%
    );
    box-shadow: 0 10px 36px rgba(0, 122, 255, 0.14);
}

[data-theme="dark"] .ios-card--ciencia-pendente {
    border-color: rgba(10, 132, 255, 0.4);
    border-left-color: #0a84ff;
    background: linear-gradient(
        160deg,
        rgba(10, 132, 255, 0.18) 0%,
        var(--glass-bg) 45%,
        var(--glass-bg) 100%
    );
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}

.ios-card-label--ciencia {
    font-size: 0.78rem;
    color: #007aff;
    padding-top: 1rem;
    padding-bottom: 0.25rem;
}

[data-theme="dark"] .ios-card-label--ciencia {
    color: #64b5ff;
}

.ios-ciencia-row__inner {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.6rem;
    padding: 0.75rem 1rem 0.9rem;
}

.ios-ciencia-row__main {
    width: 100%;
}

.ios-ciencia-row__link {
    display: block;
    text-decoration: none;
    color: inherit;
    min-width: 0;
}

.ios-ciencia-row__link .ios-inset-title,
.ios-ciencia-row__link .ios-inset-meta {
    display: block;
    width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.ios-ciencia-row__link .ios-inset-meta {
    margin-top: 0.2rem;
}

.ios-btn-ciencia-dash {
    flex-shrink: 0;
    padding: 0.42rem 1.15rem;
    border-radius: 999px;
    border: none;
    font-size: 0.82rem;
    font-weight: 650;
    color: #fff;
    background: #007aff;
    cursor: pointer;
    transition: opacity 0.15s ease, transform 0.1s ease;
}

.ios-btn-ciencia-dash:hover {
    opacity: 0.92;
}

.ios-btn-ciencia-dash:active {
    transform: scale(0.97);
}

[data-theme="dark"] .ios-btn-ciencia-dash {
    background: #0a84ff;
}

.proc-pendencias-card {
    border: 1px solid rgba(0, 122, 255, 0.28);
    border-left: 4px solid #007aff;
    background: linear-gradient(
        105deg,
        rgba(0, 122, 255, 0.07) 0%,
        transparent 55%
    );
}

[data-theme="dark"] .proc-pendencias-card {
    border-color: rgba(10, 132, 255, 0.35);
    border-left-color: #0a84ff;
}

.proc-pendencias-card .proc-section-title {
    color: var(--color-text);
    margin-bottom: 0.75rem;
}

.proc-pendencia-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 0;
    border-top: 0.5px solid var(--separator-color);
}

.proc-pendencia-row:first-of-type {
    border-top: none;
    padding-top: 0;
}

.proc-pendencia-row__meta {
    flex: 1;
    min-width: 200px;
}

.proc-pendencia-row__titulo {
    font-weight: 650;
    font-size: 0.95rem;
    color: var(--color-text);
}

.proc-pendencia-row__sub {
    font-size: 0.8rem;
    color: var(--text-soft);
    margin-top: 0.2rem;
}

.proc-manifestacao-row {
    background: rgba(255, 193, 7, 0.05);
    padding: 1rem;
    border-radius: 8px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.75rem;
    flex-wrap: wrap;
}

.proc-manifestacao-row__body {
    flex: 1;
    min-width: min(100%, 12rem);
}

.proc-manifestacao-row__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    justify-content: flex-end;
}

@media (max-width: 768px) {
    .proc-manifestacao-row {
        flex-direction: column;
        align-items: stretch;
    }

    .proc-manifestacao-row__actions {
        justify-content: stretch;
    }

    .proc-manifestacao-row__actions .btn {
        flex: 1 1 auto;
        min-width: 0;
    }
}

.ios-card-label {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    padding: 0.85rem 1rem 0.35rem;
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.ios-inset-list {
    list-style: none;
    margin: 0;
    padding: 0 0 0.5rem;
}

.ios-inset-row {
    border-top: 0.5px solid var(--separator-color);
}

.ios-inset-row--unread .ios-inset-title {
    font-weight: 700;
}

.ios-inset-link,
.ios-inset-static {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 0.15rem 0.75rem;
    padding: 0.75rem 1rem;
    text-decoration: none;
    color: inherit;
    align-items: start;
    transition: background 0.12s ease;
    min-width: 0;
}

.ios-inset-link:hover {
    background: var(--surface-level-2);
}

.ios-inset-title {
    grid-column: 1;
    font-size: 0.94rem;
    line-height: 1.3;
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}

.ios-inset-meta {
    grid-column: 1;
    font-size: 0.78rem;
    color: var(--text-soft);
    white-space: normal;
    overflow-wrap: anywhere;
    word-break: break-word;
}

.ios-inset-sub {
    grid-column: 1 / -1;
    font-size: 0.8rem;
    color: var(--text-soft);
    margin-top: 0.15rem;
    min-width: 0;
    overflow-wrap: anywhere;
    word-break: break-word;
    white-space: normal;
}

.ios-meta-danger {
    color: var(--color-danger);
    font-weight: 600;
}

.ios-inset-chevron {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
    color: var(--text-tertiary);
    font-size: 0.75rem;
}

.ios-dash-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.ios-metric-tile {
    border-radius: 16px;
    padding: 1rem 1.1rem;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.ios-metric-icon {
    font-size: 1.15rem;
    color: var(--color-primary);
    margin-bottom: 0.15rem;
}

.ios-metric-icon--orange {
    color: var(--color-accent);
}

.ios-metric-icon--purple {
    color: #af52de;
}

[data-theme="dark"] .ios-metric-icon--purple {
    color: #bf5af2;
}

.ios-metric-value {
    font-size: 1.65rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1;
}

.ios-metric-label {
    font-size: 0.78rem;
    color: var(--text-soft);
    font-weight: 500;
}

.ios-subsection-title {
    font-size: 1.05rem;
    font-weight: 700;
    margin: 0 0 1rem 0;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    letter-spacing: -0.02em;
}

.ios-subsection-title i {
    opacity: 0.9;
    font-size: 1.05em;
    min-width: 1.1em;
}

/* FA6 webfont: ícones sólidos usam peso 900 — 400 quebra o glifo */
.ios-dash .fas,
.ios-dash .fa-solid {
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-style: normal;
}

.ios-aside-hint {
    font-size: 0.82rem;
    color: var(--text-soft);
    margin: -0.35rem 0 0.75rem 0;
    line-height: 1.35;
}

.ios-shortcuts-card .ios-shortcut-btn {
    display: block;
    width: 100%;
    border-radius: 14px;
    margin-bottom: 0.5rem;
    text-align: center;
    font-weight: 600;
}

.ios-shortcuts-card .ios-shortcut-btn--primary {
    border: none;
}

.ios-dash-main-grid {
    margin-top: 0.25rem;
}

.ios-cal-scope {
    font-size: 0.78rem;
    color: var(--text-soft);
    line-height: 1.35;
    margin: 0 0 0.75rem 0;
    display: flex;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.ios-cal-scope i {
    color: var(--color-primary);
    opacity: 0.9;
}

.ios-user-cal .org-cal-header {
    margin-top: 0;
}

@media (max-width: 600px) {
    .ios-dash-large-title {
        font-size: 1.75rem;
    }

    .ios-search-pill {
        flex-wrap: wrap;
        border-radius: 18px;
        padding: 0.5rem 0.65rem;
    }

    .ios-search-pill__submit {
        width: 100%;
    }

    .ios-dash-section-head {
        flex-wrap: wrap;
        align-items: flex-start;
        gap: 0.5rem;
    }

    .ios-btn-ciencia-dash {
        width: 100%;
        text-align: center;
    }

    .ios-subsection-title {
        flex-wrap: wrap;
    }
}

@media (max-width: 420px) {
    .ios-dash-metrics {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0.55rem;
    }

    .ios-metric-tile {
        padding: 0.85rem 0.75rem;
    }

    .ios-metric-value {
        font-size: 1.45rem;
    }
}

/* Formulários em página e em modal — botões empilhados no telefone */
@media (max-width: 640px) {
    .form-actions,
    .modal-form-actions {
        flex-direction: column !important;
        align-items: stretch !important;
        justify-content: stretch !important;
        gap: 0.65rem !important;
    }

    .form-actions > .btn,
    .form-actions > a.btn,
    .form-actions > button.btn,
    .modal-form-actions > .btn,
    .modal-form-actions > a.btn,
    .modal-form-actions > button.btn {
        width: 100%;
        box-sizing: border-box;
    }

    .modal-header {
        padding: 1.35rem 1rem 1rem;
        gap: 0.5rem;
    }

    .modal-title {
        font-size: 1.05rem;
        min-width: 0;
        flex: 1;
        word-break: break-word;
        line-height: 1.25;
    }

    .modal-body {
        padding: 1.15rem 1rem;
        min-width: 0;
    }

    .modal-dialog {
        max-height: min(92vh, 92dvh);
    }
}

@media (max-width: 560px) {
    .timeline-header {
        flex-direction: column;
        align-items: flex-start;
    }

    .timeline-date {
        width: 100%;
    }

    .timeline-title,
    .timeline-text {
        overflow-wrap: anywhere;
        word-break: break-word;
    }

    .org-dash-alert-link {
        margin-left: 0;
        flex: 1 1 100%;
        text-align: center;
        padding: 0.45rem 0.75rem;
        border-radius: 10px;
        background: rgba(255, 255, 255, 0.55);
    }

    [data-theme="dark"] .org-dash-alert-link {
        background: rgba(44, 44, 46, 0.85);
    }

    .proc-ios-ato-card__head-actions {
        width: 100%;
        justify-content: flex-end;
        flex-wrap: wrap;
    }

    .proc-ios-ato-stamp {
        white-space: normal;
    }

    .header-titles .page-title {
        word-break: break-word;
        overflow-wrap: anywhere;
    }
}

/* Sincronização em tempo quase real (processo + sino): animações estilo iOS */
@keyframes proc-live-flash-enter {
    from {
        opacity: 0;
        transform: translateY(-11px) scale(0.988);
    }
    to {
        opacity: 1;
        transform: translateY(0) scale(1);
    }
}

@keyframes proc-live-update-flash {
    0% {
        opacity: 0.88;
        transform: scale(0.992);
        box-shadow: 0 0 0 0 rgba(10, 132, 255, 0.35);
    }
    40% {
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 0 0 6px rgba(10, 132, 255, 0.12);
    }
    100% {
        opacity: 1;
        transform: scale(1);
        box-shadow: 0 0 0 0 rgba(10, 132, 255, 0);
    }
}

@keyframes proc-live-stack-enter {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.proc-live-flash-enter {
    animation: proc-live-flash-enter 0.52s cubic-bezier(0.19, 0.92, 0.24, 1) both;
}

.proc-live-update-flash {
    animation: proc-live-update-flash 0.58s cubic-bezier(0.23, 0.88, 0.28, 1) both;
    border-radius: 14px;
}

.proc-live-stack-enter {
    animation: proc-live-stack-enter 0.5s cubic-bezier(0.19, 0.92, 0.24, 1) both;
}

@media (prefers-reduced-motion: reduce) {
    .proc-live-flash-enter,
    .proc-live-update-flash,
    .proc-live-stack-enter,
    .notification-bell.notification-bell--ringing .notification-bell__graphic,
    .notification-bell.notification-bell--ringing .notification-bell__clapper,
    .notification-bell.notification-bell--ringing .notification-badge {
        animation: none !important;
    }

    .notification-dropdown {
        transition: opacity 0.2s ease, visibility 0s linear 0.2s !important;
    }

    .notification-dropdown.notification-dropdown--open {
        transition: opacity 0.2s ease, visibility 0s !important;
        transform: scale(1) translateY(0) !important;
    }

    .notification-badge,
    .notification-badge__n {
        transition-duration: 0.15s !important;
        transition-delay: 0s !important;
    }
}

/* ========== Códigos brasileiros (iOS HIG / iosdesign.md) ========== */
.ios-codigos-page {
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
    background: var(--color-bg);
    position: relative;
}

.ios-codigos-topbar {
    position: sticky;
    top: 0;
    z-index: 40;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.65rem 1rem;
    padding-top: max(0.65rem, env(safe-area-inset-top));
    background: var(--glass-bg);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--glass-border);
    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.03);
}

.ios-codigos-back {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
}

.ios-codigos-back:hover {
    opacity: 0.85;
}

.ios-codigos-theme {
    border-radius: 12px !important;
}

.ios-codigos-main {
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: 1.25rem 1rem 2.5rem;
    max-width: 760px;
    margin: 0 auto;
    width: 100%;
}

.ios-codigos-kicker {
    font-size: 0.8rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-soft);
    margin-bottom: 0.35rem;
}

.ios-codigos-large-title {
    font-size: clamp(1.75rem, 5vw, 2.25rem);
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin-bottom: 0.6rem;
    transition: font-size 0.2s ease;
}

.ios-codigos-lead {
    color: var(--text-soft);
    font-size: 1rem;
    line-height: 1.5;
    margin-bottom: 1.25rem;
}

.ios-codigos-admin-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin-bottom: 1.25rem;
}

.ios-codigos-pill-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.55rem 1rem;
    border-radius: 14px;
    font-size: 0.95rem;
    font-weight: 600;
    background: var(--color-primary);
    color: #fff;
    text-decoration: none;
    box-shadow: var(--glass-shadow);
}

.ios-codigos-pill-btn:hover {
    filter: brightness(1.06);
    color: #fff;
}

.ios-codigos-pill-btn--secondary {
    background: var(--surface-level-2);
    color: var(--color-text);
    border: 1px solid var(--glass-border);
}

.ios-codigos-grid {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.ios-codigos-card {
    display: flex;
    align-items: center;
    gap: 0.9rem;
    padding: 1rem 1.1rem;
    background: var(--surface-level-1);
    border-radius: 16px;
    text-decoration: none;
    color: inherit;
    box-shadow: var(--glass-shadow);
    border: 1px solid var(--glass-border);
    transition: transform 0.2s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.2s ease;
}

.ios-codigos-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
}

.ios-codigos-card-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    flex-shrink: 0;
}

[data-theme="dark"] .ios-codigos-card-icon {
    background: rgba(10, 132, 255, 0.22);
}

.ios-codigos-card-body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
}

.ios-codigos-card-title {
    font-weight: 600;
    font-size: 1.05rem;
}

.ios-codigos-card-sub {
    font-size: 0.88rem;
    color: var(--text-soft);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ios-codigos-card-chevron {
    color: var(--text-tertiary);
    font-size: 0.9rem;
}

.ios-codigos-empty {
    padding: 1.25rem;
    border-radius: 16px;
    font-size: 0.95rem;
    color: var(--text-soft);
}

.ios-codigos-code {
    display: block;
    margin-top: 0.75rem;
    padding: 0.6rem 0.75rem;
    border-radius: 10px;
    background: var(--surface-level-2);
    font-size: 0.85rem;
    word-break: break-all;
}

.ios-codigos-foot {
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--separator-color);
    font-size: 0.9rem;
    color: var(--text-soft);
}

.ios-codigos-foot a {
    color: var(--color-primary);
    text-decoration: none;
}

.ios-codigos-foot-sep {
    margin: 0 0.4rem;
    opacity: 0.5;
}

.ios-codigos-search-wrap {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 1rem;
}

.ios-codigos-search {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.65rem 1rem;
    border-radius: 999px;
    background: var(--surface-level-2);
    border: none;
    box-shadow: inset 0 0 0 1px var(--glass-border);
}

.ios-codigos-search i {
    color: var(--text-soft);
    font-size: 0.95rem;
}

.ios-codigos-search input {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--color-text);
    font-size: 1rem;
    outline: none;
}

.ios-codigos-clear-q {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
    white-space: nowrap;
}

.ios-codigos-segment {
    display: flex;
    padding: 3px;
    border-radius: 10px;
    background: var(--surface-level-2);
    margin-bottom: 1rem;
    gap: 2px;
}

.ios-codigos-segment button {
    flex: 1;
    border: none;
    background: transparent;
    color: var(--text-soft);
    font-size: 0.82rem;
    font-weight: 600;
    padding: 0.45rem 0.4rem;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
}

.ios-codigos-segment button.is-active {
    background: var(--surface-level-1);
    color: var(--color-text);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.ios-codigos-meta-count {
    font-size: 0.88rem;
    color: var(--text-soft);
    margin-bottom: 0.75rem;
}

.ios-codigos-stream {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
}

.ios-codigos-section-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0.5rem 0 0.25rem;
    line-height: 1.35;
}

.ios-codigos-callout {
    display: flex;
    gap: 0.75rem;
    padding: 1rem 1.1rem;
    border-radius: 14px;
    background: rgba(255, 149, 0, 0.1);
    border: 1px solid rgba(255, 149, 0, 0.22);
    color: var(--color-text);
}

.ios-codigos-callout i {
    color: var(--color-accent);
    margin-top: 0.15rem;
}

.ios-codigos-callout p {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.45;
}

.ios-codigos-art-card {
    border-radius: 16px;
    padding: 1rem 1.15rem;
    border: 1px solid var(--glass-border);
}

.ios-codigos-art-head {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    margin-bottom: 0.5rem;
}

.ios-codigos-art-ref {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--color-primary);
}

.ios-codigos-art-rubric {
    font-weight: 600;
    font-size: 1rem;
}

.ios-codigos-art-text {
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--color-text);
}

.ios-codigos-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    margin-top: 0.65rem;
}

.ios-chip {
    font-size: 0.75rem;
    font-weight: 600;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    background: rgba(52, 199, 89, 0.18);
    color: var(--color-success);
}

.ios-chip--muted {
    background: var(--surface-level-2);
    color: var(--text-soft);
}

.ios-codigos-plain {
    font-size: 0.95rem;
    line-height: 1.5;
    color: var(--text-soft);
    margin: 0;
    padding-left: 0.25rem;
}

.ios-codigos-page--detail .ios-codigos-item--secao:first-child .ios-codigos-section-title {
    margin-top: 0;
}

.ios-codigos-main--import {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    min-height: calc(100dvh - 52px);
    padding-bottom: env(safe-area-inset-bottom);
}

.ios-sheet-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.32);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 50;
}

.ios-sheet {
    position: relative;
    z-index: 60;
    width: 100%;
    max-width: 520px;
    margin: 1rem;
    padding: 0.5rem 1.25rem 1.75rem;
    background: var(--surface-level-1);
    border-radius: 20px 20px 24px 24px;
    box-shadow: 0 -8px 40px rgba(0, 0, 0, 0.12), var(--glass-shadow);
    border: 1px solid var(--glass-border);
}

.ios-sheet-handle {
    display: flex;
    justify-content: center;
    padding: 0.35rem 0 0.5rem;
}

.ios-sheet-handle span {
    width: 38px;
    height: 5px;
    border-radius: 99px;
    background: var(--text-tertiary);
    opacity: 0.5;
}

.ios-sheet-title {
    font-size: 1.35rem;
    font-weight: 700;
    margin: 0 0 0.5rem;
    letter-spacing: -0.02em;
}

.ios-sheet-caption {
    font-size: 0.9rem;
    color: var(--text-soft);
    line-height: 1.45;
    margin: 0 0 1rem;
}

.ios-sheet-messages {
    margin-bottom: 1rem;
}

.ios-alert {
    font-size: 0.9rem;
    padding: 0.6rem 0.75rem;
    border-radius: 12px;
    margin: 0 0 0.5rem;
}

.ios-alert.error {
    background: rgba(255, 59, 48, 0.12);
    color: var(--color-danger);
}

.ios-alert.success {
    background: rgba(52, 199, 89, 0.15);
    color: var(--color-success);
}

.ios-sheet-form .ios-field {
    display: block;
    margin-bottom: 1rem;
}

.ios-field-label {
    display: block;
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-soft);
    margin-bottom: 0.35rem;
}

.ios-field-input {
    width: 100%;
    padding: 0.65rem 0.85rem;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: var(--surface-level-2);
    color: var(--color-text);
    font-size: 1rem;
}

.ios-field-hint {
    display: block;
    font-size: 0.75rem;
    color: var(--text-tertiary);
    margin-top: 0.3rem;
}

.ios-field-file {
    width: 100%;
    font-size: 0.9rem;
    margin-top: 0.25rem;
}

.ios-sheet-actions {
    display: flex;
    gap: 0.65rem;
    margin-top: 1.25rem;
    flex-wrap: wrap;
}

.ios-btn {
    flex: 1;
    min-width: 120px;
    padding: 0.7rem 1rem;
    border-radius: 14px;
    font-size: 1rem;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: opacity 0.15s ease, filter 0.15s ease;
}

.ios-btn--primary {
    background: var(--color-primary);
    color: #fff;
}

.ios-btn--secondary {
    background: var(--surface-level-2);
    color: var(--color-text);
    border: 1px solid var(--glass-border);
}

.ios-btn:hover {
    filter: brightness(1.05);
}

@media (max-width: 520px) {
    .ios-codigos-main--import {
        align-items: flex-end;
    }

    .ios-sheet {
        margin: 0;
        border-radius: 20px 20px 0 0;
        max-width: none;
    }
}

/* —— Tabelas de códigos (referência planilhas + iOS HIG) —— */
.ios-codigos-main--wide {
    max-width: min(1600px, 100%);
}

.ios-codigos-toolbar {
    margin-bottom: 1rem;
}

/* Estúdio de códigos (lista — admin): painel fixo em cartões */
.ios-codigos-studio {
    margin: 1.5rem 0 1.75rem;
    padding: 0;
}

.ios-codigos-studio-hero {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem 1.35rem;
    margin-bottom: 1.15rem;
    border-radius: 20px;
    background: linear-gradient(135deg, rgba(0, 122, 255, 0.14) 0%, rgba(52, 199, 89, 0.08) 100%);
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
}

[data-theme="dark"] .ios-codigos-studio-hero {
    background: linear-gradient(135deg, rgba(10, 132, 255, 0.2) 0%, rgba(50, 215, 75, 0.1) 100%);
}

.ios-codigos-studio-hero-icon {
    flex-shrink: 0;
    width: 52px;
    height: 52px;
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    color: var(--color-primary);
    background: var(--surface-level-1);
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
}

[data-theme="dark"] .ios-codigos-studio-hero-icon {
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.ios-codigos-studio-hero-text {
    min-width: 0;
    flex: 1;
}

.ios-codigos-studio-title {
    font-size: 1.35rem;
    font-weight: 800;
    letter-spacing: -0.03em;
    margin: 0 0 0.35rem;
    color: var(--color-text);
}

.ios-codigos-studio-desc {
    margin: 0;
    font-size: 0.92rem;
    line-height: 1.5;
    color: var(--text-soft);
}

.ios-codigos-studio-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    margin: 1rem 0 0.25rem;
}

.ios-codigos-studio-add-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.78rem 1.4rem;
    border-radius: 14px;
    border: none;
    font-weight: 800;
    font-size: 1.02rem;
    letter-spacing: -0.02em;
    cursor: pointer;
    color: #fff;
    background: linear-gradient(145deg, var(--color-primary), #0051d5);
    box-shadow: 0 6px 24px rgba(0, 122, 255, 0.4);
    transition: filter 0.15s ease, transform 0.1s ease;
}

.ios-codigos-studio-add-btn:hover {
    filter: brightness(1.06);
}

.ios-codigos-studio-add-btn:active {
    transform: scale(0.98);
}

.ios-codigos-add-modal-lead {
    margin: 0 0 1.05rem;
    font-size: 0.9rem;
    line-height: 1.55;
    color: var(--text-soft);
}

.ios-codigos-add-modal-form {
    margin-top: 0.25rem;
}

.ios-codigos-studio-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 340px), 1fr));
    gap: 1.15rem;
}

.ios-codigos-studio-card {
    border-radius: 18px;
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

.ios-codigos-studio-card--accent {
    border-color: rgba(0, 122, 255, 0.22);
    box-shadow: 0 8px 28px rgba(0, 122, 255, 0.12);
}

[data-theme="dark"] .ios-codigos-studio-card--accent {
    border-color: rgba(10, 132, 255, 0.35);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45);
}

.ios-codigos-studio-card-head {
    padding: 1.1rem 1.15rem 0.85rem;
    border-bottom: 1px solid var(--separator-color);
}

.ios-codigos-studio-card-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.68rem;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--color-primary);
    margin-bottom: 0.5rem;
}

.ios-codigos-studio-card-badge--light {
    color: #fff;
    background: rgba(0, 122, 255, 0.95);
    padding: 0.2rem 0.55rem;
    border-radius: 6px;
}

[data-theme="dark"] .ios-codigos-studio-card-badge--light {
    background: var(--color-primary);
    color: #fff;
}

.ios-codigos-studio-card-title {
    font-size: 1.08rem;
    font-weight: 700;
    margin: 0 0 0.4rem;
    letter-spacing: -0.02em;
}

.ios-codigos-studio-card-caption {
    margin: 0;
    font-size: 0.86rem;
    line-height: 1.45;
    color: var(--text-soft);
}

.ios-codigos-studio-form {
    padding: 1rem 1.15rem 1.15rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}

.ios-codigos-studio-fields {
    display: flex;
    flex-direction: column;
    gap: 0.85rem;
    margin-bottom: 1rem;
}

.ios-codigos-studio-field {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
}

.ios-codigos-studio-label {
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-soft);
}

.ios-codigos-studio-input,
.ios-codigos-studio-textarea {
    width: 100%;
    padding: 0.65rem 0.8rem;
    border-radius: 12px;
    border: 1px solid var(--glass-border);
    background: var(--surface-level-2);
    color: var(--color-text);
    font: inherit;
    font-size: 0.92rem;
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.ios-codigos-studio-input:focus,
.ios-codigos-studio-textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.2);
}

[data-theme="dark"] .ios-codigos-studio-input:focus,
[data-theme="dark"] .ios-codigos-studio-textarea:focus {
    box-shadow: 0 0 0 3px rgba(10, 132, 255, 0.28);
}

.ios-codigos-studio-file {
    font-size: 0.85rem;
    padding: 0.45rem 0;
}

.ios-codigos-studio-submit {
    margin-top: auto;
    width: 100%;
    padding: 0.75rem 1rem;
    border-radius: 12px;
    border: none;
    font-weight: 700;
    font-size: 0.92rem;
    cursor: pointer;
    background: linear-gradient(145deg, var(--color-primary), #0051d5);
    color: #fff;
    box-shadow: 0 4px 16px rgba(0, 122, 255, 0.35);
    transition: filter 0.15s ease, transform 0.1s ease;
}

.ios-codigos-studio-submit:hover {
    filter: brightness(1.06);
}

.ios-codigos-studio-submit:active {
    transform: scale(0.99);
}

.ios-codigos-studio-submit--secondary {
    background: var(--surface-level-2);
    color: var(--color-primary);
    border: 1px solid rgba(0, 122, 255, 0.35);
    box-shadow: none;
}

[data-theme="dark"] .ios-codigos-studio-submit--secondary {
    background: rgba(10, 132, 255, 0.15);
    border-color: rgba(10, 132, 255, 0.45);
}

.ios-codigos-search--table {
    width: 100%;
}

.ios-codigo-table-wrap {
    overflow-x: visible;
    max-width: 100%;
    border-radius: 16px;
    border: 1px solid var(--glass-border);
    background: var(--surface-level-1);
    box-shadow: var(--glass-shadow);
    margin-bottom: 1rem;
}

/* Tabela legislativa (ficha do código): cabe na largura útil, sem scroll lateral */
.ios-codigo-table--legis {
    table-layout: fixed;
    width: 100%;
}

.ios-codigo-table--legis th,
.ios-codigo-table--legis td {
    min-width: 0;
}

.ios-codigo-table--legis thead th {
    white-space: normal;
    line-height: 1.25;
    word-break: break-word;
    hyphens: auto;
}

/* Pesos de coluna: tipificação absorve mais espaço */
.ios-codigo-table--legis thead th:nth-child(1),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(1) {
    width: 7%;
}

.ios-codigo-table--legis thead th:nth-child(2),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(2) {
    width: 11%;
}

.ios-codigo-table--legis thead th:nth-child(3),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(3) {
    width: 12%;
}

.ios-codigo-table--legis thead th:nth-child(4),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(4) {
    width: 36%;
}

.ios-codigo-table--legis thead th:nth-child(5),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(5) {
    width: 11%;
}

.ios-codigo-table--legis thead th:nth-child(6),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(6) {
    width: 11%;
}

.ios-codigo-table--legis thead th:nth-child(7),
.ios-codigo-table--legis tbody td:not([colspan]):nth-child(7) {
    width: 12%;
}

.ios-codigo-table--legis .ios-codigo-td-ref {
    white-space: normal;
    word-break: break-word;
}

.ios-codigo-table--legis .ios-codigo-td-name {
    max-width: none;
    word-break: break-word;
}

.ios-codigo-table--legis .ios-codigo-td-tip {
    min-width: 0;
    max-width: none;
    word-break: break-word;
    overflow-wrap: anywhere;
    hyphens: auto;
}

.ios-codigo-table--legis .ios-codigo-td-nat,
.ios-codigo-table--legis .ios-codigo-td-st {
    white-space: normal;
    word-break: break-word;
}

.ios-codigo-table--legis .ios-codigo-td-pena,
.ios-codigo-table--legis .ios-codigo-td-multa {
    max-width: none;
    word-break: break-word;
}

@media (max-width: 900px) {
    .ios-codigo-table--legis {
        font-size: 0.82rem;
    }

    .ios-codigo-table--legis thead th {
        font-size: 0.62rem;
        padding: 0.5rem 0.4rem;
        letter-spacing: 0.02em;
    }

    .ios-codigo-table--legis td {
        padding: 0.45rem 0.4rem;
    }

    .ios-codigo-table--legis .ios-nat-pill,
    .ios-codigo-table--legis .ios-st-pill {
        max-width: 100%;
        font-size: 0.68rem;
        padding: 0.22rem 0.45rem;
    }
}

@media (max-width: 600px) {
    .ios-codigos-page--detail .ios-codigos-main {
        padding-left: max(0.65rem, env(safe-area-inset-left));
        padding-right: max(0.65rem, env(safe-area-inset-right));
    }

    .ios-codigo-table--legis {
        font-size: 0.76rem;
        line-height: 1.35;
    }

    .ios-codigo-table--legis thead th {
        font-size: 0.58rem;
        padding: 0.42rem 0.3rem;
    }

    .ios-codigo-table--legis td {
        padding: 0.38rem 0.3rem;
    }

    .ios-codigo-table--legis .ios-codigo-td-ref-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.25rem;
    }

    .ios-codigo-table--legis .ios-codigo-td-ref-actions {
        flex-direction: row;
    }

    .ios-codigo-table--legis .ios-codigo-chip-edit,
    .ios-codigo-table--legis .ios-codigo-chip-delete {
        margin-top: 0;
    }
}

.ios-codigo-table-wrap--index {
    margin-top: 0.25rem;
}

.ios-codigo-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
    line-height: 1.4;
}

.ios-codigo-table thead {
    position: sticky;
    top: 0;
    z-index: 3;
}

.ios-codigo-table thead tr {
    background: rgba(142, 142, 147, 0.18);
    backdrop-filter: blur(12px);
}

[data-theme="dark"] .ios-codigo-table thead tr {
    background: rgba(58, 58, 60, 0.92);
}

.ios-codigo-table th {
    text-align: left;
    padding: 0.65rem 0.75rem;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-soft);
    border-bottom: 1px solid var(--separator-color);
    white-space: nowrap;
}

.ios-codigo-th-num,
.ios-codigo-th-action {
    text-align: center;
}

.ios-codigo-table td {
    padding: 0.55rem 0.75rem;
    border-bottom: 1px solid rgba(60, 60, 67, 0.12);
    vertical-align: top;
    color: var(--color-text);
}

[data-theme="dark"] .ios-codigo-table td {
    border-bottom-color: rgba(84, 84, 88, 0.45);
}

.ios-codigo-table--index tbody tr:hover {
    background: rgba(0, 122, 255, 0.06);
}

[data-theme="dark"] .ios-codigo-table--index tbody tr:hover {
    background: rgba(10, 132, 255, 0.12);
}

.ios-codigo-td-title {
    min-width: 200px;
}

.ios-codigo-index-name {
    display: block;
    font-weight: 600;
    font-size: 0.98rem;
}

.ios-codigo-index-slug {
    display: block;
    font-size: 0.78rem;
    color: var(--text-soft);
    margin-top: 0.15rem;
    font-variant-numeric: tabular-nums;
}

.ios-codigo-td-desc {
    color: var(--text-soft);
    max-width: 420px;
}

.ios-codigo-td-num {
    text-align: center;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.ios-codigo-td-action {
    text-align: center;
    white-space: nowrap;
}

.ios-codigo-link-open {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    font-weight: 600;
    font-size: 0.88rem;
    color: var(--color-primary);
    text-decoration: none;
}

.ios-codigo-link-open:hover {
    opacity: 0.85;
}

.ios-codigo-link-open i {
    font-size: 0.72rem;
    opacity: 0.7;
}

.ios-codigo-td-empty {
    padding: 1rem !important;
    border: none !important;
}

.ios-codigo-emdash {
    color: var(--text-tertiary);
}

.ios-codigo-tr--section td {
    padding: 0 !important;
    border-bottom: none !important;
}

.ios-codigo-capitulo-bar {
    margin: 0.5rem 0 0.15rem;
    padding: 0.65rem 0.9rem;
    border-radius: 12px;
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #fff;
    background: linear-gradient(135deg, #1a3a6e 0%, #0d47a1 55%, #1565c0 100%);
    box-shadow: 0 2px 12px rgba(13, 71, 161, 0.25);
}

.ios-codigo-tr--obs td {
    padding: 0 !important;
    border-bottom: none !important;
}

.ios-codigo-obs-bar {
    margin: 0.35rem 0;
    padding: 0.75rem 0.9rem;
    border-radius: 12px;
    font-size: 0.88rem;
    line-height: 1.45;
    background: rgba(255, 149, 0, 0.12);
    border: 1px solid rgba(255, 149, 0, 0.25);
    color: var(--color-text);
}

.ios-codigo-obs-bar i {
    color: var(--color-accent);
    margin-right: 0.35rem;
}

.ios-codigo-tr--artigo.ios-codigo-tr--z td {
    background: rgba(142, 142, 147, 0.06);
}

[data-theme="dark"] .ios-codigo-tr--artigo.ios-codigo-tr--z td {
    background: rgba(255, 255, 255, 0.03);
}

/* Artigos (admin): realce de linha ao hover + botões só com hover (teclado: focus-within) */
.ios-codigo-table--admin tbody tr.ios-codigo-tr--artigo > td {
    transition: background-color 0.22s ease;
}

.ios-codigo-table--admin tbody tr.ios-codigo-tr--artigo:hover > td {
    background-color: rgba(0, 122, 255, 0.055);
}

.ios-codigo-table--admin tbody tr.ios-codigo-tr--artigo.ios-codigo-tr--z:hover > td {
    background-color: rgba(0, 122, 255, 0.07);
}

[data-theme="dark"] .ios-codigo-table--admin tbody tr.ios-codigo-tr--artigo:hover > td {
    background-color: rgba(10, 132, 255, 0.1);
}

[data-theme="dark"] .ios-codigo-table--admin tbody tr.ios-codigo-tr--artigo.ios-codigo-tr--z:hover > td {
    background-color: rgba(10, 132, 255, 0.13);
}

.ios-codigo-table--admin.ios-codigo-table--legis thead th:nth-child(1),
.ios-codigo-table--admin.ios-codigo-table--legis tbody td:not([colspan]):nth-child(1) {
    width: 11%;
    min-width: 5.75rem;
}

.ios-codigo-table--admin.ios-codigo-table--legis thead th:nth-child(4),
.ios-codigo-table--admin.ios-codigo-table--legis tbody td:not([colspan]):nth-child(4) {
    width: 32%;
}

.ios-codigo-td-ref {
    font-weight: 700;
    color: var(--color-primary);
    white-space: nowrap;
    font-size: 0.84rem;
}

.ios-codigo-td-name {
    font-weight: 600;
    max-width: 160px;
}

.ios-codigo-td-tip {
    min-width: 220px;
    max-width: 420px;
    line-height: 1.5;
}

.ios-codigo-td-nat,
.ios-codigo-td-st {
    white-space: nowrap;
}

.ios-codigo-td-pena,
.ios-codigo-td-multa {
    font-size: 0.85rem;
    color: var(--text-soft);
    max-width: 180px;
}

.ios-codigo-td-plain {
    font-size: 0.9rem;
    color: var(--text-soft);
    font-style: italic;
}

.ios-nat-pill,
.ios-st-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.28rem 0.55rem;
    border-radius: 10px;
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1.2;
    max-width: 220px;
    text-align: center;
}

.ios-nat--reclusao {
    background: rgba(244, 143, 177, 0.35);
    color: #880e4f;
}
[data-theme="dark"] .ios-nat--reclusao {
    color: #f8bbd0;
    background: rgba(244, 143, 177, 0.18);
}

.ios-nat--detencao {
    background: rgba(255, 213, 79, 0.45);
    color: #5d4000;
}
[data-theme="dark"] .ios-nat--detencao {
    color: #ffe082;
    background: rgba(255, 213, 79, 0.15);
}

.ios-nat--federal {
    background: rgba(255, 152, 0, 0.35);
    color: #bf360c;
}
[data-theme="dark"] .ios-nat--federal {
    color: #ffcc80;
    background: rgba(255, 152, 0, 0.2);
}

.ios-nat--infra {
    background: rgba(66, 165, 245, 0.28);
    color: #0d47a1;
}
[data-theme="dark"] .ios-nat--infra {
    color: #90caf9;
    background: rgba(66, 165, 245, 0.15);
}

.ios-nat--infra-grave {
    background: rgba(129, 212, 250, 0.35);
    color: #01579b;
}

.ios-nat--infra-graviss {
    background: rgba(239, 83, 80, 0.22);
    color: #b71c1c;
}
[data-theme="dark"] .ios-nat--infra-graviss {
    color: #ffcdd2;
}

.ios-nat--eleitoral {
    background: rgba(77, 182, 172, 0.28);
    color: #004d40;
}
[data-theme="dark"] .ios-nat--eleitoral {
    color: #b2dfdb;
}

.ios-nat--eleitoral-grave {
    background: rgba(255, 112, 67, 0.25);
    color: #bf360c;
}

.ios-nat--eleitoral-graviss {
    background: rgba(213, 0, 249, 0.15);
    color: #4a148c;
}
[data-theme="dark"] .ios-nat--eleitoral-graviss {
    color: #e1bee7;
}

.ios-nat--ambiental {
    background: rgba(102, 187, 106, 0.25);
    color: #1b5e20;
}

.ios-nat--transito {
    background: rgba(255, 183, 77, 0.3);
    color: #e65100;
}

.ios-nat--advert,
.ios-nat--multa-only {
    background: rgba(189, 189, 189, 0.35);
    color: #424242;
}
[data-theme="dark"] .ios-nat--advert {
    color: var(--color-text);
    background: rgba(255, 255, 255, 0.1);
}

.ios-nat--default {
    background: var(--surface-level-2);
    color: var(--color-text);
}

.ios-nat--muted {
    background: transparent;
    color: var(--text-soft);
    font-weight: 600;
}

/* Duração (minutos) — destaque System Blue suave */
.ios-nat--tempo {
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary);
    font-weight: 750;
    max-width: 200px;
}
[data-theme="dark"] .ios-nat--tempo {
    background: rgba(10, 132, 255, 0.18);
    color: #64b5f6;
}

.ios-st--vigente {
    background: #1b5e20;
    color: #fff;
}
[data-theme="dark"] .ios-st--vigente {
    background: rgba(52, 199, 89, 0.85);
    color: #000;
}

.ios-st--depende {
    background: #4a148c;
    color: #fff;
}
[data-theme="dark"] .ios-st--depende {
    background: rgba(94, 53, 177, 0.85);
}

.ios-st--revog {
    background: var(--text-tertiary);
    color: var(--surface-level-1);
}

.ios-st--muted {
    background: var(--surface-level-2);
    color: var(--text-soft);
}

.ios-codigos-lead--compact {
    margin-bottom: 1rem;
    font-size: 0.95rem;
}

.ios-codigos-table-hint {
    font-size: 0.82rem;
    color: var(--text-soft);
    margin-top: 0.5rem;
}

/* Cartões na lista de códigos */
.ios-codigo-cards {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.ios-codigo-card {
    text-decoration: none;
    color: inherit;
    display: block;
    border-radius: 18px;
    transition: transform 0.2s cubic-bezier(0.25, 1, 0.5, 1), box-shadow 0.2s ease;
}

.ios-codigo-card:hover {
    transform: translateY(-3px);
}

.ios-codigo-card-surface {
    display: flex;
    align-items: stretch;
    gap: 0.85rem;
    padding: 1rem 1.1rem;
    background: var(--surface-level-1);
    border: 1px solid var(--glass-border);
    border-radius: 18px;
    box-shadow: var(--glass-shadow);
    min-height: 88px;
}

.ios-codigo-card-icon {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.35rem;
    flex-shrink: 0;
}

[data-theme="dark"] .ios-codigo-card-icon {
    background: rgba(10, 132, 255, 0.22);
}

.ios-codigo-card-text {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    justify-content: center;
}

.ios-codigo-card-title {
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: -0.02em;
    line-height: 1.25;
}

.ios-codigo-card-slug {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-soft);
    font-variant-numeric: tabular-nums;
}

.ios-codigo-card-epi {
    font-size: 0.85rem;
    color: var(--text-soft);
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ios-codigo-card-stat {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    text-align: right;
    flex-shrink: 0;
    padding-left: 0.35rem;
}

.ios-codigo-card-stat strong {
    font-size: 1.25rem;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    color: var(--color-text);
    line-height: 1;
}

.ios-codigo-card-stat span {
    font-size: 0.68rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-soft);
    margin-top: 0.2rem;
}

.ios-codigo-card-go {
    display: flex;
    align-items: center;
    color: var(--text-tertiary);
    font-size: 0.95rem;
    padding-left: 0.25rem;
}

.ios-codigo-cards-empty {
    margin-top: 0.5rem;
}

.ios-codigos-admin-panel {
    border-radius: 18px;
    margin-bottom: 1.25rem;
    overflow: hidden;
    border: 1px solid var(--glass-border);
    box-shadow: var(--glass-shadow);
}

.ios-codigos-admin-panel-sum {
    list-style: none;
    cursor: pointer;
    padding: 1rem 1.15rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.75rem;
    font-weight: 700;
    font-size: 1rem;
    color: var(--color-text);
    background: rgba(0, 122, 255, 0.08);
}

.ios-codigos-admin-panel-sum::-webkit-details-marker {
    display: none;
}

.ios-codigos-admin-panel-sum-icon {
    color: var(--color-primary);
    font-size: 1.25rem;
}

.ios-codigos-admin-panel-sum-hint {
    margin-left: auto;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--text-soft);
}

.ios-codigos-admin-panel-body {
    padding: 0 1.15rem 1.15rem;
}

.ios-codigos-admin-panel-caption {
    font-size: 0.88rem;
    color: var(--text-soft);
    line-height: 1.45;
    margin-bottom: 1rem;
}

.ios-codigos-admin-form .ios-field--compact {
    margin-bottom: 0.75rem;
}

.ios-codigos-pill-btn--block {
    width: 100%;
    justify-content: center;
    margin-top: 0.5rem;
    border: none;
    cursor: pointer;
}

.ios-codigo-header-row {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.25rem;
}

.ios-codigo-header-text {
    flex: 1;
    min-width: 0;
}

.ios-codigo-icon-edit {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 12px;
    border: none;
    background: var(--surface-level-2);
    color: var(--color-primary);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    transition: transform 0.15s ease, background 0.15s ease;
}

.ios-codigo-icon-edit:hover {
    background: rgba(0, 122, 255, 0.12);
    transform: scale(1.04);
}

.ios-codigo-icon-edit--header {
    margin-top: 1.5rem;
}

.ios-codigo-td-section-cell {
    padding: 0 !important;
    vertical-align: middle !important;
    overflow: visible;
}

.ios-codigo-capitulo-bar--click {
    width: 100%;
    display: block;
    margin: 0;
    border: none;
    background: linear-gradient(135deg, #1a3a6e 0%, #0d47a1 55%, #1565c0 100%);
    color: #fff;
    font: inherit;
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    text-align: left;
    padding: 0.65rem 0.9rem;
    border-radius: 12px;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(13, 71, 161, 0.25);
    transition: filter 0.15s ease, transform 0.1s ease;
}

.ios-codigo-capitulo-bar--click:hover {
    filter: brightness(1.06);
}

.ios-codigo-capitulo-bar--click:active {
    transform: scale(0.998);
}

tr.ios-codigo-section-flash .ios-codigo-td-section-cell {
    animation: ios-codigo-sec-pulse 1.3s ease-out;
}

@keyframes ios-codigo-sec-pulse {
    0% {
        box-shadow: inset 0 0 0 3px rgba(0, 122, 255, 0.75);
    }
    100% {
        box-shadow: inset 0 0 0 0 rgba(0, 122, 255, 0);
    }
}

.ios-codigo-admin-toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.85rem 1.25rem;
    padding: 1rem 1.2rem;
    margin-bottom: 1rem;
    border-radius: 18px;
}

.ios-codigo-save-flash {
    flex: 1 0 100%;
    width: 100%;
    margin: 0 0 0.35rem 0;
    font-weight: 650;
    font-size: 0.92rem;
    color: var(--ios-blue, #007aff);
}

.ios-codigo-admin-toolbar-text {
    flex: 1;
    min-width: min(100%, 220px);
    margin: 0;
    font-size: 0.9rem;
    line-height: 1.5;
    color: var(--text-soft);
}

.ios-codigo-add-dispositivo {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.62rem 1.05rem;
    border-radius: 12px;
    border: none;
    background: linear-gradient(145deg, var(--color-primary), #0051d5);
    color: #fff;
    font-weight: 700;
    font-size: 0.88rem;
    letter-spacing: -0.01em;
    cursor: pointer;
    box-shadow: 0 4px 18px rgba(0, 122, 255, 0.38);
    transition: filter 0.15s ease, transform 0.1s ease;
}

.ios-codigo-add-dispositivo:hover {
    filter: brightness(1.07);
}

.ios-codigo-add-dispositivo:active {
    transform: scale(0.98);
}

.ios-codigo-section-row {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    padding: 0.5rem 0.65rem;
    min-width: 0;
}

.ios-codigo-section-row .ios-codigo-capitulo-bar--click {
    flex: 1;
    min-width: 0;
    width: auto;
}

.ios-codigo-section-drag-h {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.6rem;
    align-self: stretch;
    min-height: 2.45rem;
    border-radius: 10px;
    color: rgba(60, 60, 67, 0.38);
    font-size: 0.95rem;
    cursor: grab;
    touch-action: none;
    user-select: none;
    transition: background 0.18s ease, color 0.18s ease;
}

[data-theme="dark"] .ios-codigo-section-drag-h {
    color: rgba(235, 235, 245, 0.38);
}

.ios-codigo-section-drag-h:hover {
    background: rgba(0, 122, 255, 0.08);
    color: rgba(0, 122, 255, 0.85);
}

[data-theme="dark"] .ios-codigo-section-drag-h:hover {
    background: rgba(10, 132, 255, 0.14);
    color: #0a84ff;
}

.ios-codigo-section-drag-h:active {
    cursor: grabbing;
}

#codigo-stream.codigo-reorder-inactive .ios-codigo-section-drag-h {
    opacity: 0.28;
    pointer-events: none;
    cursor: default;
}

.ios-codigo-section-peek {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: stretch;
    border-radius: 12px;
    outline: none;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    transition: background 0.22s ease, box-shadow 0.22s ease;
}

.ios-codigo-section-peek:hover {
    background: rgba(0, 122, 255, 0.06);
}

[data-theme="dark"] .ios-codigo-section-peek:hover {
    background: rgba(10, 132, 255, 0.1);
}

.ios-codigo-section-peek:focus-visible {
    box-shadow: inset 0 0 0 2px rgba(0, 122, 255, 0.45);
}

.ios-codigo-obs-row {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    padding: 0.35rem 0.65rem;
}

.ios-codigo-obs-row .ios-codigo-obs-bar {
    flex: 1;
    min-width: 0;
    margin: 0.25rem 0;
}

.ios-codigo-plain-row {
    display: flex;
    align-items: flex-start;
    gap: 0.55rem;
    padding: 0.35rem 0.65rem;
}

.ios-codigo-plain-row .ios-codigo-td-plain {
    flex: 1;
    min-width: 0;
    margin: 0;
}

.ios-codigo-td-ref-inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.4rem;
    min-width: 0;
}

.ios-codigo-td-ref-txt {
    min-width: 0;
    word-break: break-word;
}

.ios-codigo-chip-edit {
    flex-shrink: 0;
    width: 30px;
    height: 30px;
    margin: -0.1rem 0 0;
    padding: 0;
    border: none;
    border-radius: 10px;
    background: rgba(0, 122, 255, 0.14);
    color: var(--color-primary);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    box-shadow: 0 1px 4px rgba(0, 122, 255, 0.12);
    transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
}

.ios-codigo-chip-edit:hover {
    background: rgba(0, 122, 255, 0.24);
    box-shadow: 0 2px 10px rgba(0, 122, 255, 0.2);
    transform: scale(1.04);
}

.ios-codigo-td-ref-actions {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 0.28rem;
    flex-shrink: 0;
}

.ios-codigo-chip-delete {
    flex-shrink: 0;
    width: 30px;
    height: 30px;
    margin: -0.1rem 0 0;
    padding: 0;
    border: none;
    border-radius: 10px;
    background: rgba(255, 59, 48, 0.14);
    color: var(--color-danger);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.82rem;
    box-shadow: 0 1px 4px rgba(255, 59, 48, 0.14);
    transition: background 0.15s ease, transform 0.1s ease, box-shadow 0.15s ease;
}

.ios-codigo-chip-delete:hover {
    background: rgba(255, 59, 48, 0.24);
    box-shadow: 0 2px 10px rgba(255, 59, 48, 0.22);
    transform: scale(1.04);
}

/* Menu contextual (peek): célula inteira da coluna Artigo (admin) */
.ios-codigo-table--admin .ios-codigo-tr--artigo td.ios-codigo-td-ref--peek-cell {
    vertical-align: top;
    cursor: default;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
    outline: none;
    border-radius: 12px;
    transition: background 0.22s ease, box-shadow 0.22s ease;
}

.ios-codigo-table--admin .ios-codigo-tr--artigo td.ios-codigo-td-ref--peek-cell .ios-codigo-td-ref-inner {
    min-height: 2.75rem;
    justify-content: flex-start;
    align-items: flex-start;
}

.ios-codigo-table--admin .ios-codigo-tr--artigo td.ios-codigo-td-ref--peek-cell:hover {
    background: rgba(0, 122, 255, 0.07);
}

[data-theme="dark"] .ios-codigo-table--admin .ios-codigo-tr--artigo td.ios-codigo-td-ref--peek-cell:hover {
    background: rgba(10, 132, 255, 0.12);
}

.ios-codigo-table--admin .ios-codigo-tr--artigo td.ios-codigo-td-ref--peek-cell:focus-visible {
    box-shadow: inset 0 0 0 2px rgba(0, 122, 255, 0.45);
}

.ios-codigo-peek-root {
    position: fixed;
    inset: 0;
    z-index: 12500;
    pointer-events: none;
}

.ios-codigo-peek-root--open {
    pointer-events: auto;
}

.ios-codigo-peek-dim {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(12px) saturate(1.1);
    -webkit-backdrop-filter: blur(12px) saturate(1.1);
    opacity: 0;
    transition: opacity 0.32s cubic-bezier(0.25, 0.82, 0.25, 1);
}

[data-theme="dark"] .ios-codigo-peek-dim {
    background: rgba(0, 0, 0, 0.48);
}

.ios-codigo-peek-root--open .ios-codigo-peek-dim {
    opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
    .ios-codigo-peek-dim {
        transition: opacity 0.12s ease;
    }
}

.ios-codigo-peek-plate {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 1;
    min-width: 228px;
    max-width: min(300px, calc(100vw - 28px));
    padding: 0.35rem 0;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(22px) saturate(1.45);
    -webkit-backdrop-filter: blur(22px) saturate(1.45);
    box-shadow:
        0 4px 24px rgba(0, 0, 0, 0.05),
        0 20px 56px rgba(0, 0, 0, 0.14),
        0 0 0 0.5px rgba(0, 0, 0, 0.05);
    transform: translate(-50%, -50%) perspective(900px) rotateX(10deg) scale(0.9);
    opacity: 0;
    transform-origin: 50% 92%;
    transition:
        opacity 0.32s cubic-bezier(0.25, 0.82, 0.25, 1),
        transform 0.44s cubic-bezier(0.25, 0.82, 0.25, 1);
    will-change: transform, opacity;
}

[data-theme="dark"] .ios-codigo-peek-plate {
    background: rgba(44, 44, 48, 0.94);
    box-shadow:
        0 8px 40px rgba(0, 0, 0, 0.38),
        0 0 0 0.5px rgba(255, 255, 255, 0.08);
}

.ios-codigo-peek-plate--in {
    opacity: 1;
    transform: translate(-50%, -50%) perspective(900px) rotateX(0deg) scale(1);
}

@media (prefers-reduced-motion: reduce) {
    .ios-codigo-peek-plate {
        transition: opacity 0.18s ease;
    }

    .ios-codigo-peek-plate,
    .ios-codigo-peek-plate--in {
        transform: translate(-50%, -50%) scale(1);
    }
}

.ios-codigo-peek-kicker {
    margin: 0.1rem 1rem 0.4rem;
    font-size: 0.68rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    color: rgba(60, 60, 67, 0.52);
}

[data-theme="dark"] .ios-codigo-peek-kicker {
    color: rgba(235, 235, 245, 0.48);
}

.ios-codigo-peek-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    width: 100%;
    padding: 0.6rem 1rem;
    border: none;
    background: transparent;
    font-family: inherit;
    font-size: 0.98rem;
    font-weight: 500;
    line-height: 1.25;
    text-align: left;
    color: #007aff;
    color: var(--color-primary, #007aff);
    cursor: pointer;
    transition: background 0.14s ease;
}

[data-theme="dark"] .ios-codigo-peek-row {
    color: #0a84ff;
}

.ios-codigo-peek-row:hover,
.ios-codigo-peek-row:focus-visible {
    background: rgba(0, 122, 255, 0.09);
}

[data-theme="dark"] .ios-codigo-peek-row:hover,
[data-theme="dark"] .ios-codigo-peek-row:focus-visible {
    background: rgba(10, 132, 255, 0.16);
}

.ios-codigo-peek-row--danger {
    color: #ff3b30;
    color: var(--color-danger, #ff3b30);
}

.ios-codigo-peek-row--danger:hover,
.ios-codigo-peek-row--danger:focus-visible {
    background: rgba(255, 59, 48, 0.1);
}

.ios-codigo-peek-sep {
    height: 1px;
    margin: 0.15rem 0.75rem;
    background: rgba(60, 60, 67, 0.14);
}

[data-theme="dark"] .ios-codigo-peek-sep {
    background: rgba(255, 255, 255, 0.11);
}

.ios-codigo-peek-icon {
    width: 1.38rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    opacity: 0.92;
    font-size: 1.02rem;
}

.ios-codigo-table--admin tbody tr[data-item-pk] {
    cursor: grab;
    transition: box-shadow 0.2s ease, opacity 0.2s ease, transform 0.18s ease;
}

.ios-codigo-tr--sort-ghost {
    opacity: 0.42;
    background: rgba(0, 122, 255, 0.07) !important;
}

.ios-codigo-tr--sort-chosen {
    box-shadow: 0 12px 32px rgba(0, 122, 255, 0.22);
    cursor: grabbing !important;
    transform: scale(1.008);
}

.ios-codigo-tr--sort-drag {
    opacity: 0.96;
}

.ios-codigo-row-edit {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    border: none;
    background: rgba(0, 122, 255, 0.1);
    color: var(--color-primary);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.95rem;
    transition: background 0.15s ease, transform 0.1s ease;
}

.ios-codigo-row-edit--labeled {
    width: auto;
    min-width: 6.5rem;
    height: auto;
    padding: 0.48rem 0.75rem;
    gap: 0.4rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.ios-codigo-row-edit--labeled i {
    font-size: 0.9rem;
}

.ios-codigo-row-edit:hover {
    background: rgba(0, 122, 255, 0.2);
    transform: scale(1.05);
}

.ios-codigo-edit-overlay {
    position: fixed;
    inset: 0;
    z-index: 12000;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.ios-codigo-edit-overlay.modal-overlay {
    z-index: 12000;
}

.ios-codigo-edit-overlay[hidden] {
    display: none !important;
}

/* Folha de edição de código — mesmo padrão de #globalModal (.modal-dialog + header arrastável) */
.ios-codigo-edit-sheet.modal-dialog {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 520px;
    max-height: min(88vh, 720px);
    margin: 0.75rem;
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    background: var(--surface-level-1);
    border: 1px solid var(--glass-border);
    box-shadow: 0 -12px 48px rgba(0, 0, 0, 0.18);
}

.ios-codigo-edit-sheet.modal-dialog .modal-header {
    flex-shrink: 0;
}

.ios-codigo-edit-modal-body.modal-body {
    padding: 1.25rem 1.5rem max(1.5rem, env(safe-area-inset-bottom));
    overflow-y: auto;
    flex: 1;
    min-height: 0;
    -webkit-overflow-scrolling: touch;
}

.ios-codigo-edit-sheet-title.modal-title {
    font-size: 1.28rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    text-align: left;
    flex: 1;
    margin-right: 0.75rem;
}

[data-theme="dark"] .ios-codigo-edit-sheet.modal-dialog {
    background: var(--surface-level-1);
}

.ios-field-textarea {
    min-height: 88px;
    resize: vertical;
    font-family: inherit;
}

.ios-codigo-edit-form select.ios-field-input {
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238E8E93' d='M2.5 4.5L6 8l3.5-3.5'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.75rem center;
    padding-right: 2.25rem;
}

[data-theme="dark"] .ios-codigo-edit-form select.ios-field-input {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23AEAEB2' d='M2.5 4.5L6 8l3.5-3.5'/%3E%3C/svg%3E");
}

.ios-codigo-edit-actions {
    display: flex;
    gap: 0.65rem;
    margin-top: 1.1rem;
    flex-wrap: wrap;
}

@media (max-width: 520px) {
    .ios-codigo-edit-sheet.modal-dialog {
        margin: 0;
        max-width: none;
    }

    .ios-codigo-card-go {
        display: none;
    }
}

/* ========== Painel Administração (iosdesign.md) ========== */
.administracao-page {
    --adm-blue: #007aff;
    --adm-green: #34c759;
    --adm-orange: #ff9500;
    --adm-purple: #af52de;
    --adm-indigo: #5856d6;
    max-width: 1100px;
}

.administracao-ios-nav {
    margin: 0 0 1.5rem;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 0.25rem;
}

.administracao-ios-segment {
    display: inline-flex;
    gap: 0.2rem;
    padding: 0.25rem;
    background: rgba(120, 120, 128, 0.12);
    border-radius: 12px;
    min-width: min-content;
}

.administracao-ios-segment__btn {
    padding: 0.45rem 0.75rem;
    border-radius: 10px;
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--color-text);
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.2s ease, color 0.2s ease;
}

.administracao-ios-segment__btn:hover {
    background: rgba(255, 255, 255, 0.45);
    color: var(--adm-blue);
}

.administracao-ios-segment__btn.is-active {
    background: var(--surface-level-1, #fff);
    color: var(--adm-blue);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

html[data-theme="dark"] .administracao-ios-segment {
    background: rgba(120, 120, 128, 0.24);
}

html[data-theme="dark"] .administracao-ios-segment__btn.is-active {
    background: rgba(44, 44, 46, 0.98);
}

.administracao-ios-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 1rem;
    margin-top: 0.5rem;
}

.administracao-ios-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.35rem;
    padding: 1.15rem 1.2rem;
    background: var(--surface-level-1, #fff);
    border-radius: 18px;
    border: 0.5px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.04);
    text-decoration: none;
    color: inherit;
    transition: transform 0.22s ease, box-shadow 0.22s ease;
}

.administracao-ios-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

html[data-theme="dark"] .administracao-ios-card {
    background: rgba(44, 44, 46, 0.92);
    border-color: var(--glass-border);
}

.administracao-ios-card--muted {
    opacity: 0.92;
}

.administracao-ios-card__icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    color: #fff;
    margin-bottom: 0.25rem;
}

.administracao-ios-card__icon--blue {
    background: linear-gradient(145deg, #0a84ff, #007aff);
}
.administracao-ios-card__icon--green {
    background: linear-gradient(145deg, #34c759, #30d158);
}
.administracao-ios-card__icon--orange {
    background: linear-gradient(145deg, #ff9500, #ff9f0a);
}
.administracao-ios-card__icon--purple {
    background: linear-gradient(145deg, #af52de, #da8fff);
}
.administracao-ios-card__icon--indigo {
    background: linear-gradient(145deg, #5856d6, #7c7cff);
}

.administracao-ios-card__title {
    font-weight: 700;
    font-size: 1.05rem;
    letter-spacing: -0.02em;
}

.administracao-ios-card__meta {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--adm-blue);
}

.administracao-ios-card__hint {
    font-size: 0.78rem;
    color: var(--text-soft);
    line-height: 1.4;
}

.administracao-ios-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: flex-end;
    margin-bottom: 1rem;
}

.administracao-ios-search {
    flex: 1;
    min-width: 220px;
}

.administracao-ios-select-label {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-soft);
}

.administracao-ios-select {
    min-width: 160px;
    border-radius: 12px;
}

.administracao-ios-select-label--grow {
    flex: 1 1 220px;
    min-width: 200px;
}

/* Busca avançada — lista de processos */
#processosListPage .processos-advanced-panel {
    margin-top: 0.6rem;
    margin-bottom: 0.35rem;
    padding: 1rem 1.15rem;
    border-radius: 16px;
    background: var(--surface-level-1, rgba(120, 120, 128, 0.08));
    border: 0.5px solid var(--glass-border);
}

#processosListPage .processos-advanced-panel summary {
    cursor: pointer;
    font-weight: 650;
    font-size: 0.92rem;
    list-style: none;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    user-select: none;
}

#processosListPage .processos-advanced-panel summary::-webkit-details-marker {
    display: none;
}

#processosListPage .processos-advanced-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

#processosListPage .processos-advanced-grid .form-group-mini label {
    display: block;
    font-size: 0.72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--text-soft);
    margin-bottom: 0.35rem;
}

#processosListPage .processos-advanced-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: center;
    margin-top: 1rem;
}

#processosListPage .processos-pagination {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin: 1.5rem 0 2rem;
    font-size: 0.9rem;
}

#processosListPage .filter-dropdown-wrap--ios {
    min-width: 200px;
}

/* Barra de pesquisa/status por cima do painel <details> para o menu não ficar atrás */
#processosListPage .search-filter-row {
    position: relative;
    z-index: 60;
    margin-bottom: 0.25rem;
}

#processosListPage .search-filter-row .custom-select-ui.active .select-items {
    z-index: 70;
}

#processosListPage .status-cards-row {
    margin-top: 1.75rem;
}

#processosListPage .process-header-section {
    margin-bottom: 0.25rem;
}

/* Painel de filtros acima dos cartões de estado: stacking para o menu iOS */
#processosListPage details.processos-advanced-panel[open] {
    position: relative;
    z-index: 40;
    isolation: isolate;
}

#processosListPage details.processos-advanced-panel .custom-select-ui.active .select-items {
    z-index: 50;
}

.administracao-ios-table-wrap {
    border-radius: 18px;
    overflow: hidden;
    padding: 0;
}

.administracao-ios-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.administracao-ios-table th {
    text-align: left;
    padding: 0.75rem 1rem;
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--text-soft);
    background: rgba(120, 120, 128, 0.08);
    border-bottom: 0.5px solid var(--separator-color);
}

.administracao-ios-table td {
    padding: 0.65rem 1rem;
    border-bottom: 0.5px solid var(--separator-color);
    vertical-align: middle;
}

.administracao-ios-table--compact td,
.administracao-ios-table--compact th {
    padding: 0.5rem 0.75rem;
    font-size: 0.8rem;
}

.administracao-user-cell {
    display: flex;
    align-items: center;
    gap: 0.65rem;
}

.administracao-user-cell__av {
    border-radius: 10px;
    object-fit: cover;
}

.administracao-user-cell__ph {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: rgba(120, 120, 128, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-soft);
}

.administracao-user-cell__name {
    font-weight: 650;
    display: block;
}

.administracao-user-cell__sub {
    font-size: 0.75rem;
    color: var(--text-soft);
}

.administracao-mono,
.administracao-mono-sm {
    font-family: ui-monospace, monospace;
    font-size: 0.82rem;
}

.administracao-mono-sm {
    font-size: 0.75rem;
}

.administracao-org-cargos-cell {
    max-width: 220px;
    vertical-align: top;
}

.administracao-vinc-line {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    align-items: flex-start;
    margin-bottom: 0.45rem;
    padding-bottom: 0.45rem;
    border-bottom: 0.5px solid rgba(0, 0, 0, 0.06);
}

.administracao-vinc-line:last-child {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

html[data-theme="dark"] .administracao-vinc-line {
    border-bottom-color: var(--glass-border);
}

.administracao-vinc-line__org {
    font-weight: 700;
    font-size: 0.85rem;
}

.administracao-vinc-line__cargo {
    font-size: 0.78rem;
    line-height: 1.25;
}

.administracao-vinc-pill {
    font-size: 0.62rem;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--adm-blue);
    background: rgba(0, 122, 255, 0.1);
    padding: 0.12rem 0.4rem;
    border-radius: 6px;
    margin-top: 0.1rem;
}

.administracao-vinc-line--extra .administracao-vinc-line__org {
    font-weight: 650;
}

.administracao-vinculos-extra {
    padding: 1rem 1.1rem;
    border-radius: 16px;
    margin-top: 1rem;
}

.administracao-vinculo-formset {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

.administracao-vinculo-row {
    padding: 0.75rem 0.85rem;
    border-radius: 14px;
    border: 0.5px solid rgba(0, 0, 0, 0.08);
    background: var(--surface-level-1, rgba(255, 255, 255, 0.55));
}

html[data-theme="dark"] .administracao-vinculo-row {
    background: rgba(44, 44, 46, 0.65);
    border-color: var(--glass-border);
}

.administracao-form-grid--vinculo {
    margin-top: 0.25rem;
}

.administracao-vinculo-delete {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.6rem;
    font-size: 0.78rem;
    color: var(--text-soft);
    cursor: pointer;
}

.administracao-muted {
    color: var(--text-soft);
}

.administracao-empty {
    text-align: center;
    padding: 2rem 1rem;
    color: var(--text-soft);
}

.administracao-ios-btn {
    border-radius: 12px;
    font-weight: 600;
    background: rgba(0, 122, 255, 0.12);
    color: var(--adm-blue);
    border: none;
    padding: 0.4rem 0.85rem;
}

.administracao-ios-btn:hover {
    background: rgba(0, 122, 255, 0.2);
}

.administracao-ios-btn--danger {
    background: rgba(255, 59, 48, 0.12);
    color: #ff3b30;
}

.administracao-ios-btn--danger:hover {
    background: rgba(255, 59, 48, 0.2);
}

.administracao-ios-btn--secondary {
    background: rgba(120, 120, 128, 0.12);
    color: var(--color-text);
}

.administracao-ios-btn--secondary:hover {
    background: rgba(120, 120, 128, 0.2);
}

.administracao-login-hist-launcher {
    margin-bottom: 1rem;
}

.administracao-login-hist-dialog {
    border: none;
    border-radius: 20px;
    padding: 0;
    max-width: min(420px, 94vw);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
    z-index: 10060;
}

.administracao-login-hist-dialog::backdrop {
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(6px);
}

.administracao-login-hist-dialog__head {
    padding: 1.15rem 1.25rem 0.5rem;
}

.administracao-login-hist-dialog__title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 720;
}

.administracao-login-hist-dialog__sub {
    margin: 0.35rem 0 0;
    font-size: 0.82rem;
}

.administracao-login-hist-dialog__list {
    margin: 0;
    padding: 0.5rem 1.25rem 1rem;
    list-style: none;
    max-height: min(52vh, 360px);
    overflow-y: auto;
}

.administracao-login-hist-dialog__list li {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 0.75rem;
    padding: 0.5rem 0;
    border-bottom: 0.5px solid rgba(0, 0, 0, 0.06);
    font-size: 0.82rem;
}

html[data-theme="dark"] .administracao-login-hist-dialog__list li {
    border-bottom-color: var(--glass-border);
}

.administracao-login-hist-dialog__list time {
    color: var(--text-soft);
    white-space: nowrap;
}

.administracao-login-hist-dialog__empty {
    margin: 0;
    padding: 0.75rem 1.25rem 1rem;
    font-size: 0.86rem;
}

.administracao-login-hist-dialog__actions {
    padding: 0 1.25rem 1.15rem;
    display: flex;
    justify-content: stretch;
}

.administracao-login-hist-dialog__actions .administracao-ios-submit {
    width: 100%;
    border-radius: 14px;
}

.administracao-ios-link {
    color: var(--adm-blue);
    font-weight: 600;
    text-decoration: none;
}

.administracao-ios-link:hover {
    text-decoration: underline;
}

.administracao-pagination {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-top: 1.25rem;
    flex-wrap: wrap;
}

.administracao-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.administracao-stat-card {
    background: var(--surface-level-1, #fff);
    border-radius: 16px;
    padding: 1rem;
    border: 0.5px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
    text-align: center;
}

html[data-theme="dark"] .administracao-stat-card {
    background: rgba(44, 44, 46, 0.92);
    border-color: var(--glass-border);
}

.administracao-stat-card__value {
    display: block;
    font-size: 1.45rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.administracao-stat-card__label {
    font-size: 0.72rem;
    color: var(--text-soft);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.administracao-ios-panel {
    padding: 1.15rem 1.25rem;
    border-radius: 18px;
    margin-bottom: 1rem;
}

.administracao-panel-title {
    margin: 0 0 0.65rem;
    font-size: 1.05rem;
    font-weight: 700;
}

.administracao-panel-note {
    margin: 0 0 0.75rem;
    font-size: 0.85rem;
}

.administracao-ip-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
}

.administracao-log-table-wrap {
    overflow-x: auto;
}

.administracao-ua-cell {
    max-width: 240px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.administracao-org-list {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.administracao-org-row {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 0.85rem 1rem;
    border-radius: 16px;
    text-decoration: none;
    color: inherit;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.administracao-org-row:hover {
    transform: scale(1.01);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.08);
}

.administracao-org-row__ico {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: rgba(0, 122, 255, 0.12);
    color: var(--adm-blue);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
}

.administracao-org-row__body {
    flex: 1;
    min-width: 0;
}

.administracao-org-row__title {
    font-weight: 700;
    display: block;
}

.administracao-org-row__meta {
    font-size: 0.8rem;
    color: var(--text-soft);
}

.administracao-org-row__chev {
    color: var(--text-tertiary);
    opacity: 0.6;
}

.administracao-marca-forms {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.administracao-marca-block {
    padding: 1.25rem 1.35rem;
    border-radius: 18px;
}

.administracao-marca-form .administracao-field {
    margin-bottom: 1rem;
}

.administracao-field label {
    display: block;
    font-size: 0.72rem;
    font-weight: 650;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-soft);
    margin-bottom: 0.35rem;
}

.administracao-field input[type="text"],
.administracao-field input[type="url"],
.administracao-field select,
.administracao-field input[type="file"] {
    width: 100%;
    max-width: 100%;
    border-radius: 12px;
}

.administracao-help {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.78rem;
}

.administracao-ios-submit {
    border-radius: 14px;
    margin-top: 0.5rem;
}

.administracao-form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.85rem;
}

@media (min-width: 520px) {
    .administracao-form-grid {
        grid-template-columns: 1fr 1fr;
    }
}

.administracao-field--error input,
.administracao-field--error select {
    border-color: #ff3b30 !important;
}

.administracao-field__err {
    display: block;
    font-size: 0.78rem;
    color: #ff3b30;
    margin-top: 0.25rem;
}

.administracao-modal-actions {
    margin-top: 1.25rem;
    display: flex;
    justify-content: flex-end;
}

.administracao-standalone-form {
    padding: 1.5rem;
    border-radius: 18px;
    max-width: 720px;
}

.administracao-del-form {
    display: inline;
}

/* Administração — SPA, ordenação, marca com crop, permissões iOS */
.administracao-spa-main--swap {
    opacity: 0.55;
    transform: translateY(6px);
    transition: opacity 0.22s ease, transform 0.22s ease;
}

.administracao-spa-main--entered {
    animation: administracaoSpaEnter 0.38s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes administracaoSpaEnter {
    from {
        opacity: 0.4;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: none;
    }
}

.administracao-th-sort {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font: inherit;
    font-weight: 650;
    color: var(--color-primary, #007aff);
    text-decoration: none;
    letter-spacing: inherit;
}

.administracao-th-sort:hover {
    text-decoration: underline;
}

.administracao-th-sort.is-active {
    color: var(--color-text);
}

.administracao-th-sort--static {
    color: var(--text-soft);
    font-weight: 650;
    cursor: default;
}

.administracao-th-sort__ico {
    font-size: 0.85em;
    opacity: 0.85;
}

.administracao-ios-table th {
    vertical-align: middle;
}

.administracao-marca-layout {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.administracao-marca-block--hero {
    padding: 1.35rem 1.45rem;
}

.administracao-marca-block__intro {
    margin-bottom: 1.1rem;
}

.administracao-marca-block__lede {
    margin: 0.35rem 0 0;
    font-size: 0.88rem;
    line-height: 1.45;
}

.administracao-marca-assets {
    display: grid;
    gap: 1.1rem;
}

@media (min-width: 720px) {
    .administracao-marca-assets {
        grid-template-columns: 1fr 1fr;
    }
}

.administracao-marca-asset {
    border-radius: 16px;
    padding: 1rem 1.05rem;
    background: var(--surface-level-2, rgba(0, 0, 0, 0.03));
    border: 0.5px solid var(--glass-border, rgba(0, 0, 0, 0.06));
}

html[data-theme="dark"] .administracao-marca-asset {
    background: rgba(255, 255, 255, 0.05);
}

.administracao-marca-asset__title {
    font-size: 1.02rem;
    font-weight: 700;
    margin: 0 0 0.25rem;
    letter-spacing: -0.02em;
}

.administracao-marca-asset__hint {
    margin: 0;
    font-size: 0.82rem;
    color: var(--text-soft);
    line-height: 1.4;
}

.administracao-marca-asset__meta {
    margin: 0.5rem 0 0;
    font-size: 0.78rem;
}

.administracao-marca-asset__meta code {
    font-size: 0.76rem;
    word-break: break-all;
}

.administracao-marca-asset__preview-shell {
    margin-top: 0.75rem;
    border-radius: 14px;
    overflow: hidden;
    background: repeating-linear-gradient(
        45deg,
        rgba(0, 0, 0, 0.04),
        rgba(0, 0, 0, 0.04) 8px,
        rgba(0, 0, 0, 0.02) 8px,
        rgba(0, 0, 0, 0.02) 16px
    );
    min-height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

html[data-theme="dark"] .administracao-marca-asset__preview-shell {
    background: repeating-linear-gradient(
        45deg,
        rgba(255, 255, 255, 0.04),
        rgba(255, 255, 255, 0.04) 8px,
        rgba(255, 255, 255, 0.02) 8px,
        rgba(255, 255, 255, 0.02) 16px
    );
}

.administracao-marca-asset__preview {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.75rem;
    min-height: 100px;
}

.administracao-marca-asset__img {
    max-width: 100%;
    max-height: 140px;
    object-fit: contain;
    display: block;
}

.administracao-marca-asset__ph {
    font-size: 0.85rem;
    color: var(--text-soft);
}

.administracao-marca-asset__toolbar {
    margin-top: 0.75rem;
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.administracao-marca-native-file {
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 0.5px solid var(--glass-border);
    font-size: 0.8rem;
    line-height: 1.45;
    position: relative;
}

/* ClearableFileInput: só «Ver ficheiro» + «Limpar»; o ficheiro novo é escolhido só via «Escolher imagem…» + recorte */
.administracao-marca-native-file .file-upload {
    margin: 0;
    padding: 0.65rem 0.85rem;
    border-radius: 14px;
    background: rgba(120, 120, 128, 0.08);
    border: 0.5px solid rgba(0, 0, 0, 0.06);
    color: var(--color-text);
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.55rem;
}

html[data-theme="dark"] .administracao-marca-native-file .file-upload {
    background: rgba(255, 255, 255, 0.06);
    border-color: var(--glass-border);
}

.administracao-marca-native-file .file-upload a {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.42rem 0.95rem;
    border-radius: 12px;
    font-weight: 650;
    font-size: 0.78rem;
    text-decoration: none;
    word-break: break-word;
    background: rgba(0, 122, 255, 0.12);
    color: var(--color-primary, #007aff);
    border: none;
    max-width: 100%;
    box-sizing: border-box;
}

.administracao-marca-native-file .file-upload a:hover {
    background: rgba(0, 122, 255, 0.2);
}

.administracao-marca-native-file .file-upload input[type="checkbox"] {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    pointer-events: none;
}

.administracao-marca-native-file .file-upload label {
    display: inline-flex;
    align-items: center;
    margin: 0;
    padding: 0.4rem 0.9rem;
    border-radius: 12px;
    font-size: 0.78rem;
    font-weight: 650;
    background: rgba(255, 59, 48, 0.1);
    color: var(--color-danger, #ff3b30);
    cursor: pointer;
    border: 0.5px solid rgba(255, 59, 48, 0.22);
    transition: background 0.15s ease;
}

.administracao-marca-native-file .file-upload label:hover {
    background: rgba(255, 59, 48, 0.16);
}

.administracao-marca-native-file .file-upload br {
    display: none;
}

/* Input nativo oculto: evita segundo botão «Procurar…»; o recorte preenche este campo. */
.administracao-marca-native-file input[type="file"] {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
    opacity: 0 !important;
    pointer-events: none !important;
}

.administracao-crop-sheet.modal-overlay {
    align-items: center;
    justify-content: center;
    padding: 1rem;
    inset: 0;
    width: 100vw;
    height: 100vh;
    max-height: 100dvh;
    box-sizing: border-box;
}

.administracao-crop-sheet .administracao-crop-sheet__dialog.modal-dialog {
    border-radius: 20px;
    max-width: min(540px, 100%);
    transform: scale(0.94) translateY(16px);
    max-height: min(92vh, 92dvh);
}

.administracao-crop-sheet.modal-overlay.active .administracao-crop-sheet__dialog.modal-dialog {
    transform: scale(1) translateY(0);
}

.administracao-crop-sheet__handle {
    width: 40px;
    height: 5px;
    border-radius: 99px;
    background: rgba(0, 0, 0, 0.12);
    margin: 0.65rem auto 0.25rem;
}

html[data-theme="dark"] .administracao-crop-sheet__handle {
    background: rgba(255, 255, 255, 0.2);
}

.administracao-crop-sheet__title {
    margin: 0.35rem 1.25rem 0;
    font-size: 1.15rem;
    font-weight: 720;
    letter-spacing: -0.03em;
}

.administracao-crop-sheet__hint {
    margin: 0.35rem 1.25rem 0.75rem;
    font-size: 0.84rem;
    line-height: 1.45;
}

.administracao-crop-sheet__viewport {
    margin: 0 1rem;
    max-height: min(48vh, 420px);
    background: #000;
    border-radius: 14px;
    overflow: hidden;
}

.administracao-crop-sheet__viewport img {
    display: block;
    max-width: 100%;
}

.administracao-crop-sheet__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.6rem;
    padding: 1rem 1.25rem 1.15rem;
}

.administracao-permissoes-card {
    margin-top: 1.25rem;
    padding: 1.1rem 1.2rem;
    border-radius: 16px;
}

.administracao-permissoes-card__title {
    margin: 0 0 0.35rem;
    font-size: 1.02rem;
    font-weight: 720;
}

.administracao-permissoes-card__intro {
    margin: 0 0 1rem;
    font-size: 0.84rem;
    line-height: 1.45;
}

.administracao-perm-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.75rem 0;
    border-top: 0.5px solid var(--glass-border);
}

.administracao-perm-row:first-of-type {
    border-top: none;
    padding-top: 0;
}

.administracao-perm-row__text {
    flex: 1;
    min-width: 0;
}

.administracao-perm-row__label {
    display: block;
    font-weight: 650;
    font-size: 0.92rem;
}

.administracao-perm-row__hint {
    display: block;
    margin-top: 0.3rem;
    font-size: 0.8rem;
    color: var(--text-soft);
    line-height: 1.45;
}

.administracao-ios-switch {
    position: relative;
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    cursor: pointer;
}

.administracao-ios-switch-input {
    position: absolute;
    opacity: 0;
    width: 1px;
    height: 1px;
    margin: 0;
    pointer-events: none;
}

.administracao-ios-switch__visual {
    position: relative;
    width: 51px;
    height: 31px;
    border-radius: 999px;
    background: #e9e9ea;
    transition: background 0.22s ease;
}

html[data-theme="dark"] .administracao-ios-switch__visual {
    background: #39393d;
}

.administracao-ios-switch__visual::after {
    content: "";
    position: absolute;
    left: 2px;
    top: 2px;
    width: 27px;
    height: 27px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.18);
    transition: transform 0.24s cubic-bezier(0.22, 1, 0.36, 1);
}

.administracao-ios-switch-input:checked + .administracao-ios-switch__visual {
    background: #34c759;
}

.administracao-ios-switch-input:checked + .administracao-ios-switch__visual::after {
    transform: translateX(20px);
}

.administracao-ios-switch-input:focus-visible + .administracao-ios-switch__visual {
    outline: 2px solid var(--color-primary, #007aff);
    outline-offset: 3px;
}

/* Administração › Estatísticas — mapas e gráficos */
.administracao-stats-maps-row {
    display: grid;
    gap: 1.1rem;
    margin-top: 0.25rem;
}

@media (min-width: 900px) {
    .administracao-stats-maps-row {
        grid-template-columns: 1fr 1fr;
    }
}

.administracao-stats-map-card {
    padding: 1.2rem 1.25rem;
}

.administracao-stats-leaflet {
    height: min(360px, 52vh);
    width: 100%;
    border-radius: 14px;
    overflow: hidden;
    margin-top: 0.65rem;
    border: 0.5px solid var(--glass-border);
    background: #f5f5f7;
}

html[data-theme="dark"] .administracao-stats-leaflet {
    background: #2c2c2e;
}

.administracao-stats-section-title {
    margin: 1.35rem 0 0.45rem;
    font-size: 0.72rem;
    font-weight: 750;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-soft, #636366);
}

.administracao-stats-charts-row {
    display: grid;
    gap: 1.1rem;
    margin-top: 1.1rem;
}

@media (min-width: 820px) {
    .administracao-stats-charts-row {
        grid-template-columns: 1fr 1fr;
    }

    .administracao-stats-charts-row--pair {
        grid-template-columns: 1fr 1fr;
    }

    .administracao-stats-charts-row--triple {
        grid-template-columns: repeat(3, 1fr);
    }

    .administracao-stats-chart-card--span2 {
        grid-column: span 2;
    }
}

.administracao-stats-chart-card {
    padding: 1.15rem 1.2rem;
}

.administracao-stats-echart {
    width: 100%;
    height: min(300px, 42vh);
    margin-top: 0.35rem;
}

.administracao-stats-echart--compact {
    height: min(288px, 42vh);
}

.administracao-stats-echart--tall {
    height: min(300px, 44vh);
}

.administracao-stats-echart--heatmap {
    height: min(340px, 48vh);
}

.administracao-stats-echart--graph {
    height: min(380px, 52vh);
}

.administracao-ip-list--rich li {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1.4fr);
    gap: 0.65rem 0.9rem;
    align-items: baseline;
}

@media (max-width: 640px) {
    .administracao-ip-list--rich li {
        grid-template-columns: 1fr;
    }
}

.administracao-ip-list__count {
    font-size: 0.78rem;
    color: var(--text-soft);
    white-space: nowrap;
}

.administracao-ip-list__geo {
    font-size: 0.78rem;
    color: var(--color-text);
    text-align: right;
}

.administracao-geo-cell {
    font-size: 0.8rem;
    max-width: 10rem;
}

.administracao-http-code {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.6rem;
    padding: 0.12rem 0.45rem;
    border-radius: 8px;
    font-weight: 700;
    font-size: 0.78rem;
}

.administracao-http-code--400,
.administracao-http-code--401,
.administracao-http-code--403,
.administracao-http-code--404 {
    background: rgba(255, 149, 0, 0.2);
    color: #c93400;
}

.administracao-http-code--500,
.administracao-http-code--502,
.administracao-http-code--503 {
    background: rgba(255, 59, 48, 0.18);
    color: #d70015;
}

