/* ==== Unified form/card styling for dashboard pages ====
   Используется в create_project.html, profile_page.html и других страницах
   с формами. Токены берутся из style.css (--bg-elevated, --border, --text-1,
   --accent, --r-md/lg, --font). Префикс cp- сохранён по истории (create project),
   но применим ко ВСЕМ страницам с карточками форм. */

.cp-page {
    max-width: 860px;
    margin: 0 auto;
    padding: 4px 2px 32px;
    font-family: var(--font);
    color: var(--text-1);
}
.cp-header {
    display: flex; align-items: center; justify-content: space-between;
    gap: 12px; margin-bottom: 14px;
}
.cp-title { font-size: 15px; font-weight: 600; color: var(--text-1); margin: 0; }
.cp-selector {
    width: 280px; max-width: 100%; height: 34px;
    padding: 0 12px; font-size: 13px; font-family: var(--font);
    background: var(--bg-input); color: var(--text-1);
    border: 1px solid var(--border); border-radius: var(--r-md);
    cursor: pointer;
}
.cp-card {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 18px 18px 16px;
    margin-bottom: 14px;
}
.cp-section-head { margin: 0 0 12px; }
.cp-section-title {
    font-size: 13px; font-weight: 600; color: var(--text-1);
    margin: 0; letter-spacing: 0;
}
.cp-section-desc {
    font-size: 12px; color: var(--text-2); margin: 4px 0 0; line-height: 1.5;
}
.cp-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 10px 14px;
}
.cp-grid--3 { grid-template-columns: 1.3fr 1fr 1fr; }
.cp-field { display: flex; flex-direction: column; min-width: 0; }
.cp-field--full { margin-top: 10px; grid-column: 1 / -1; }
.cp-field--ac { position: relative; }
.cp-label {
    font-size: 11px; font-weight: 500; color: var(--text-2);
    margin-bottom: 4px; letter-spacing: 0;
}
.cp-req { color: var(--accent); font-weight: 600; }
.cp-input {
    width: 100%; padding: 7px 10px; height: 34px;
    box-sizing: border-box;
    background: var(--bg-input); color: var(--text-1);
    border: 1px solid var(--border); border-radius: var(--r-md);
    font: 13px/1.35 var(--font); outline: none;
    transition: border-color .15s ease, background .15s ease;
}
.cp-input::placeholder { color: var(--text-3); }
.cp-input:hover { border-color: var(--border-hover, #3a3a40); }
.cp-input:focus { border-color: var(--accent); background: var(--bg-input); }
.cp-textarea { height: auto; min-height: 70px; padding: 8px 10px; resize: vertical; line-height: 1.45; }
.cp-hidden { display: none; }
.cp-divider {
    height: 1px; background: var(--border);
    margin: 18px -18px 14px;
}

/* Actions / buttons */
.cp-actions {
    display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 12px;
}
.cp-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    height: 34px; padding: 0 14px;
    font: 500 13px/1 var(--font);
    border-radius: var(--r-md); border: 1px solid var(--border);
    cursor: pointer; user-select: none;
    transition: background .15s ease, opacity .15s ease, border-color .15s ease;
    color: var(--text-1); background: transparent;
}
.cp-btn--primary {
    background: var(--accent); color: var(--accent-text, #ffffff);
    border-color: transparent; font-weight: 600;
}
.cp-btn--primary:hover { opacity: .92; }
.cp-btn--primary:disabled { opacity: .55; cursor: default; }
.cp-btn--ghost {
    background: var(--bg-input); color: var(--text-1);
    border-color: var(--border);
}
.cp-btn--ghost:hover { background: var(--bg-hover); }
.cp-btn--lg { height: 38px; padding: 0 22px; font-size: 14px; }
.cp-status { font-size: 12px; color: var(--text-2); }
.cp-status.is-error { color: var(--danger); }
.cp-status.is-ok { color: var(--accent); }
.cp-footer {
    display: flex; gap: 12px; align-items: center;
    margin-top: 18px; padding-top: 14px;
    border-top: 1px solid var(--border);
}

/* Mobile: single column */
@media (max-width: 640px) {
    .cp-grid, .cp-grid--3 { grid-template-columns: 1fr; }
    .cp-header { flex-direction: column; align-items: stretch; }
    .cp-selector { width: 100%; }
}
