*,
*::before,
*::after{
box-sizing:border-box;
}

html{
scroll-behavior:smooth;
}

body{
font-family:"Vazirmatn",sans-serif;
background:#0f2b23;
color:#f5e9c8;
margin:0;
line-height:1.6;
}

.renew {
position: absolute;
top: 0;
width: 100%;
height: 100%;
background-color: #0f2b23;
z-index: 2;
text-align: center;
padding-top: 40vh;
}
.renew h2 {
margin-bottom: 5px;
}

/* header */
header{
text-align:center;
padding:20px 10px;
}

h1{
margin:0;
font-size:32px;
}

h2{
margin-top:40px;
font-size:24px;
border-bottom:1px solid #d4b46a;
padding-bottom:6px;
}

/* category navigation */

.category-nav{
position:sticky;
top:0;
background:#0f2b23;
overflow-x:auto;
white-space:nowrap;
padding:10px;
border-bottom:1px solid #d4b46a;
-webkit-overflow-scrolling:touch;
scroll-behavior:smooth;
}

.category-nav a{
display:inline-block;
color:#f5e9c8;
padding:8px 16px;
text-decoration:none;
border:1px solid #d4b46a;
border-radius:20px;
margin-left:8px;
font-size:15px;
transition:0.2s;
}

.category-nav a:hover{
background:#d4b46a;
color:#0f2b23;
}

/* menu container */

.menu{
max-width:900px;
margin:auto;
padding:10px;
}

.menu-section{
scroll-margin-top:70px;
}

/* menu items */

.menu-item{
display:flex;
justify-content:space-between;
align-items:center;
gap:12px;
background:#13352c;
padding:12px;
margin-top:10px;
border-radius:8px;
border:1px solid #d4b46a;
}

.menu-item-name{
font-size:18px;
flex:1;
}

.item-price,
.menu-item-price{
font-weight:bold;
white-space:nowrap;
}

/* prevent overflow */

.menu-item,
.menu-item-name,
.item-price,
.menu-item-price{
min-width:0;
overflow-wrap:anywhere;
}

/* mobile optimization */

@media (max-width:768px){

h1{
font-size:26px;
}

h2{
font-size:20px;
}

.category-nav{
display:flex;
gap:10px;
padding:10px;
}

.category-nav a{
flex:0 0 auto;
padding:10px 16px;
font-size:14px;
}

.category-nav a.active{
background:#d4b46a;
color:#0f2b23;
font-weight:bold;
}

.menu{
padding:10px;
}

.menu-item{
flex-direction:column;
align-items:flex-start;
gap:6px;
}

.menu-item-name{
font-size:16px;
}

.item-price,
.menu-item-price{
font-size:16px;
}

}

/* very small phones */

@media (max-width:420px){

h1{
font-size:22px;
}

.menu-item-name{
font-size:15px;
}

.item-price,
.menu-item-price{
font-size:15px;
}

}

/* admin panel */

.admin-page{
padding:20px 12px 40px;
}

.admin-container{
max-width:1000px;
margin:auto;
display:grid;
gap:20px;
}

.admin-form-card,
.admin-list-card,
.admin-category{
background:#13352c;
border:1px solid #d4b46a;
border-radius:16px;
box-shadow:0 8px 24px rgba(0,0,0,0.18);
}

.admin-form-card,
.admin-list-card{
padding:18px;
}

.admin-form-card h2,
.admin-list-card h2{
margin-top:0;
}

.admin-form-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:14px;
margin-top:14px;
}

.admin-field{
display:flex;
flex-direction:column;
gap:8px;
}

.admin-field label{
font-size:14px;
color:#d8c79a;
}

.admin-field input,
.admin-field select{
width:100%;
background:#0f2b23;
color:#f5e9c8;
border:1px solid #d4b46a;
border-radius:10px;
padding:12px 14px;
font-family:inherit;
font-size:15px;
outline:none;
transition:border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.admin-field input::placeholder{
color:#cdbf99;
}

.admin-field input:focus,
.admin-field select:focus{
border-color:#e6c97a;
box-shadow:0 0 0 3px rgba(212,180,106,0.18);
}

.admin-actions{
display:flex;
gap:10px;
flex-wrap:wrap;
margin-top:18px;
}

.admin-btn{
appearance:none;
border:none;
border-radius:10px;
padding:11px 18px;
font-family:inherit;
font-size:15px;
font-weight:700;
cursor:pointer;
transition:transform 0.15s, opacity 0.2s, background 0.2s, color 0.2s;
}

.admin-btn:hover{
transform:translateY(-1px);
}

.admin-btn:active{
transform:translateY(0);
}

.admin-btn-primary{
background:#d4b46a;
color:#0f2b23;
}

.admin-btn-secondary{
background:transparent;
color:#f5e9c8;
border:1px solid #d4b46a;
}

.admin-btn-danger{
background:#8f2f2f;
color:#fff4e8;
}

.admin-items{
display:grid;
gap:18px;
margin-top:14px;
}

.admin-category{
padding:16px;
}

.admin-category-title{
margin:0 0 12px;
font-size:20px;
border-bottom:1px solid rgba(212,180,106,0.45);
padding-bottom:8px;
}

.admin-category-items{
display:grid;
gap:10px;
}

.admin-item{
display:flex;
justify-content:space-between;
align-items:center;
gap:12px;
padding:12px;
border:1px solid rgba(212,180,106,0.55);
border-radius:12px;
background:#0f2b23;
}

.admin-item-content{
display:flex;
flex-direction:column;
gap:4px;
min-width:0;
flex:1;
}

.admin-item-name{
font-size:17px;
font-weight:700;
overflow-wrap:anywhere;
}

.admin-item-price{
font-size:15px;
color:#d8c79a;
}

.admin-item-actions{
flex:0 0 auto;
}

.admin-empty{
padding:12px;
border:1px dashed rgba(212,180,106,0.5);
border-radius:10px;
color:#d8c79a;
text-align:center;
}

@media (max-width:768px){

.admin-page{
padding:14px 10px 30px;
}

.admin-form-card,
.admin-list-card,
.admin-category{
border-radius:14px;
}

.admin-form-grid{
grid-template-columns:1fr;
}

.admin-actions{
flex-direction:column;
}

.admin-btn{
width:100%;
}

.admin-item{
flex-direction:column;
align-items:flex-start;
}

.admin-item-actions{
width:100%;
}

.admin-item-actions .admin-btn{
width:100%;
}

.admin-category-title{
font-size:18px;
}

.admin-item-name{
font-size:16px;
}

.admin-item-price{
font-size:14px;
}

}

.admin-edit-input{
width:100%;
background:#0f2b23;
color:#f5e9c8;
border:1px solid #d4b46a;
border-radius:8px;
padding:8px 10px;
font-family:inherit;
margin-bottom:6px;
}

@media (max-width:420px){

.admin-form-card,
.admin-list-card,
.admin-category{
padding:14px;
}

.admin-field input,
.admin-field select{
font-size:14px;
padding:11px 12px;
}

.admin-btn{
font-size:14px;
padding:10px 14px;
}

}