body{
font-family:Arial, Helvetica, sans-serif;
margin:0;
padding:15px;
background:#1e1e1e;
color:#fff;
}

/* top bar */
.topbar{
text-align:center;
font-size:20px;
margin-bottom:15px;
}

/* search */
#search{
width:100%;
padding:10px;
margin-bottom:20px;
border-radius:8px;
border:none;
font-size:16px;
}

/* categories */
h2{
margin-top:25px;
border-bottom:1px solid #444;
padding-bottom:5px;
}

/* grid */
.grid{
display:grid;
grid-template-columns:repeat(auto-fill,minmax(250px,1fr));
gap:15px;
}

/* card */
.card{
background:#2b2b2b;
padding:15px;
border-radius:10px;
}

/* title */
.place{
font-weight:bold;
margin-bottom:10px;
}

/* buttons */
.row{
display:flex;
gap:10px;
margin-top:10px;
}

.btn{
flex:1;
text-align:center;
padding:8px;
border-radius:6px;
background:#27ae60;
color:#fff;
text-decoration:none;
font-size:14px;
}

.map{
background:#2980b9;
}

/* ===== FOOTER ===== */
.footer{
width:100%;
display:flex;
justify-content:center;
margin-top:40px;
}

.footer-inner{
text-align:center;
font-size:13px;
opacity:0.7;
}

.footer-text{
margin-bottom:6px;
}

.admin-icon{
font-size:20px;
cursor:pointer;
display:block;
}

/* ===== MODAL ===== */
.modal{
display:none;
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.7);
justify-content:center;
align-items:center;
z-index:999;
}

.modal-box{
background:#fff;
color:#333;
padding:25px;
border-radius:10px;
width:90%;
max-width:320px;
text-align:center;
position:relative;
}

.modal-box input{
width:100%;
padding:10px;
margin:10px 0;
border-radius:6px;
border:1px solid #ccc;
}

.close{
position:absolute;
top:10px;
right:15px;
cursor:pointer;
font-size:18px;
}