/* ============================================
   ESTILOS GLOBAIS DO SISTEMA - TAILWIND CSS
   ============================================ */

/* Reset básico */
* {
    box-sizing: border-box;
}

html {
    height: 100%;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Componentes customizados - Botões */
.btn-primary {
    background-color: #2563eb;
    color: white;
    font-weight: 500;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
    outline: none;
}

.btn-primary:hover {
    background-color: #1d4ed8;
}

.btn-primary:focus {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

.btn-secondary {
    background-color: #4b5563;
    color: white;
    font-weight: 500;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
    outline: none;
}

.btn-secondary:hover {
    background-color: #374151;
}

.btn-secondary:focus {
    outline: 2px solid #6b7280;
    outline-offset: 2px;
}

.btn-success {
    background-color: #16a34a;
    color: white;
    font-weight: 500;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
    outline: none;
}

.btn-success:hover {
    background-color: #15803d;
}

.btn-success:focus {
    outline: 2px solid #22c55e;
    outline-offset: 2px;
}

.btn-danger {
    background-color: #dc2626;
    color: white;
    font-weight: 500;
    padding: 0.5rem 1rem;
    border-radius: 0.5rem;
    transition: background-color 0.2s;
    outline: none;
}

.btn-danger:hover {
    background-color: #b91c1c;
}

.btn-danger:focus {
    outline: 2px solid #ef4444;
    outline-offset: 2px;
}

/* Cards customizados */
.card {
    background-color: white;
    border-radius: 0.5rem;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
    padding: 1.5rem;
    transition: background-color 0.2s;
}

.dark .card {
    background-color: #1f2937;
}

/* Inputs customizados */
.input {
    width: 100%;
    padding: 0.5rem 1rem;
    border: 1px solid #d1d5db;
    border-radius: 0.5rem;
    outline: none;
    transition: all 0.2s;
}

.input:focus {
    border-color: transparent;
    box-shadow: 0 0 0 2px #3b82f6;
}

.dark .input {
    background-color: #374151;
    border-color: #4b5563;
    color: white;
}

/* Animações personalizadas */
.fade-in {
    animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}

/* ============================================
   ESTILOS PWA E MOBILE
   ============================================ */

/* Safe area para dispositivos com notch (iPhone X+) */
@supports (padding: max(0px)) {
    body {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }
    
    header {
        padding-left: env(safe-area-inset-left);
        padding-right: env(safe-area-inset-right);
    }
}

/* Modo standalone (app instalado) */
body.standalone-mode {
    /* Ajustes específicos para quando o app está instalado */
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    user-select: none;
}

body.standalone-mode header {
    /* Ajusta header para safe area em modo standalone */
    padding-top: env(safe-area-inset-top);
}

/* Melhorias de toque para mobile */
@media (hover: none) and (pointer: coarse) {
    /* Aumenta área de toque em dispositivos touch */
    button, a, input[type="button"], input[type="submit"] {
        min-height: 44px;
        min-width: 44px;
    }
    
    /* Melhora feedback visual em toques */
    button:active, a:active {
        opacity: 0.7;
        transform: scale(0.98);
    }
}

/* Previne zoom em inputs em iOS */
@media screen and (max-width: 768px) {
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    input[type="tel"],
    input[type="url"],
    textarea,
    select {
        font-size: 16px !important; /* Previne zoom automático no iOS */
    }
}

/* Melhorias de scroll suave */
html {
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
}

/* Ajustes para telas muito pequenas */
@media screen and (max-width: 320px) {
    .container {
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }
    
    h1 {
        font-size: 1.5rem !important;
    }
    
    h2 {
        font-size: 1.25rem !important;
    }
}

/* Ajustes para tablets em modo retrato */
@media screen and (min-width: 768px) and (max-width: 1024px) and (orientation: portrait) {
    .container {
        max-width: 100%;
        padding: 1rem;
    }
}

/* Previne seleção de texto em elementos interativos (mobile) */
@media (hover: none) and (pointer: coarse) {
    button, a {
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0.1);
    }
}

/* Melhorias de acessibilidade para navegação por teclado */
*:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* Ajustes para modo escuro em PWA */
@media (prefers-color-scheme: dark) {
    body:not(.dark) {
        /* Aplica dark mode automático se o sistema estiver em dark mode */
    }
}

/* Estilos para banner de instalação PWA */
#installBanner {
    position: relative;
    z-index: 1000;
    animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
    from {
        transform: translateY(-100%);
        opacity: 0;
    }
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

/* Melhorias de performance para animações */
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* Ajustes para impressão */
@media print {
    header,
    footer,
    #installBanner,
    .no-print {
        display: none !important;
    }
    
    body {
        background: white !important;
        color: black !important;
    }
}