/**
 * SeuSaude Branding - Roundcube Elastic Skin
 * email.seusaude.com (default brand)
 */

/* ═══════════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════════ */

body.task-login #logo,
body.task-login .voice { display: none !important; }

body.task-login #layout {
    overflow: visible !important;
    height: auto !important;
    min-height: 100vh !important;
    display: block !important;
}

body.task-login #layout-content {
    background: linear-gradient(135deg, #667eea 0%, #22c1c3 100%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100vh !important;
    padding: 24px !important;
    text-align: left !important;
}
body.task-login #layout-content::before {
    content: '';
    position: fixed;
    inset: 0;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(120,80,220,0.15) 0%, transparent 50%),
        radial-gradient(ellipse at 80% 20%, rgba(34,193,195,0.15) 0%, transparent 50%);
    pointer-events: none;
    z-index: 0;
}

body.task-login .login-card {
    position: relative;
    z-index: 1;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 6px rgba(0,0,0,0.04), 0 20px 50px rgba(0,0,0,0.12);
    width: 100%;
    max-width: 420px;
    padding: 40px 36px 32px;
    margin: 0 auto;
}

body.task-login .login-header {
    text-align: center;
    margin-bottom: 32px;
}
body.task-login .login-header img {
    max-width: 190px;
    height: auto;
    margin-bottom: 14px;
}
body.task-login .login-title {
    font-size: 24px;
    font-weight: 700;
    color: #1e293b;
    margin: 0 0 4px;
}
body.task-login .login-header .login-subtitle {
    display: block;
    font-size: 15px;
    color: #64748b;
    letter-spacing: 0.2px;
    margin-top: 4px;
}
body.task-login .login-header .login-divider {
    width: 44px;
    height: 3px;
    background: linear-gradient(90deg, #7c5cdb, #22c1c3);
    border-radius: 2px;
    margin: 16px auto 0;
}

body.task-login #login-form {
    background: none !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
    width: 100% !important;
    border-radius: 0 !important;
    position: static !important;
    top: auto !important;
}

body.task-login #login-form > table {
    width: 100% !important;
    border-spacing: 0 !important;
    border-collapse: collapse !important;
}
body.task-login #login-form > table,
body.task-login #login-form > table > tbody,
body.task-login #login-form > table > tbody > tr,
body.task-login #login-form > table > tbody > tr > td {
    display: block !important;
    width: 100% !important;
}
body.task-login #login-form > table > tbody > tr {
    margin-bottom: 20px !important;
}
body.task-login #login-form > table > tbody > tr > td {
    padding: 0 !important;
}

body.task-login #login-form > table > tbody > tr > td.title {
    padding-bottom: 8px !important;
}
body.task-login #login-form > table > tbody > tr > td.title label {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #374151 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.6px !important;
}
body.task-login #login-form > table > tbody > tr > td.title label::after {
    content: ':' !important;
}

body.task-login #login-form .input-group .icon,
body.task-login #login-form .input-group .input-group-prepend,
body.task-login #login-form .input-group-text {
    display: none !important;
}

body.task-login #login-form .input-group {
    display: flex !important;
    align-items: center !important;
    border: 2px solid #e2e8f0 !important;
    border-radius: 10px !important;
    background: #f8fafc !important;
    overflow: hidden !important;
    transition: border-color 0.2s, box-shadow 0.2s !important;
}
body.task-login #login-form .input-group:focus-within {
    border-color: #7c5cdb !important;
    box-shadow: 0 0 0 3px rgba(124,92,219,0.1) !important;
    background: #fff !important;
}

body.task-login #login-form input.form-control,
body.task-login #login-form input[type="text"],
body.task-login #login-form input[type="password"] {
    flex: 1 !important;
    width: 100% !important;
    height: 46px !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 16px !important;
    font-size: 15px !important;
    color: #1e293b !important;
    background: transparent !important;
    box-sizing: border-box !important;
    outline: none !important;
    margin: 0 !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
}
body.task-login #login-form input::placeholder {
    color: #94a3b8 !important;
}

body.task-login #login-form .formbuttons {
    margin: 28px 0 0 !important;
    padding: 0 !important;
}
body.task-login #login-form .formbuttons .submit,
body.task-login #login-form button.mainaction,
body.task-login #rcmloginsubmit {
    width: 100% !important;
    height: 48px !important;
    background: linear-gradient(135deg, #7c5cdb 0%, #22c1c3 100%) !important;
    border: none !important;
    border-radius: 10px !important;
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: opacity 0.2s, transform 0.2s !important;
    letter-spacing: 0.4px !important;
    padding: 0 !important;
    display: block !important;
}
body.task-login #rcmloginsubmit:hover {
    opacity: 0.92 !important;
    transform: translateY(-1px) !important;
}

body.task-login .login-forgot {
    text-align: center;
    margin: 20px 0 0;
}
body.task-login .login-forgot a {
    color: #7c5cdb;
    font-size: 13px;
    text-decoration: none;
    font-weight: 500;
}
body.task-login .login-forgot a:hover {
    text-decoration: underline;
}

body.task-login .login-register {
    text-align: center;
    margin: 20px 0 4px;
    padding-top: 20px;
    border-top: 1px solid #f1f5f9;
}
body.task-login .login-register a {
    color: #64748b;
    font-size: 13px;
    text-decoration: none;
}
body.task-login .login-register a strong {
    color: #7c5cdb;
    font-weight: 600;
}
body.task-login .login-register a:hover { color: #7c5cdb; }

body.task-login #login-footer {
    text-align: center;
    padding-top: 12px;
    font-size: 12px;
    color: #94a3b8;
}

@media (max-width: 480px) {
    body.task-login #layout-content { padding: 16px !important; }
    body.task-login .login-card {
        padding: 32px 24px 24px;
        border-radius: 14px;
    }
    body.task-login .login-header img { max-width: 170px; }
    body.task-login .login-header { margin-bottom: 28px; }
    body.task-login #login-form input {
        font-size: 16px !important;
    }
}

body.task-login .noscriptwarning {
    position: relative;
    z-index: 1;
    max-width: 440px;
    margin: 12px auto;
    background: rgba(255,255,255,0.9);
    border-radius: 10px;
    padding: 14px;
    text-align: center;
    font-size: 13px;
    color: #dc2626;
}

/* ═══════════════════════════════════════════
   APP (pós-login)
   ═══════════════════════════════════════════ */

body:not(.task-login) {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

#layout > .header,
#layout > div > .header {
    background: linear-gradient(135deg, #667eea 0%, #22c1c3 100%) !important;
}

/* Label "Webmail:" discreto abaixo do título do header */
body:not(.task-login) #layout > .header .header-title::after,
body:not(.task-login) #layout > div > .header .header-title::after {
    content: " - Webmail";
    opacity: 0.75;
    font-weight: 400;
    font-size: 0.82em;
    margin-left: 6px;
    letter-spacing: 0.3px;
}

.menu a.button,
#layout > .header a.button,
#layout > div > .header a.button {
    color: #fff !important;
}

.menu a.button:hover,
#layout > .header a.button:hover,
#layout > div > .header a.button:hover {
    background: rgba(255, 255, 255, 0.15) !important;
}

.header .header-title,
.header a.button::before,
#layout .header span.inner {
    color: #fff !important;
}

.searchbar input {
    border-color: rgba(255, 255, 255, 0.3) !important;
}

.menu a.button.selected,
.menu a.button.active,
.menu a.button:focus,
#layout .header a.button.selected {
    background: rgba(124, 92, 219, 0.5) !important;
    color: #fff !important;
}

#mailboxlist li a:hover,
#mailboxlist li.selected > a,
.listing li a:hover {
    background: rgba(124, 92, 219, 0.08) !important;
}

#mailboxlist li.selected > a { color: #7c5cdb !important; font-weight: 600; }
#mailboxlist li.selected > a::before { color: #7c5cdb !important; }

a, .listing a.active { color: #7c5cdb; }
a:hover { color: #6345c4; }

.btn-primary,
a.btn-primary,
.formbuttons .btn-primary {
    background: linear-gradient(135deg, #7c5cdb 0%, #22c1c3 100%) !important;
    border: none !important;
    color: #fff !important;
}
.btn-primary:hover,
a.btn-primary:hover { opacity: 0.9; }

#taskmenu a::before { color: #fff !important; }
#taskmenu a:hover { background: rgba(255, 255, 255, 0.15) !important; }
#taskmenu a.selected,
#taskmenu a.button.selected { background: rgba(124, 92, 219, 0.5) !important; }

#compose-toolbar {
    background: linear-gradient(135deg, #667eea 0%, #22c1c3 100%) !important;
}
#compose-toolbar a.button { color: #fff !important; }

input[type="checkbox"]:checked { accent-color: #7c5cdb; }
::-webkit-scrollbar-thumb {
    background: rgba(124, 92, 219, 0.3);
    border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover { background: rgba(124, 92, 219, 0.5); }

/* ─── Lista de mensagens: contraste lidos vs nao-lidos ─── */
.messagelist tr td,
.messagelist tr td a.subject,
.messagelist tr td .fromto {
    color: #64748b;
    font-weight: 400;
}
.messagelist tr.unread td,
.messagelist tr.unread td a.subject,
.messagelist tr.unread td .fromto,
.messagelist tr.unread td .subject {
    color: #0f172a !important;
    font-weight: 700 !important;
}
.messagelist tr:hover td {
    background: rgba(124, 92, 219, 0.06) !important;
    transition: background-color 0.15s ease;
}
.messagelist tr.selected td,
.messagelist tr.focused.selected td {
    background: rgba(124, 92, 219, 0.14) !important;
    color: #1e293b !important;
}

/* Badge/contador da sidebar com cor da marca */
#mailboxlist li .unreadcount,
.listing li .unreadcount {
    background: linear-gradient(135deg, #7c5cdb 0%, #22c1c3 100%) !important;
    color: #fff !important;
    border-radius: 11px;
    padding: 1px 8px;
    font-weight: 600;
    font-size: 11px;
    min-width: 20px;
    text-align: center;
    box-shadow: 0 1px 3px rgba(124, 92, 219, 0.25);
}

/* Toolbar buttons - hover suave */
.toolbar a.button,
.toolbar button.button {
    transition: background-color 0.15s ease, transform 0.1s ease;
}
.toolbar a.button:hover:not(.disabled),
.toolbar button.button:hover:not(.disabled) {
    background: rgba(124, 92, 219, 0.1) !important;
}

/* ─── Responsive tablet/mobile ─── */
@media (max-width: 1024px) {
    .messagelist td.subject a { font-size: 15px; }
    .messagelist td.fromto { font-size: 14px; }
}

@media (max-width: 768px) {
    body:not(.task-login) { font-size: 14px; }
    #layout { min-height: 100vh; min-height: 100dvh; }
    #layout > .header,
    #layout > div > .header { padding: 0 0.5rem !important; }

    /* Botoes 44px - touch-friendly */
    button.btn, a.button, .btn,
    .toolbar a.button, .toolbar button.button,
    #taskmenu a.button { min-height: 44px; min-width: 44px; }

    /* Lista de mensagens legivel em mobile */
    .messagelist td.subject a { font-size: 14px; line-height: 1.4; }
    .messagelist td.fromto { font-size: 13px; }
    .messagelist td.date { font-size: 12px; }

    /* Header label simplificado em mobile */
    #layout > .header .header-title::after,
    #layout > div > .header .header-title::after {
        display: none;
    }
}

@media (max-width: 480px) {
    /* Inputs com 16px evita zoom iOS */
    .searchbar input,
    #compose-subject input,
    #compose-contacts input,
    .compose-headers input,
    input[type="text"],
    input[type="email"],
    input[type="search"],
    textarea { font-size: 16px !important; }

    /* Sidebar como overlay/drawer */
    #layout-sidebar {
        position: fixed !important;
        top: 0;
        left: 0;
        z-index: 1050;
        width: 85% !important;
        max-width: 320px;
        height: 100vh;
        height: 100dvh;
        box-shadow: 2px 0 12px rgba(0, 0, 0, 0.15);
    }

    /* Compose em tela cheia */
    body.task-mail.action-compose #layout-content,
    body.task-mail.action-compose .editor-frame {
        height: 100vh !important;
        height: 100dvh !important;
    }
    #compose-body { min-height: 45vh; }

    /* Toolbar compacta */
    .toolbar a.button span.inner,
    .toolbar button.button span.inner { display: none; }

    /* Lista mais compacta mas legivel */
    .messagelist td { padding: 8px 6px !important; }
    .messagelist td.subject a { font-size: 14px; }
}

/* ─── Safe-area para iPhones com notch ─── */
@supports (padding: max(0px)) {
    body {
        padding-left: max(env(safe-area-inset-left), 0px);
        padding-right: max(env(safe-area-inset-right), 0px);
    }
    #layout > .header {
        padding-top: env(safe-area-inset-top) !important;
    }
    @media (max-width: 480px) {
        #layout-sidebar { padding-bottom: env(safe-area-inset-bottom); }
    }
}

/* ═══════════════════════════════════════════
   PRINT - layout limpo
   ═══════════════════════════════════════════ */
@media print {
    body, html { background: #fff !important; color: #000 !important; }
    #layout > .header,
    #layout > div > .header,
    #taskmenu,
    #layout-sidebar,
    #messagelist-header,
    .toolbar,
    .searchbar,
    .footer,
    #message-header-additional,
    .header-links,
    a.button, button.button { display: none !important; }
    #layout, #layout-content, #layout-content > .content,
    .messageview, #messagebody, #message-content {
        position: static !important;
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        overflow: visible !important;
        box-shadow: none !important;
        border: none !important;
        background: #fff !important;
    }
    #messagebody, #message-content, .messageview * {
        font-family: Georgia, "Times New Roman", serif !important;
        color: #000 !important;
        font-size: 12pt !important;
        line-height: 1.55 !important;
    }
    .message-partheaders,
    .message-header,
    #message-objects {
        border-bottom: 1px solid #000 !important;
        padding-bottom: 8pt;
        margin-bottom: 12pt;
    }
    a { color: #000 !important; text-decoration: underline; }
    @page { margin: 1.4cm; }
}
