/* ============================================================
   CON Conference Portal — portal.css
   Tailwind CDN is loaded on the page; this file adds
   custom components that Tailwind utility classes can't cover.
   ============================================================ */

/* ── Root tokens ──────────────────────────────────────────── */
:root {
    --con-navy:    #1a3a6b;
    --con-blue:    #2563eb;
    --con-light:   #dbeafe;
    --con-gold:    #f59e0b;
    --con-radius:  1rem;
}

/* ── Wrap ─────────────────────────────────────────────────── */
.con-portal-wrap {
    font-family: 'Inter', Arial, sans-serif;
    background: linear-gradient(135deg, #e8f0fe 0%, #f1f5f9 60%, #ede9fe 100%);
}

/* ── Form card ────────────────────────────────────────────── */
.con-form-card {
    border-radius: 1.5rem;
    box-shadow: 0 25px 60px -10px rgba(26, 58, 107, .18), 0 8px 20px -5px rgba(0, 0, 0, .06);
}

/* ── Banner / header strip ────────────────────────────────── */
.con-form-banner {
    background: linear-gradient(135deg, var(--con-navy) 0%, #1e4db7 55%, var(--con-blue) 100%);
    position: relative;
    overflow: hidden;
}
.con-form-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}

/* ── Crest circle ─────────────────────────────────────────── */
.con-crest-circle {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: rgba(255, 255, 255, .15);
    border: 2px solid rgba(255, 255, 255, .30);
    color: #fff;
}

/* ── Section headers ──────────────────────────────────────── */
.con-section-title {
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--con-navy);
    display: flex;
    align-items: center;
    gap: .6rem;
}
.con-step-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background: var(--con-navy);
    color: #fff;
    font-size: .8rem;
    font-weight: 800;
    flex-shrink: 0;
}

/* ── Fields grid ──────────────────────────────────────────── */
.con-fields-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
}

/* Full-width fields */
.con-field-group[data-field="province"],
.con-field-group[data-field="diocese"],
.con-field-group[data-field="office"] {
    grid-column: 1 / -1;
}

/* ── Province accordion ───────────────────────────────────── */
.con-province-accordion {
    border: 1px solid #e2e8f0;
    border-radius: .75rem;
    box-shadow: 0 10px 30px -5px rgba(0, 0, 0, .12);
    background: #fff;
    position: relative;
    z-index: 100;
}

.con-prov-header {
    cursor: pointer;
    user-select: none;
    transition: background .15s;
}
.con-prov-header:hover { background: #eff6ff; }

.con-prov-dioceses {
    /* slides open via JS .hidden toggle; add a subtle animation */
    animation: conSlideDown .18s ease-out;
}
@keyframes conSlideDown {
    from { opacity: 0; transform: translateY(-6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.con-diocese-btn {
    cursor: pointer;
    transition: background .12s, color .12s;
}
.con-diocese-btn:hover          { background: #eef2ff; color: #4338ca; }
.con-diocese-btn.selected,
.con-diocese-btn.bg-indigo-100  { background: #e0e7ff; color: #3730a3; font-weight: 600; }

/* ── Province trigger button ──────────────────────────────── */
.con-province-trigger {
    border-radius: .75rem;
    cursor: pointer;
    transition: border-color .15s;
}
.con-province-trigger:hover { border-color: var(--con-blue); }

/* ── Upload zone ──────────────────────────────────────────── */
.con-upload-zone {
    border: 2px dashed #cbd5e1;
    border-radius: .875rem;
    padding: 1rem 1.25rem;
    background: #f8fafc;
    transition: border-color .2s, background .2s;
}
.con-upload-zone:hover {
    border-color: var(--con-blue);
    background: #eff6ff;
}

/* ── Inputs ───────────────────────────────────────────────── */
.con-input,
.con-select {
    background: #fff;
    border: 1.5px solid #cbd5e1;
    border-radius: .75rem;
    padding: .75rem 1rem;
    font-size: .875rem;
    color: #1e293b;
    transition: border-color .15s, box-shadow .15s;
    width: 100%;
}
.con-input:focus,
.con-select:focus {
    outline: none;
    border-color: var(--con-blue);
    box-shadow: 0 0 0 3px rgba(37, 99, 235, .15);
}
.con-input::placeholder { color: #94a3b8; }

/* ── Submit button ────────────────────────────────────────── */
.con-submit-btn {
    background: linear-gradient(135deg, var(--con-navy) 0%, var(--con-blue) 100%);
    color: #fff;
    border: none;
    border-radius: 1rem;
    padding: 1rem 1.5rem;
    font-size: 1.125rem;
    font-weight: 700;
    cursor: pointer;
    transition: filter .2s, transform .1s;
    letter-spacing: .01em;
    width: 100%;
}
.con-submit-btn:hover  { filter: brightness(1.08); }
.con-submit-btn:active { transform: scale(.98); }
.con-submit-btn:disabled { filter: grayscale(.6); cursor: not-allowed; }

.con-submit-btn-sm {
    background: linear-gradient(135deg, var(--con-navy) 0%, var(--con-blue) 100%);
    color: #fff;
    border: none;
    border-radius: .6rem;
    padding: .4rem .85rem;
    font-size: .8rem;
    font-weight: 600;
    cursor: pointer;
    transition: filter .15s;
}
.con-submit-btn-sm:hover { filter: brightness(1.1); }

/* ── Delegate block ───────────────────────────────────────── */
.con-delegate-block {
    background: #f8fafc;
    border: 1.5px solid #e2e8f0;
    border-radius: 1.125rem;
    padding: 1.5rem;
    position: relative;
    transition: border-color .2s;
}
.con-delegate-block:hover { border-color: #bfdbfe; }

/* ── Response / status area ───────────────────────────────── */
#con-response { min-height: 0; transition: min-height .2s; }

/* ── Delegates list table ─────────────────────────────────── */
.con-table-head {
    background: linear-gradient(90deg, var(--con-navy) 0%, #1e4db7 100%);
    color: #fff;
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .06em;
}
.con-table-head th { padding: .75rem 1rem; font-weight: 600; }

/* ── Admin panel overrides ────────────────────────────────── */
.con-admin-wrap { max-width: 1100px; }

.con-admin-h1 {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--con-navy);
    margin-bottom: 1.2rem;
    display: flex;
    align-items: center;
    gap: .6rem;
}
.con-admin-version {
    font-size: .75rem;
    background: var(--con-light);
    color: var(--con-navy);
    border-radius: 999px;
    padding: .2rem .6rem;
    font-weight: 600;
}

.con-stat-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 1rem;
    margin: 1.2rem 0;
}
.con-stat-card {
    background: #fff;
    border-radius: .875rem;
    padding: 1.2rem 1.4rem;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.con-stat-num   { font-size: 2rem; font-weight: 800; line-height: 1; }
.con-stat-label { font-size: .75rem; color: #64748b; margin-top: .25rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }

.con-admin-card {
    background: #fff;
    border-radius: .875rem;
    padding: 1.25rem 1.5rem;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.con-admin-card-title { font-size: 1rem; font-weight: 700; color: var(--con-navy); margin-bottom: .75rem; }

.con-admin-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
    justify-content: space-between;
    margin: .75rem 0;
}
.con-admin-toolbar-form { display: flex; gap: .4rem; align-items: center; flex-wrap: wrap; }

.con-admin-table { border-radius: .75rem; overflow: hidden; }

/* ── Responsive tweaks ────────────────────────────────────── */
@media (max-width: 640px) {
    .con-form-banner { padding: 1.5rem 1.25rem; }
    .con-fields-grid { grid-template-columns: 1fr; }
    .con-submit-btn  { font-size: 1rem; }
}

/* ============================================================
   Landing Dashboard – Conference selection cards
   ============================================================ */

/* Card grid */
.con-landing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 1.5rem;
}

/* Individual card */
.con-conf-card {
    background: #fff;
    border-radius: 1.25rem;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
    border: 1.5px solid #e2e8f0;
    display: flex;
    flex-direction: column;
    transition: transform .2s, box-shadow .2s;
}
.con-conf-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(0, 0, 0, .14);
}
.con-conf-card--closed {
    opacity: .7;
    filter: grayscale(.4);
}
.con-conf-card--closed:hover {
    transform: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, .08);
}

/* Card banner (colored top strip) */
.con-conf-card-banner {
    padding: 2rem 1.5rem 1.5rem;
    text-align: center;
    position: relative;
}
.con-conf-card-banner::after {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23fff' fill-opacity='0.05'%3E%3Cpath d='M20 20h20v20H20zM0 0h20v20H0z'/%3E%3C/g%3E%3C/svg%3E");
    pointer-events: none;
}

/* Status badges */
.con-open-badge {
    display: inline-block;
    background: rgba(255,255,255,.2);
    color: #fff;
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: .25rem .75rem;
    border-radius: 999px;
    border: 1px solid rgba(255,255,255,.35);
}
.con-closed-badge {
    display: inline-block;
    background: rgba(0,0,0,.25);
    color: rgba(255,255,255,.8);
    font-size: .7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .08em;
    padding: .25rem .75rem;
    border-radius: 999px;
}

/* Card body */
.con-conf-card-body {
    padding: 1.25rem 1.5rem 1.5rem;
    display: flex;
    flex-direction: column;
    flex: 1;
}
.con-conf-card-title {
    font-size: 1.1rem;
    font-weight: 800;
    color: #1e293b;
    margin-bottom: .4rem;
}
.con-conf-theme {
    font-size: .8rem;
    color: #4f46e5;
    font-style: italic;
    margin-bottom: .75rem;
    line-height: 1.4;
}

/* Meta rows (dates, venue) */
.con-conf-meta {
    display: flex;
    flex-direction: column;
    gap: .3rem;
    margin-bottom: .75rem;
}
.con-conf-meta-row {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .8rem;
    color: #64748b;
}
.con-conf-meta-icon { font-size: .9rem; flex-shrink: 0; }

/* Description */
.con-conf-desc {
    font-size: .8rem;
    color: #64748b;
    line-height: 1.5;
    margin-bottom: 1rem;
    flex: 1;
}

/* Card footer (CTA button) */
.con-conf-card-footer { margin-top: auto; }

.con-conf-register-btn {
    display: block;
    text-align: center;
    background: linear-gradient(135deg, var(--con-navy) 0%, var(--con-blue) 100%);
    color: #fff;
    font-weight: 700;
    font-size: .875rem;
    padding: .75rem 1.25rem;
    border-radius: .875rem;
    text-decoration: none;
    transition: filter .2s, transform .1s;
    border: none;
    cursor: pointer;
    width: 100%;
}
.con-conf-register-btn:hover {
    filter: brightness(1.1);
    transform: translateY(-1px);
    color: #fff;
    text-decoration: none;
}
.con-conf-register-btn--disabled {
    background: #94a3b8;
    cursor: not-allowed;
    transform: none;
    filter: none;
}
.con-conf-register-btn--disabled:hover {
    filter: none;
    transform: none;
}

@media (max-width: 640px) {
    .con-landing-grid { grid-template-columns: 1fr; }
}
