/* File: assets/css/style.css - TEMA FAMILY GATHERING */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root {
    --cl-primary: #FF6B6B;      /* Coral pink hangat */
    --cl-secondary: #4ECDC4;    /* Turquoise lembut */
    --cl-accent: #45B7D1;       /* Biru langit cerah */
    --cl-warm: #FFE66D;         /* Kuning hangat */
    --cl-soft: #96CEB4;         /* Hijau mint lembut */
    --cl-text: #2C3E50;         /* Dark blue untuk teks */
    --cl-light: #F8F9FA;        /* Off-white */
    --cl-border: rgba(255, 107, 107, 0.2); /* Border coral transparan */
    /* Backward compatibility */
    --cl-dark-blue: #2C3E50;
    --cl-mid-blue: #FF6B6B;
    --cl-light-blue: #4ECDC4;
    --cl-silver: #FFFFFF;
    --cl-grey: #7F8C8D;
}

body {
    font-family: 'Poppins', sans-serif;
    background: linear-gradient(135deg, #FFFBF0 0%, #FFF8E7 25%, #F0FFF0 50%, #F5F5DC 75%, #FDF5E6 100%);
    background-image: 
        radial-gradient(circle at 15% 25%, rgba(255, 182, 193, 0.15) 0%, transparent 40%),
        radial-gradient(circle at 85% 75%, rgba(152, 251, 152, 0.15) 0%, transparent 40%),
        radial-gradient(circle at 50% 10%, rgba(255, 239, 213, 0.2) 0%, transparent 30%),
        url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="120" height="120" viewBox="0 0 120 120"><circle fill="%23FFB6C1" fill-opacity=".04" cx="30" cy="30" r="8"/><circle fill="%2398FB98" fill-opacity=".04" cx="90" cy="90" r="6"/><circle fill="%23FFEFD5" fill-opacity=".05" cx="60" cy="20" r="4"/><circle fill="%23F0E68C" fill-opacity=".03" cx="20" cy="80" r="5"/></svg>');
    color: var(--cl-text);
    line-height: 1.7;
    min-height: 100vh;
}

/* === Card & Form Styling === */
.card-form {
    background: linear-gradient(145deg, rgba(255, 255, 255, 0.95) 0%, rgba(248, 249, 250, 0.9) 100%);
    border: 2px solid var(--cl-border);
    border-radius: 20px;
    backdrop-filter: blur(15px);
    box-shadow: 0 15px 35px rgba(255, 107, 107, 0.1), 0 5px 15px rgba(78, 205, 196, 0.1);
}

/* === Form Elements === */
.form-label {
    font-weight: 600;
    color: var(--cl-text);
    margin-bottom: 8px;
}

.form-control, .form-select,
.select2-container--bootstrap-5 .select2-selection {
    background-color: rgba(255, 255, 255, 0.9) !important;
    color: var(--cl-text) !important;
    border: 2px solid var(--cl-border) !important;
    border-radius: 15px;
    transition: all 0.3s ease;
    padding: 12px 18px;
    font-size: 1rem;
}

.form-control:focus, .form-select:focus,
.select2-container--bootstrap-5.select2-container--open .select2-selection {
    border-color: var(--cl-primary) !important;
    box-shadow: 0 0 0 4px rgba(255, 107, 107, 0.2) !important;
    background-color: #FFFFFF !important;
    transform: translateY(-1px);
}

/* === Buttons === */
.btn-submit, .btn-primary {
    background: linear-gradient(135deg, var(--cl-primary) 0%, var(--cl-secondary) 100%);
    border: none;
    color: #FFFFFF;
    font-weight: 600;
    border-radius: 30px;
    text-transform: none;
    transition: all 0.4s ease;
    padding: 14px 35px;
    font-size: 1.1rem;
    box-shadow: 0 8px 20px rgba(255, 107, 107, 0.3);
}

.btn-submit:hover, .btn-primary:hover {
    background: linear-gradient(135deg, var(--cl-secondary) 0%, var(--cl-accent) 100%);
    transform: translateY(-4px) scale(1.02);
    box-shadow: 0 12px 30px rgba(78, 205, 196, 0.4);
    color: #FFFFFF;
}

/* === Navbar Admin === */
.navbar {
    background: linear-gradient(135deg, var(--cl-dark-blue) 0%, var(--cl-mid-blue) 100%) !important;
    backdrop-filter: blur(10px);
    border-bottom: 2px solid var(--cl-light-blue);
    box-shadow: 0 2px 10px rgba(26, 35, 126, 0.2);
}
.navbar .nav-link.active {
    color: #FFFFFF !important;
    font-weight: 700 !important;
}
.navbar .nav-link {
    color: var(--cl-grey);
    font-weight: 500;
}
.navbar .nav-link:hover {
    color: #FFFFFF;
}

/* === DataTables Styling === */
.table { --bs-table-color: var(--cl-dark-blue); --bs-table-bg: rgba(255, 255, 255, 0.8); --bs-table-border-color: var(--cl-border); --bs-table-striped-color: var(--cl-dark-blue); --bs-table-striped-bg: rgba(66, 165, 245, 0.05); --bs-table-hover-color: var(--cl-dark-blue); --bs-table-hover-bg: rgba(66, 165, 245, 0.1); }
.dataTables_wrapper { color: var(--cl-grey); }
.dataTables_wrapper .form-control, .dataTables_wrapper .form-select { background-color: #FFFFFF !important; color: var(--cl-dark-blue) !important; }
.page-item.active .page-link { background-color: var(--cl-light-blue); border-color: var(--cl-light-blue); }
.page-link { background-color: #FFFFFF; border-color: var(--cl-border); color: var(--cl-dark-blue); }
.page-link:hover { background-color: var(--cl-light-blue); color: #fff; border-color: var(--cl-light-blue); }

/* === RSVP Form Specifics === */
.guest-entry {
    background: linear-gradient(145deg, rgba(255, 107, 107, 0.03) 0%, rgba(78, 205, 196, 0.03) 100%);
    border: 2px solid rgba(255, 107, 107, 0.1);
    margin-top: 2rem !important;
    padding: 2rem !important;
    border-radius: 20px;
    position: relative;
    overflow: hidden;
}
.guest-entry::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--cl-primary), var(--cl-secondary), var(--cl-warm));
}
.guest-entry h5 {
    color: var(--cl-primary);
    font-weight: 600;
    margin-bottom: 1.5rem;
}

/* Modal Styling */
.modal-content.bg-dark {
    background-color: #FFFFFF !important;
    border: 2px solid var(--cl-light-blue);
    color: var(--cl-dark-blue) !important;
}