/* ============================================================
   Monday.com-inspired Design System
   Cadastro de Lojas — Grupo Burguês
   ============================================================ */

:root {
    /* -------- Marca: Grupo Burguês (âmbar/laranja quente) -------- */
    --brand:         #e8821e;   /* destaque/realce (ícones sobre soft)        */
    --brand-strong:  #c45d12;   /* AÇÃO: botões/links (contraste ok c/ branco) */
    --brand-hover:   #a94e0f;
    --brand-soft:    #fff3e2;   /* preenchimentos suaves (radio/badge/banner) */
    --brand-focus:   rgba(232, 130, 30, 0.20);
    --brand-grad:    linear-gradient(135deg, #f59e0b 0%, #ea580c 100%); /* faixas/header */

    --bg-app:           #faf7f3;
    --bg-card:          #ffffff;
    --bg-icon-soft:     var(--brand-soft);
    --bg-info-soft:     #fff8e7;

    --border:           #ece6df;
    --border-input:     #ddd5cc;
    --border-strong:    #c9bfb3;

    --text-primary:     #2b2622;
    --text-secondary:   #6f675f;
    --text-placeholder: #a89f95;

    /* Tokens funcionais repontados para a marca: botões, foco, radios e
       selects herdam o âmbar sem precisar reescrever cada componente. */
    --primary:          var(--brand-strong);
    --primary-hover:    var(--brand-hover);
    --primary-focus:    var(--brand-focus);
    --primary-soft:     var(--brand-soft);

    --danger:           #d83a52;
    --danger-soft:      rgba(216, 58, 82, 0.12);
    --warning:          #fdab3d;

    --shadow-card:      0 1px 2px rgba(43, 38, 34, 0.05), 0 6px 16px rgba(43, 38, 34, 0.06);
    --shadow-card-hover:0 2px 6px rgba(43, 38, 34, 0.07), 0 12px 28px rgba(43, 38, 34, 0.10);

    --radius-card:      16px;
    --radius-input:     10px;
    --radius-pill:      999px;

    --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-display: 'Plus Jakarta Sans', var(--font);
}

/* -------- Base -------- */
* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font);
    background:
        radial-gradient(1100px 500px at 50% -10%, rgba(245, 158, 11, 0.10), transparent 60%),
        var(--bg-app);
    background-attachment: fixed;
    color: var(--text-primary);
    font-size: 15px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-height: 100vh;
}

/* -------- Layout containers -------- */
.app-shell {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
}

.form-shell {
    max-width: 880px;
    margin: 0 auto;
    padding: 40px 20px 60px;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* -------- Entrada suave dos cards -------- */
@keyframes fade-up {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* -------- Cards -------- */
.card-monday {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-card);
    box-shadow: var(--shadow-card);
    padding: 32px;
    animation: fade-up 0.45s cubic-bezier(0.22, 1, 0.36, 1) both;
}

.card-monday + .card-monday {
    margin-top: 0;
}

/* Faixa de marca no topo dos cards de destaque (login + header). */
.login-card,
.header-card {
    position: relative;
    overflow: hidden;
}

.login-card::before,
.header-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 5px;
    background: var(--brand-grad);
}

/* -------- Login card -------- */
.login-card {
    width: 100%;
    max-width: 440px;
    padding: 44px 40px 40px;
    text-align: center;
}

.login-card .icon-wrap { margin: 0 auto 24px; }

.login-card h1 {
    font-family: var(--font-display);
    font-size: 30px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.02em;
    margin: 0 0 8px;
}

/* -------- Wordmark (kicker da marca acima do título) -------- */
.brand-kicker {
    font-family: var(--font-display);
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--brand-strong);
    margin: 0 0 6px;
}

.login-card .subtitle {
    color: var(--text-secondary);
    font-size: 15px;
    margin: 0 0 32px;
}

.login-card form { text-align: left; }

/* -------- Header card (formulário) -------- */
.header-card {
    display: flex;
    align-items: center;
    gap: 20px;
}

.header-card .icon-wrap { flex-shrink: 0; }

.header-card h1 {
    font-family: var(--font-display);
    font-size: 24px;
    font-weight: 700;
    color: var(--text-primary);
    letter-spacing: -0.02em;
    margin: 0 0 4px;
}

.header-card p {
    color: var(--text-secondary);
    font-size: 14px;
    margin: 0;
}

/* -------- Store icon (circle wrapper) -------- */
.icon-wrap {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: var(--brand-grad);
    box-shadow: 0 6px 16px rgba(234, 88, 12, 0.28);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.icon-wrap svg {
    width: 30px;
    height: 30px;
    color: #fff;
}

/* -------- Section card -------- */
.section-card .section-head {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
}

.section-badge {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--primary-soft);
    color: var(--primary);
    font-weight: 600;
    font-size: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: -0.01em;
}

.section-title {
    font-family: var(--font-display);
    font-size: 16px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
    letter-spacing: -0.015em;
}

/* -------- Info banner (CNPJ warning) -------- */
.info-banner {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-left: 4px solid var(--brand);
    border-radius: var(--radius-card);
    padding: 18px 22px;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    box-shadow: var(--shadow-card);
}

.info-banner .info-icon {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    color: var(--brand);
    margin-top: 1px;
}

.info-banner .info-text {
    color: var(--text-primary);
    font-size: 14px;
    line-height: 1.5;
}

.info-banner .info-text strong { font-weight: 600; }

/* -------- Form fields -------- */
.field { margin-bottom: 18px; }
.field:last-child { margin-bottom: 0; }

.form-label,
label.form-label {
    display: block;
    font-weight: 500;
    font-size: 13px;
    color: var(--text-secondary);
    margin-bottom: 8px;
    letter-spacing: 0;
}

.form-control,
.form-select,
input.form-control,
select.form-select,
textarea.form-control {
    width: 100%;
    border: 1px solid var(--border-input);
    border-radius: var(--radius-input);
    padding: 12px 14px;
    font-size: 14px;
    font-family: var(--font);
    color: var(--text-primary);
    background-color: var(--bg-card);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    line-height: 1.4;
    appearance: none;
    -webkit-appearance: none;
}

.form-control:hover,
.form-select:hover { border-color: var(--border-strong); }

.form-control:focus,
.form-select:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 4px var(--primary-focus);
    outline: 0;
    background-color: var(--bg-card);
}

.form-control::placeholder { color: var(--text-placeholder); }

/* Select chevron */
.form-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23676879'%3E%3Cpath d='M4.22 6.22a.75.75 0 0 1 1.06 0L8 8.94l2.72-2.72a.75.75 0 1 1 1.06 1.06l-3.25 3.25a.75.75 0 0 1-1.06 0L4.22 7.28a.75.75 0 0 1 0-1.06z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
    background-size: 16px;
    padding-right: 40px;
}

/* Invalid state — subtle */
.form-control.is-invalid,
.form-select.is-invalid {
    border-color: var(--danger);
    box-shadow: 0 0 0 4px var(--danger-soft);
}

.invalid-feedback {
    display: none;
    font-size: 12.5px;
    color: var(--danger);
    margin-top: 6px;
    font-weight: 500;
}

.form-control.is-invalid ~ .invalid-feedback,
.form-select.is-invalid ~ .invalid-feedback { display: block; }

/* -------- Grid (lightweight, no Bootstrap required) -------- */
.row {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 18px;
}

.col-12 { grid-column: span 12; }
.col-8  { grid-column: span 8; }
.col-6  { grid-column: span 6; }
.col-5  { grid-column: span 5; }
.col-4  { grid-column: span 4; }
.col-3  { grid-column: span 3; }

@media (max-width: 720px) {
    .col-8, .col-6, .col-5, .col-4, .col-3 { grid-column: span 12; }
    .card-monday { padding: 24px; }
    .header-card { flex-direction: column; align-items: flex-start; text-align: left; }
    .form-shell { padding: 24px 14px 48px; }
}

/* -------- Loja-select card (alteração) -------- */
.loja-select-card[hidden] { display: none !important; }

.loja-select-card .loja-select-hint {
    color: var(--text-secondary);
    font-size: 13.5px;
    margin: -8px 0 18px;
}

/* -------- Importar planilha card (cadastro) -------- */
.importar-card[hidden] { display: none !important; }

.importar-card .importar-hint {
    color: var(--text-secondary);
    font-size: 13.5px;
    margin: -8px 0 18px;
}

.importar-controls {
    display: flex;
    gap: 12px;
    align-items: stretch;
}

.importar-file-wrap {
    flex: 1;
    cursor: pointer;
    display: block;
}

.importar-file-label {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 11px 14px;
    border: 1px dashed var(--border-input);
    border-radius: var(--radius-input);
    background: var(--bg-app);
    transition: border-color 0.18s ease, background-color 0.18s ease;
    min-height: 48px;
}

.importar-file-wrap:hover .importar-file-label {
    border-color: var(--primary);
    background: var(--primary-soft);
}

.importar-file-name {
    flex: 1;
    font-size: 13.5px;
    color: var(--text-secondary);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.importar-file-cta {
    flex-shrink: 0;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--primary);
    background: var(--bg-card);
    border: 1px solid var(--border-input);
    border-radius: 8px;
    padding: 6px 12px;
}

.importar-controls .importar-btn {
    width: auto;
    flex: 0 0 auto;
    padding: 12px 22px;
    font-size: 14px;
}

.importar-controls .importar-btn:disabled {
    opacity: 0.6;
    cursor: progress;
}

.importar-status {
    margin: 14px 0 0;
    font-size: 13.5px;
    min-height: 1.2em;
    color: var(--text-secondary);
}

.importar-status.ok      { color: #1f9d5b; font-weight: 500; }
.importar-status.error   { color: var(--danger); font-weight: 500; }
.importar-status.loading { color: var(--text-secondary); }

@media (max-width: 720px) {
    .importar-controls { flex-direction: column; }
    .importar-btn { width: 100%; }
}

/* -------- Radio cards (Monday-style) -------- */
.radio-group {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
}

@media (max-width: 720px) {
    .radio-group { grid-template-columns: 1fr; }
}

.radio-card {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 16px 18px;
    border: 1px solid var(--border-input);
    border-radius: var(--radius-input);
    background: var(--bg-card);
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, background-color 0.18s ease;
    user-select: none;
}

.radio-card:hover { border-color: var(--border-strong); }

.radio-card input[type="radio"] {
    position: absolute;
    opacity: 0;
    pointer-events: none;
}

.radio-indicator {
    flex-shrink: 0;
    width: 18px;
    height: 18px;
    border: 2px solid var(--border-strong);
    border-radius: 50%;
    background: var(--bg-card);
    margin-top: 2px;
    transition: border-color 0.18s ease, background-color 0.18s ease;
    display: inline-block;
    position: relative;
}

.radio-card input[type="radio"]:checked ~ .radio-indicator {
    border-color: var(--primary);
}

.radio-card input[type="radio"]:checked ~ .radio-indicator::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--primary);
    transform: translate(-50%, -50%);
}

.radio-card:has(input[type="radio"]:checked) {
    border-color: var(--primary);
    background: var(--primary-soft);
    box-shadow: 0 0 0 4px var(--primary-focus);
}

.radio-card input[type="radio"]:focus-visible ~ .radio-indicator {
    box-shadow: 0 0 0 4px var(--primary-focus);
}

.radio-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    line-height: 1.35;
}

.radio-title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 14px;
    color: var(--text-primary);
}

.radio-desc {
    font-size: 12.5px;
    color: var(--text-secondary);
}

/* -------- Buttons -------- */
.btn-primary-monday {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: var(--brand-grad);
    color: #fff;
    border: none;
    border-radius: var(--radius-input);
    padding: 14px 18px;
    font-size: 15px;
    font-weight: 600;
    font-family: var(--font);
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(234, 88, 12, 0.24);
    transition: filter 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
    letter-spacing: 0;
}

.btn-primary-monday:hover {
    filter: brightness(1.05) saturate(1.05);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(234, 88, 12, 0.32);
}

.btn-primary-monday:active { transform: translateY(0); }

/* Travado: enquanto o usuário não marcar "Li e concordo" o botão fica cinza
   e sem interação (cursor proibido, sem hover/transform). */
.btn-primary-monday:disabled,
.btn-primary-monday[disabled] {
    background: #cbd5e1;
    color: #f1f5f9;
    cursor: not-allowed;
    box-shadow: none;
    filter: none;
    transform: none;
    pointer-events: none;
}

.btn-primary-monday:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 4px var(--primary-focus);
}

.submit-wrap {
    display: flex;
    justify-content: flex-end;
    margin-top: 4px;
}

.submit-wrap .btn-primary-monday {
    width: auto;
    min-width: 220px;
    padding: 14px 28px;
}

@media (max-width: 720px) {
    .submit-wrap .btn-primary-monday { width: 100%; }
}
