:root{
    --blue:#102a56;
    --blue2:#173f7a;
    --gold:#f4c542;
    --earth:#8a5a3b;
    --light:#f8fafc;
    --text:#1f2937;
}

*{
    box-sizing:border-box;
}

body{
    margin:0;
    font-family:Inter,Arial,sans-serif;
    color:var(--text);
    background:#fff;
}

a{
    text-decoration:none;
    color:inherit;
}

.container{
    max-width:1180px;
    margin:auto;
    padding:0 20px;
}

.site-header{
    position:sticky;
    top:0;
    z-index:20;
    background:rgba(255,255,255,.95);
    border-bottom:1px solid #e5e7eb;
    backdrop-filter:blur(12px);
}

.nav-wrap{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:16px 20px;
}

.brand{
    display:flex;
    align-items:center;
    gap:12px;
    color:var(--blue);
}

.brand small{
    display:block;
    color:#777;
    font-size:12px;
}

.logo{
    background:var(--blue);
    color:var(--gold);
    width:46px;
    height:46px;
    display:grid;
    place-items:center;
    border-radius:16px;
    font-size:24px;
}

/* =========================
   NAVIGATION
========================= */

.main-nav{
    display:flex;
    gap:22px;
    align-items:center;
    font-weight:700;
    font-size:14px;
}

.main-nav a{
    position:relative;
    color:var(--text);
    transition:.3s;
}

.main-nav a:hover{
    color:#16a34a !important;
}

.main-nav a.active{
    color:#16a34a !important;
    font-weight:900;
}

.main-nav a.active::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-8px;
    width:100%;
    height:3px;
    background:#16a34a;
    border-radius:999px;
}

.donate,
.btn{
    background:var(--gold);
    color:var(--blue)!important;
    border-radius:999px;
    padding:12px 20px;
    font-weight:900;
    display:inline-block;
    border:0;
    cursor:pointer;
    transition:.3s;
}

.btn:hover{
    transform:translateY(-2px);
}

.btn.blue{
    background:var(--blue);
    color:#fff!important;
}

.small-btn{
    padding:10px 16px !important;
    font-size:13px;
    border-radius:12px !important;
    font-weight:800;
    width:180px;
    text-align:center;
    display:flex;
    align-items:center;
    justify-content:center;
}

.delete-btn{
    background:#dc2626 !important;
    color:#fff !important;
}

.delete-btn:hover{
    background:#b91c1c !important;
}

.admin-sermon-actions{
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:10px;
    margin-top:20px;
}

.dropdown{
    position:relative;
}

.dropdown-menu{
    display:none;
    position:absolute;
    right:0;
    top:25px;
    background:#fff;
    border:1px solid #ddd;
    border-radius:18px;
    box-shadow:0 16px 40px rgba(0,0,0,.12);
    padding:10px;
    width:240px;
}

.dropdown:hover .dropdown-menu{
    display:block;
}

.dropdown-menu a{
    display:block;
    padding:12px;
    border-radius:12px;
}

.dropdown-menu a:hover{
    background:#eef4ff;
}

.mobile-menu{
    display:none;
}

.hero{
    background:linear-gradient(135deg,#0d2248,#173f7a,#241a15);
    color:#fff;
    padding:90px 0;
}

.hero-grid{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:50px;
    align-items:center;
}

.badge{
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.2);
    border-radius:999px;
    padding:9px 15px;
    color:var(--gold);
    display:inline-block;
    font-weight:800;
}

.hero h1{
    font-size:58px;
    line-height:1.03;
    margin:22px 0;
}

.hero p{
    font-size:18px;
    line-height:1.8;
    color:#eaf1ff;
}

.hero-card{
    background:rgba(255,255,255,.12);
    padding:18px;
    border-radius:32px;
}

.church-img{
    height:420px;
    border-radius:24px;
    background:url('/uploads/images/hero/church_building.jpg');
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    display:block;
    overflow:hidden;
    cursor:pointer;
    transition:.3s;
}

.church-img:hover{
    outline:4px solid var(--gold);
    outline-offset:4px;
}

.section{
    padding:78px 0;
}

.section.alt{
    background:#f4f7fb;
}

.title{
    text-align:center;
    max-width:760px;
    margin:0 auto 45px;
}

.title span{
    color:#b88700;
    font-weight:900;
    letter-spacing:.22em;
    text-transform:uppercase;
    font-size:13px;
}

.title h2{
    font-size:42px;
    color:var(--blue);
    margin:12px 0;
}

.title p{
    font-size:17px;
    line-height:1.7;
    color:#64748b;
}

.grid{
    display:grid;
    gap:24px;
}

.grid-3{
    grid-template-columns:repeat(3,1fr);
}

.grid-4{
    grid-template-columns:repeat(4,1fr);
}

.card{
    background:red;
    border:1px solid #e5e7eb;
    border-radius:28px;
    padding:28px;
    box-shadow:0 10px 30px rgba(15,23,42,.06);
}

.card h3{
    color:var(--blue);
    margin-top:0;
}

.icon{
    width:54px;
    height:54px;
    border-radius:18px;
    background:#fff5cc;
    display:grid;
    place-items:center;
    font-size:26px;
    margin-bottom:18px;
}

.sermon-video{
    height:180px;
    border-radius:22px;
    background:linear-gradient(135deg,var(--blue),#111827);
    display:grid;
    place-items:center;
    color:var(--gold);
    font-size:50px;
    margin:-10px -10px 20px;
    overflow:hidden;
}

.sermon-notes{
    margin-top:20px;
    padding-top:15px;
    border-top:1px solid #e5e7eb;
    color:#374151;
    font-size:15px;
    line-height:1.7;
    max-height:260px;
    overflow-y:auto;
}

.sermon-notes::-webkit-scrollbar{
    width:6px;
}

.sermon-notes::-webkit-scrollbar-thumb{
    background:#cbd5e1;
    border-radius:999px;
}

.card video{
    width:100%;
    border-radius:16px;
    margin-top:15px;
}

.card audio{
    width:100%;
    margin-top:15px;
}

.form{
    display:grid;
    gap:15px;
}

.form input,
.form textarea,
.form select{
    width:100%;
    border:1px solid #d1d5db;
    border-radius:16px;
    padding:14px;
    font-size:15px;
}

.form textarea{
    min-height:140px;
}

.notice{
    padding:14px 18px;
    border-radius:14px;
    margin-bottom:18px;
    background:#ecfdf5;
    color:#065f46;
    font-weight:700;
}

.error{
    background:#fef2f2;
    color:#991b1b;
}

.footer{
    background:#0f172a;
    color:#fff;
    padding:32px 0;
}

.footer a{
    color:var(--gold);
}

.footer-grid{
    display:flex;
    justify-content:space-between;
    gap:20px;
}

.admin-wrap{
    max-width:1000px;
    margin:auto;
}

/* =========================
   ADMIN TABLE FIX
========================= */

.admin-wrap .card{
    overflow-x:auto;
}



.admin-wrap .table td,
.admin-wrap .table th{
    vertical-align:middle;
}

.table{
    width:100%;
    border-collapse:collapse;
    background:#fff;
    border-radius:18px;
    overflow:hidden;
}

.table th,
.table td{
    padding:14px;
    border-bottom:1px solid #eee;
    text-align:left;
}

.admin-menu{
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    margin-bottom:24px;
}

.admin-menu a{
    background:#eef4ff;
    color:var(--blue);
    padding:12px 16px;
    border-radius:999px;
    font-weight:800;
}

.gallery-box{
    height:170px;
    border-radius:24px;
    background:linear-gradient(135deg,#dbeafe,#fef3c7);
    display:grid;
    place-items:center;
    font-size:44px;
}

.upload-sermon-card{
    padding:42px;
}

.upload-sermon-card h1{
    margin-top:0;
    color:var(--blue);
    font-size:38px;
}

.upload-help{
    color:#64748b;
    line-height:1.7;
    margin-bottom:28px;
}

.upload-sermon-form label{
    font-weight:800;
    color:var(--blue);
    margin-top:8px;
}

.upload-sermon-form textarea{
    min-height:190px;
    line-height:1.7;
}

.upload-btn{
    width:100%;
    margin-top:10px;
    font-size:16px;
}

@media(max-width:900px){

    .main-nav{
        display:none;
    }

    .mobile-menu{
        display:block;
        background:none;
        border:0;
        font-size:28px;
    }

    .menu-open .main-nav{
        display:grid;
        position:absolute;
        left:0;
        right:0;
        top:79px;
        background:#fff;
        padding:20px;
        border-bottom:1px solid #ddd;
    }

    .hero-grid,
    .grid-3,
    .grid-4{
        grid-template-columns:1fr;
    }

    .hero h1{
        font-size:40px;
    }

    .footer-grid{
        flex-direction:column;
    }

    .dropdown-menu{
        position:static;
        box-shadow:none;
        width:100%;
        border:0;
    }

    .sermon-card{
        display:flex;
        flex-direction:column;
    }

    .sermon-audio-player{
        width:100%;
        margin:15px 0;
        border-radius:12px;
    }
	
	.admin-inline-form{
    display:flex;
    gap:10px;
    align-items:center;
}

.permission-box{
    display:grid;
    gap:8px;
}

.permission-option{
    display:flex;
    align-items:center;
    gap:8px;
    font-size:13px;
    font-weight:700;
    color:var(--blue);
}

.permission-option input{
    width:auto;
}

.permission-box .small-btn{
    margin-top:8px;
}
	/* =========================
   PAGE PERMISSION CHECKBOXES
========================= */

.permission-box{
    display:grid;
    grid-template-columns:repeat(2, minmax(120px, 1fr));
    gap:8px 12px;
    max-width:320px;
}

.permission-option{
    display:flex;
    align-items:center;
    gap:6px;
    font-size:13px;
    font-weight:700;
    color:var(--blue);
    line-height:1.2;
}

.permission-option input{
    width:16px !important;
    height:16px;
    margin:0;
    flex-shrink:0;
}

.permission-box .small-btn{
    grid-column:1 / -1;
    width:100%;
    margin-top:8px;
}

.admin-users-table th:nth-child(4),
.admin-users-table td:nth-child(4){
    width:260px;
}
	
	.permission-grid{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:10px 14px !important;
    min-width:320px !important;
}

.permission-grid .permission-option{
    display:flex !important;
    align-items:center !important;
    gap:8px !important;
    white-space:nowrap !important;
}

.permission-grid .permission-option input{
    width:16px !important;
    height:16px !important;
    flex:0 0 16px !important;
}

.permission-grid .small-btn{
    grid-column:1 / -1 !important;
    width:100% !important;
}
}