/**
 * Dra. Louise Chateaubriand - Webmail
 * Replica exata do login do admin panel (admin.css)
 */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap');

:root {
    --nude-100: #F8F6F3;
    --nude-200: #EEEBE6;
    --nude-300: #DBD2C8;
    --nude-400: #C4B8AB;
    --nude-500: #8E7468;
    --nude-600: #553234;
    --nude-700: #462829;
    --dark-200: #3D322E;
    --dark-300: #2C2420;
    --dark-400: #1E1814;
}

/* ═══════════════════════════════════════════
   LOGIN PAGE - Replica admin.css
   ═══════════════════════════════════════════ */

body.task-login {
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif !important;
    -webkit-font-smoothing: antialiased;
    padding-left: env(safe-area-inset-left);
    padding-right: env(safe-area-inset-right);
}

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(145deg, var(--dark-400) 0%, var(--dark-300) 50%, #3A2E28 100%) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 100vh !important;
    padding: 1.5rem !important;
    text-align: left !important;
    position: relative !important;
    overflow: hidden !important;
}

body.task-login #layout-content::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 200%;
    background: radial-gradient(circle at 30% 40%, rgba(85, 50, 52, 0.06) 0%, transparent 50%),
                radial-gradient(circle at 70% 60%, rgba(85, 50, 52, 0.04) 0%, transparent 40%);
    animation: loginBgMove 20s ease-in-out infinite alternate;
    pointer-events: none;
    z-index: 0;
}

@keyframes loginBgMove {
    0% { transform: translate(0, 0); }
    100% { transform: translate(-3%, -2%); }
}

body.task-login .login-card {
    position: relative;
    z-index: 1;
    background: #fff;
    border-radius: 20px;
    padding: 3rem 2.5rem;
    max-width: 420px;
    width: 100%;
    box-shadow: 0 25px 80px rgba(0, 0, 0, 0.25);
    border: 1px solid var(--nude-300);
    margin: 0 auto;
}

/* Header - logomarca transparente centralizada */
body.task-login .login-header {
    text-align: center;
    margin-bottom: 2rem;
}
body.task-login #login-logo {
    display: block !important;
    max-width: 320px !important;
    width: 100% !important;
    height: auto !important;
    object-fit: contain !important;
    margin: 0 auto 0.5rem !important;
    background: transparent !important;
}
body.task-login .login-title { display: none !important; }
body.task-login .login-subtitle { display: none !important; }
body.task-login .login-divider {
    width: 100% !important;
    height: 1px !important;
    background: linear-gradient(90deg, transparent, var(--nude-300), transparent) !important;
    border-radius: 0 !important;
    margin: 1.5rem 0 0 !important;
}

/* Form reset */
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;
}

/* Table layout - labels acima */
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: 1rem !important;
}
body.task-login #login-form > table > tbody > tr > td { padding: 0 !important; }

/* Labels */
body.task-login #login-form > table > tbody > tr > td.title {
    padding-bottom: 6px !important;
}
body.task-login #login-form > table > tbody > tr > td.title label {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 0.72rem !important;
    font-weight: 600 !important;
    color: var(--nude-500) !important;
    text-transform: uppercase !important;
    letter-spacing: 1.2px !important;
}

/* Esconder icons do Roundcube */
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; }

/* Input group - borda nude arredondada */
body.task-login #login-form .input-group {
    display: flex !important;
    align-items: center !important;
    border: 1.5px solid var(--nude-300) !important;
    border-radius: 12px !important;
    background: var(--nude-100) !important;
    overflow: hidden !important;
    transition: all 0.2s !important;
}
body.task-login #login-form .input-group:focus-within {
    border-color: var(--nude-500) !important;
    background: #fff !important;
    box-shadow: 0 0 0 3px rgba(85, 50, 52, 0.15) !important;
}

/* Inputs */
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: 48px !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0.85rem 1rem !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 0.9rem !important;
    color: var(--dark-200) !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: var(--nude-600) !important;
}

/* Botão - gradiente nude com sombra */
body.task-login #login-form .formbuttons {
    margin: 1.25rem 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;
    padding: 0.9rem !important;
    height: auto !important;
    background: linear-gradient(135deg, var(--nude-500), var(--nude-600)) !important;
    color: var(--nude-100) !important;
    border: none !important;
    border-radius: 12px !important;
    font-family: 'DM Sans', sans-serif !important;
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all 0.3s !important;
    letter-spacing: 0.4px !important;
    display: block !important;
    box-shadow: 0 4px 15px rgba(85, 50, 52, 0.3) !important;
    margin: 0.5rem 0 0 !important;
}
body.task-login #rcmloginsubmit:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 25px rgba(85, 50, 52, 0.4) !important;
}

/* Footer */
body.task-login #login-footer {
    text-align: center;
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--nude-200);
    font-size: 0.75rem;
    color: var(--nude-500);
    font-weight: 500;
}

/* Mensagens de erro/alerta */
body.task-login #messagestack {
    margin: 0 0 1rem !important;
}
body.task-login #messagestack .alert,
body.task-login #messagestack .error,
body.task-login #messagestack .warning {
    background: #fef2f2 !important;
    border: 1px solid #fecaca !important;
    color: #dc2626 !important;
    padding: 0.65rem 1rem !important;
    border-radius: 10px !important;
    font-size: 0.82rem !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
}

body.task-login .noscriptwarning {
    position: relative;
    z-index: 1;
    max-width: 420px;
    margin: 12px auto;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 10px;
    padding: 14px;
    text-align: center;
    font-size: 13px;
    color: #dc2626;
}

/* Responsive mobile */
@media (max-width: 480px) {
    body.task-login #layout-content {
        padding: 1rem !important;
    }
    body.task-login .login-card {
        padding: 2rem 1.5rem !important;
        border-radius: 16px !important;
    }
    body.task-login .login-title { font-size: 1.3rem !important; }
    body.task-login .login-subtitle { font-size: 0.72rem !important; }
    body.task-login .login-header { margin-bottom: 1.5rem !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"] {
        font-size: 16px !important; /* Evita zoom no iOS */
    }
}

/* ═══════════════════════════════════════════
   APP (pos-login) - Toolbar & UI
   ═══════════════════════════════════════════ */

body:not(.task-login) {
    font-family: 'DM Sans', -apple-system, sans-serif;
}

/* Header principal */
#layout > .header,
#layout > div > .header {
    background: linear-gradient(135deg, var(--nude-600) 0%, var(--nude-500) 100%) !important;
}

/* Label "Webmail" discreto apos o titulo 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.8;
    font-weight: 400;
    font-size: 0.82em;
    margin-left: 6px;
    letter-spacing: 0.4px;
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
}

.menu a.button,
#layout > .header a.button,
#layout > div > .header a.button,
.header .header-title,
.header a.button::before,
#layout .header span.inner {
    color: var(--nude-100) !important;
}

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

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

.menu a.button.selected,
.menu a.button.active,
.menu a.button:focus,
#layout .header a.button.selected {
    background: rgba(142, 116, 104, 0.6) !important;
    color: var(--nude-100) !important;
}

/* Sidebar */
#mailboxlist li a:hover,
#mailboxlist li.selected > a,
.listing li a:hover {
    background: rgba(85, 50, 52, 0.08) !important;
}

#mailboxlist li.selected > a,
#mailboxlist li.selected > a::before {
    color: var(--nude-600) !important;
    font-weight: 600;
}

/* Links */
a, .listing a.active { color: var(--nude-600); }
a:hover { color: var(--nude-500); }

/* Botões primários */
.btn-primary,
a.btn-primary,
.formbuttons .btn-primary,
button.mainaction {
    background: linear-gradient(135deg, var(--nude-500), var(--nude-600)) !important;
    border: none !important;
    color: #fff !important;
    box-shadow: 0 4px 15px rgba(85, 50, 52, 0.25) !important;
}

.btn-primary:hover,
a.btn-primary:hover,
button.mainaction:hover {
    transform: translateY(-1px);
    opacity: 0.95;
}

/* Taskmenu */
#taskmenu a::before { color: var(--nude-100) !important; }
#taskmenu a:hover { background: rgba(248, 246, 243, 0.15) !important; }
#taskmenu a.selected,
#taskmenu a.button.selected {
    background: rgba(142, 116, 104, 0.5) !important;
}

/* Compose */
#compose-toolbar {
    background: linear-gradient(135deg, var(--nude-600) 0%, var(--nude-500) 100%) !important;
}
#compose-toolbar a.button { color: var(--nude-100) !important; }

/* Checkbox & scrollbar */
input[type="checkbox"]:checked { accent-color: var(--nude-600); }
::-webkit-scrollbar { width: 7px; }
::-webkit-scrollbar-track { background: var(--nude-200); }
::-webkit-scrollbar-thumb { background: var(--nude-500); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--nude-600); }
::selection { background: var(--nude-500); color: var(--nude-100); }

/* ─── Lista de mensagens: contraste lidos vs nao-lidos ─── */
.messagelist tr td,
.messagelist tr td a.subject,
.messagelist tr td .fromto {
    color: var(--nude-500);
    font-weight: 400;
}
.messagelist tr.unread td,
.messagelist tr.unread td a.subject,
.messagelist tr.unread td .fromto,
.messagelist tr.unread td .subject {
    color: var(--dark-400) !important;
    font-weight: 700 !important;
}
.messagelist tr:hover td {
    background: rgba(85, 50, 52, 0.06) !important;
    transition: background-color 0.15s ease;
}
.messagelist tr.selected td,
.messagelist tr.focused.selected td {
    background: rgba(85, 50, 52, 0.13) !important;
    color: var(--dark-300) !important;
}

/* Badge/contador da sidebar com cor da marca */
#mailboxlist li .unreadcount,
.listing li .unreadcount {
    background: linear-gradient(135deg, var(--nude-600), var(--nude-500)) !important;
    color: var(--nude-100) !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(85, 50, 52, 0.3);
}

/* 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(85, 50, 52, 0.08) !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; }
    .searchbar { max-width: 100%; }
    .menu a.button { padding: 0 0.65rem !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; }

    /* Header ajustado */
    #layout > .header,
    #layout > div > .header { padding: 0 0.5rem !important; }

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

    /* Esconder sufixo do titulo em mobile */
    #layout > .header .header-title::after,
    #layout > div > .header .header-title::after { display: none; }
}

@media (max-width: 480px) {
    /* Inputs 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 drawer/overlay */
    #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.2);
    }

    /* 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 (so icones) */
    .toolbar a.button span.inner,
    .toolbar button.button span.inner { display: none; }

    /* Lista compacta */
    .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: 'Cormorant Garamond', 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; }
}
