/* ===============================
   LOVCHIK – PINK PSY STYLE
   Mobile-first / Adaptive
================================ */

/* ---------- VARIABLES ---------- */
:root {
    --pink-main: #ff5fa2;
    --pink-soft: #ff87c2;
    --pink-light: #ffe3f1;
    --pink-bg: #fff5fa;
    --pink-dark: #d63384;

    --text-main: #4a2b3b;
    --text-soft: #6f1d4d;

    --radius-lg: 24px;
    --radius-md: 16px;

    --shadow-soft: 0 20px 50px rgba(255, 105, 180, 0.25);
}

/* ---------- GLOBAL ---------- */
body {
    background: linear-gradient(135deg, var(--pink-light), var(--pink-bg));
    color: var(--text-main);
    font-family: 'Segoe UI', 'Inter', system-ui, -apple-system, sans-serif;
    line-height: 1.6;
}

/* ---------- CONTAINER ---------- */
.container {
    padding-left: 16px;
    padding-right: 16px;
}

/* ---------- HEADINGS ---------- */
h1, h2, h3, h4, h5 {
    color: var(--pink-dark);
    font-weight: 800;
    letter-spacing: -0.02em;
}

h1 {
    font-size: 1.9rem;
}

h2 {
    font-size: 1.6rem;
}

h3 {
    font-size: 1.35rem;
}

/* ---------- TEXT ---------- */
p {
    color: var(--text-soft);
    font-size: 1rem;
}

small {
    color: #8a4b6a;
}

/* ---------- CARDS ---------- */
.card {
    border-radius: var(--radius-lg);
    border: none;
    box-shadow: var(--shadow-soft);
    background: rgba(255, 255, 255, 0.96);
}

.card-body {
    padding: 24px;
}

/* ---------- FORMS ---------- */
.form-control {
    border-radius: var(--radius-md);
    padding: 12px 14px;
    border: 1px solid #ffd1e6;
    font-size: 1rem;
}

.form-control:focus {
    border-color: var(--pink-main);
    box-shadow: 0 0 0 0.15rem rgba(255, 95, 162, 0.25);
}

/* ---------- BUTTONS ---------- */
.btn {
    border-radius: var(--radius-md);
    font-weight: 600;
    padding: 12px 18px;
    font-size: 1rem;
}

/* Primary pink button */
.btn-primary,
.btn-pink {
    background: linear-gradient(135deg, var(--pink-main), var(--pink-soft));
    border: none;
    color: #fff;
}

.btn-primary:hover,
.btn-pink:hover {
    background: linear-gradient(135deg, #ff4b96, #ff76b8);
}

/* Secondary */
.btn-secondary {
    background: #ffe3f1;
    border: none;
    color: var(--pink-dark);
}

/* Disabled */
.btn:disabled {
    opacity: 0.6;
}

/* ---------- ALERTS ---------- */
.alert {
    border-radius: var(--radius-md);
    font-size: 0.95rem;
}

/* ---------- PROGRESS ---------- */
.progress {
    height: 18px;
    border-radius: 999px;
    background: #ffe3f1;
}

.progress-bar {
    background: linear-gradient(135deg, var(--pink-main), var(--pink-soft));
    font-weight: 600;
}

/* ---------- NAVBAR ---------- */
.navbar {
    background: rgba(255,255,255,0.95);
    box-shadow: 0 8px 20px rgba(255, 105, 180, 0.15);
}

.navbar-brand {
    font-weight: 800;
    color: var(--pink-dark);
}

.nav-link {
    color: var(--text-soft);
    font-weight: 600;
}

.nav-link:hover {
    color: var(--pink-main);
}

/* ---------- TABLES ---------- */
.table {
    background: #fff;
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.table thead {
    background: #ffe3f1;
}

.table th {
    color: var(--pink-dark);
    font-weight: 700;
}

/* ---------- ACHIEVEMENTS ---------- */
.achievement-card {
    position: relative;
    overflow: hidden;
}

.achievement-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top right, rgba(255, 95, 162, 0.15), transparent 60%);
}

/* ---------- TEST / LANDING ---------- */
.psychology-comment {
    background: #fff0f6;
    border-left: 4px solid var(--pink-main);
    padding: 14px 18px;
    border-radius: var(--radius-md);
    font-style: italic;
    color: #7a2b54;
}

/* ---------- FOOTER ---------- */
footer {
    color: #8a4b6a;
    font-size: 0.85rem;
    padding: 20px 0;
}

/* ---------- MOBILE OPTIMIZATION ---------- */
@media (max-width: 576px) {

    h1 { font-size: 1.6rem; }
    h2 { font-size: 1.4rem; }
    h3 { font-size: 1.2rem; }

    .card-body {
        padding: 20px;
    }

    .btn {
        width: 100%;
    }

    .table {
        font-size: 0.9rem;
    }

    .g-recaptcha {
        transform: scale(0.85);
        transform-origin: center;
    }
}

/* ---------- SMOOTH FEEL ---------- */
* {
    transition: background-color .25s ease, box-shadow .25s ease, transform .25s ease;
}
