/* =========================================================
   CanCham Cambodia
   Contact Page
   File: /assets/pages/contact.css
   ========================================================= */

.page-contact {

    --contact-bg: #f4f7fb;
    --contact-surface: #ffffff;
    --contact-surface-soft: #f8fbff;

    --contact-text: #142033;
    --contact-text-muted: #5c6b82;

    --contact-heading: #0d1b2a;

    --contact-border: rgba(20,32,51,0.1);

    --contact-primary: #0f4c81;
    --contact-secondary: #1d6fa3;

    --contact-shadow-sm: 0 6px 16px rgba(12,28,52,0.05);
    --contact-shadow-md: 0 10px 24px rgba(12,28,52,0.08);

    --contact-radius-md: 10px;
    --contact-radius-lg: 14px;

    --contact-max-width: 1240px;

    background:
        radial-gradient(circle at top left, rgba(15,76,129,0.05), transparent 32%),
        radial-gradient(circle at right 10% top 10%, rgba(29,111,163,0.04), transparent 24%),
        linear-gradient(180deg,#f7faff 0%,#f4f7fb 100%);

    color: var(--contact-text);
}

.page-contact .site-shell {

    width: min(100% - 2rem, var(--contact-max-width));
    margin-inline: auto;

}


/* =========================================================
   Layout
   ========================================================= */

.contact-shell {

    padding: 2rem 0 4rem;

}

.contact-heading {

    margin-bottom: 1.75rem;

}

.contact-layout {

    display: grid;
    grid-template-columns: minmax(300px,0.9fr) minmax(0,1.1fr);
    gap: 1.5rem;
    align-items: start;

}


/* =========================================================
   Left Panel
   ========================================================= */

.contact-panel {

    display: grid;
    gap: 1rem;

}

.contact-panel__block {

    padding: 1.25rem;

    border-radius: var(--contact-radius-lg);

    background:
        linear-gradient(180deg,#ffffff,#f8fbff);

    border: 1px solid var(--contact-border);

    box-shadow: var(--contact-shadow-sm);

}

.contact-panel__title {

    margin: 0 0 .9rem;

    font-size: 1.05rem;

    color: var(--contact-heading);

}


/* =========================================================
   Contact Info Cards
   ========================================================= */

.contact-info-grid {

    display: grid;
    gap: .8rem;

}

.contact-info-card {

    padding: .9rem 1rem;

    border-radius: 10px;

    background: #fff;

    border: 1px solid rgba(15,76,129,0.08);

}

.contact-info-card__label {

    margin: 0 0 .35rem;

    font-size: .72rem;

    font-weight: 800;

    letter-spacing: .08em;

    text-transform: uppercase;

    color: var(--contact-text-muted);

}

.contact-info-card__value {

    margin: 0;

    font-weight: 700;

    font-size: .97rem;

    color: var(--contact-heading);

}

.contact-info-card__value a {

    color: var(--contact-primary);
    text-decoration: none;

}

.contact-info-card__value a:hover {

    color: var(--contact-secondary);

}


/* =========================================================
   Topic List
   ========================================================= */

.contact-note-list {

    display: grid;
    gap: .7rem;

    margin: 0;
    padding: 0;
    list-style: none;

}

.contact-note-list__item {

    position: relative;

    padding-left: 1.6rem;

    line-height: 1.65;

}

.contact-note-list__item::before {

    content: "";

    position: absolute;

    left: 0;
    top: .6rem;

    width: .55rem;
    height: .55rem;

    border-radius: 50%;

    background:
        linear-gradient(135deg,var(--contact-primary),var(--contact-secondary));

    box-shadow: 0 0 0 3px rgba(15,76,129,0.08);

}


/* =========================================================
   Form Card
   ========================================================= */

.contact-form-card {

    padding: 1.35rem;

    border-radius: var(--contact-radius-lg);

    background:
        linear-gradient(180deg,#ffffff,#f8fbff);

    border: 1px solid var(--contact-border);

    box-shadow: var(--contact-shadow-md);

}

.contact-form-card__header {

    margin-bottom: 1.1rem;

}

.contact-form-card__title {

    margin: 0;

    font-size: 1.45rem;

    color: var(--contact-heading);

}

.contact-form-card__intro {

    margin: .6rem 0 0;

    color: var(--contact-text-muted);

    font-size: .95rem;

}


/* =========================================================
   Form Grid
   ========================================================= */

.contact-form {

    display: grid;
    gap: 1rem;

}

.contact-form__grid {

    display: grid;

    grid-template-columns: 1fr 1fr;

    gap: .95rem;

}

.form-field {

    display: grid;

    gap: .4rem;

}

.form-field--full {

    grid-column: 1 / -1;

}

.form-field label {

    font-size: .88rem;

    font-weight: 700;

}

.form-field input,
.form-field select,
.form-field textarea {

    width: 100%;

    padding: .8rem .9rem;

    border-radius: 8px;

    border: 1px solid var(--contact-border);

    font: inherit;

    color: var(--contact-text);

    background: #fff;

    transition:
        border-color .2s ease,
        box-shadow .2s ease;

}

.form-field textarea {

    min-height: 10rem;

    resize: vertical;

}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {

    outline: none;

    border-color: rgba(15,76,129,0.45);

    box-shadow: 0 0 0 4px rgba(15,76,129,0.08);

}


/* =========================================================
   Form Footer
   ========================================================= */

.contact-form__footer {

    display: flex;

    justify-content: space-between;

    align-items: center;

    gap: 1rem;

}

.contact-form__note {

    margin: 0;

    font-size: .9rem;

    color: var(--contact-text-muted);

}

.contact-form__note a {

    color: var(--contact-primary);

    text-decoration: none;

    font-weight: 700;

}


/* =========================================================
   Responsive
   ========================================================= */

@media (max-width: 980px) {

    .contact-layout {

        grid-template-columns: 1fr;

    }

}

@media (max-width: 760px) {

    .contact-form__grid {

        grid-template-columns: 1fr;

    }

    .contact-form__footer {

        flex-direction: column;

        align-items: stretch;

    }

}