:root {
    --pm-orange: #ed7024;
    --pm-orange-dark: #d45e10;
    --pm-ink: #1a1a1a;
    --pm-muted: #64748b;
    --pm-border: #e2e8f0;
}

* { box-sizing: border-box; }

body {
    font-family: "Source Sans 3", -apple-system, Segoe UI, Roboto, sans-serif;
    margin: 0;
    padding: 0;
    color: #475569;
    background: #ed7024;
    min-height: 100vh;
}

.wrap {
    max-width: 760px;
    margin: 0 auto;
    padding: 24px 16px 60px;
}

.brand {
    text-align: center;
    padding: 24px 0 12px;
}
.brand img { width: 220px; max-width: 70%; height: auto; }

.card {
    background: #fff;
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 25px 50px -12px rgba(0,0,0,0.25);
}
.card h1 {
    margin: 0 0 6px;
    color: var(--pm-ink);
    font-size: 24px;
}
.card .intro {
    margin: 0 0 20px;
    color: var(--pm-muted);
    font-size: 15px;
}

.form-section-title {
    color: var(--pm-orange);
    font-size: 15px;
    font-weight: 600;
    margin: 24px 0 8px;
    border-bottom: 1px solid #f1f5f9;
    padding-bottom: 6px;
}
.form-section-title:first-of-type { margin-top: 8px; }
.section-hint { font-size: 12px; color: #94a3b8; font-weight: 400; }

.flex { display: flex; }
.wrapf { flex-wrap: wrap; }
.gap { gap: 12px; }
.s-100 { width: 100%; }
.s-50 { flex: 1 1 calc(50% - 12px); min-width: 200px; }
.s-33 { flex: 1 1 calc(33% - 12px); min-width: 160px; }

label {
    display: block;
    font-size: 13px;
    color: #475569;
    font-weight: 600;
    margin-bottom: 4px;
}
input, select, textarea {
    width: 100%;
    padding: 11px 12px;
    border: 1px solid var(--pm-border);
    border-radius: 8px;
    font-size: 15px;
    font-family: inherit;
    background: #fff;
    color: var(--pm-ink);
}
input:focus, select:focus, textarea:focus {
    border-color: var(--pm-orange);
    outline: none;
}
input[readonly] {
    background: #f8fafc;
    color: var(--pm-muted);
    cursor: not-allowed;
}
.field { margin-bottom: 6px; }

.actions {
    margin-top: 28px;
    display: flex;
    justify-content: flex-end;
}
.btn-save {
    background: var(--pm-orange);
    color: #fff;
    border: none;
    padding: 14px 36px;
    border-radius: 10px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    transition: background .2s;
}
.btn-save:hover { background: var(--pm-orange-dark); }
.btn-save:disabled { opacity: .6; cursor: default; }

.note {
    background: #fff7ed;
    border: 1px solid var(--pm-orange);
    color: #9a3412;
    border-radius: 10px;
    padding: 12px 14px;
    font-size: 13px;
    margin-bottom: 18px;
}

/* Pantalla de estado (error / éxito) */
.state {
    text-align: center;
    padding: 40px 24px;
}
.state .icon { font-size: 56px; margin-bottom: 12px; }
.state h2 { color: var(--pm-ink); margin: 0 0 8px; }
.state p { color: var(--pm-muted); margin: 0; }

.footer {
    text-align: center;
    color: rgba(255,255,255,0.9);
    font-size: 13px;
    margin-top: 20px;
}
