/*color vars*/
:root {
  --brand: #242e69;
  --brand-dark: #1f234f;                
  --brand-light: #6a6a88;               
  --brand-accent: #d2cec3;              
  --bg: #f7faff;                        
  --ink: #0b1a3d;
  --border: #cfdffe; 
                   
}
body {
  background-image: url('/uploads/menu/webBackground.jpeg') !important;
  /* adjust the path */
  background-size: cover !important;
  /* makes it fill the screen */
  background-repeat: no-repeat !important;
  /* prevents tiling */
  background-attachment: fixed !important;
  /* makes it stay still when scrolling */
  background-position: center !important;
  /* centers the image */
  margin: 0 !important;
  font-family: Arial, sans-serif !important;
  text-decoration: none !important;
}
@media (max-width:768px) {
  body {
    overflow-y: auto;
  }
}
/* Gradient background for booking & location boxes */
.res_div {
    background: linear-gradient(135deg, #242e69, #d2cec3) !important;
    color: #0b1a3d;
}

/* Optional: make text easy to read */
.res_div h5 {
    color: #ffffff;
}

.res_div label,
.res_div p {
    color: #f0f0f0;
}

/* Hero Section (Specials) */
.index_hero {
  background: linear-gradient(135deg, var(--brand-accent), #fff);
  border: 1px solid var(--border);
  border-radius: 1rem;
  color: var(--ink);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

/* Index Images*/
.index_img{
  min-height: 220px;
  max-height: 220px;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
}
/* Index Footer */
footer {
  background-color: var(--brand-dark);
  color: #ffffff;
}
footer h6 {
  color: #ffffff;
}
footer a {
  color: var(--brand-accent);
}

/* Buttons */
button, .btn {
  background-color: var(--brand);
  color: #fff;
  border: 1px solid var(--brand-dark);
  border-radius: 999px;
  padding: 0.5rem 1.2rem;
  transition: background-color 0.2s ease;
}
button:hover, .btn:hover {
  background-color: var(--brand-dark);
}

/* Pills*/
.index_pill {
  background: #fff;
  border: 1px solid var(--brand-accent);
  border-radius: 999px;
  padding: 0.5rem 1rem;
  color: var(--ink);
  font-weight: 500;
}

/* Cards */
.index_card {
  background: #d2cec3;
  border: 1px solid var(--border);
  border-radius: 1rem;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
}
.index_card h3 {
  color: var(--brand-dark);
}
.index_card {
    border-radius: 1rem;
    border: none;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

/* Login and Register */
.reg-body body{
  overflow-y: hidden;
  justify-content: center;
}
.containers{
  justify-content: center;
  max-width: 350px;
  margin: 4vh auto;
  background: linear-gradient(135deg, #d2cec3 , #242e69);
  padding: 14px 16px;
  border-radius: 12px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  color: #ffffff;
  background-color: var(--brand);
  font-size: 90%;
}

.login-container, .reset-container {
  justify-content: center;
  max-width: 350px;
  min-width: 350px;
  margin: 14vh auto;
  background: linear-gradient(135deg, #d2cec3 , #242e69);
  padding: 28px 16px;
  border-radius: 12px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
  color: #ffffff;
  background-color: var(--brand);
}

input[type="text"],
input[type="email"],
input[type="password"]{
  width: 95%;
  height: 10px;
  padding: 10px;
  margin-bottom: 1.5vh;
  border: 1px solid #d2cec3;
  border-radius: 6px;
}

.login-container .signup-link,
.reset-container .signup-link {
  display: block;
  text-align: center;
  margin-top: 1rem;
  color: #d2cec3;
  text-decoration: none;
  font-size: 0.95rem;
}

.login-container .signup-link:hover,
.reset-container .signup-link:hover{
  color: #ffffff;
}

.login-container button:hover {
  background: #2f64d6;
  color: #fff;
}

.login-container h2,
.containers h2,
.reset-container h2 {
  text-align: center;
  margin-bottom: 0.5rem;
  color: #fff;
}
.login-container label,
.containers label {
  color: #ffffff;
}
.login-container button,
.containers button,
.reset-container button {
  justify-content: center;
  width: 100%;
  height: 40px;
  background: #d2cec3;
  color: #242e69;
  border: none;
  border-radius: 6px;
  font-size: 1rem;
  cursor: pointer;
  transition: background 0.2s ease;
}
.containers button:hover{
  background: #2f64d6;
  color: #fff;
}
.login-container input[type="text"], 
.login-container input[type="password"],
.reset-container input {
  width: 100%;
  height: 100%;
}
#password-requirements {
  display: none;
  font-size: xx-small;
  color: #f0f0f0;
  margin-bottom: 10px;
}
#password-feedback,
#confirm-feedback {
  font-size: 12px;
  margin-bottom: 10px;
}
.error {
  color: #ff6b6b;
  text-align: center;
  margin-bottom: 10px;
}
.login-link {
  text-align: center;
  margin-top: 16px;
  font-size: 14px;
}

.login-link a {
  color: #d2cec3;
  text-decoration: none;
}

.login-link a:hover {
  color: #ffffff;
}

/*Menu Items & Filter*/
.filter-card {
  position: sticky;
  top: 1rem
}
.menu-thumb {
  width: 100%;
  height: 160px;
  object-fit: cover;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem
}
.menu-card {
  border-radius: 1rem
}
.menu-item {
  transition: transform 0.2s
}
.menu-item:hover {
  transform: translateY(-2px)
}
.price-missing {
  color: #dc3545;
  font-style: italic
}
.veg-badge {
  background: #28a745;
  color: white;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.7em
}
.spice-badge {
  background: #ffc107;
  color: #000;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.7em
}
.spice-hot {
  background: #dc3545;
  color: white
}

/*Admin Customers*/
.customer-container, 
.stats-container, 
.menu-container,
.reservation-container,
.admin-orders-container{
  background: rgba(255, 255, 255, 0.85);
  padding: 2rem;
  border-radius: 1rem;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
  margin-top: 2rem;
}
.customer-container h2,
.stats-container h2,
.menu-container h2,
.reservation-container h2,
.admin-orders-container h2{
  color: var(--brand-dark);
  margin-bottom: 1.5rem !important;
}
.alert-warning {
  border-radius: 1rem;
  background: var(--brand-accent);
  color: var(--brand-dark);
}
.form-control:focus,
.form-select:focus {
  border-color: var(--brand-dark);
  box-shadow: 0 0 0 0.2rem rgba(36, 46, 105, 0.25);
}
.customer-card {
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--brand), var(--brand-light), var(--brand-accent));
  color: #fff;
  border: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.customer-card input.form-control {
  border-radius: 6px;
  border: 1px solid #d2cec3;
}
.customer-card button {
  max-height: 95%;
  border-radius: 6px;
  border: none;
  background: var(--brand-accent);
  color: var(--brand-dark);
  transition: background 0.2s ease, color 0.2s ease;
}
.customer-card button:hover {
  background: var(--brand-light);
  color: #fff;
}
.customer-table {
  background: rgba(255, 255, 255, 0.95);
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.customer-table thead,
.admin-menu thead {
  background: var(--brand);
  color: #fff;
}
.customer-table th,
.customer-table td,
.stats-table td,
.stats-table th,
.admin-menu th,
.admin-menu td {
  vertical-align: middle !important;
}
.customer-table tbody tr:nth-child(even), 
.admin-menu tbody tr:nth-child(even) {
  background: rgba(46, 78, 182, 0.05);
}

/*Admin Stats*/
.stats-card {
  border-radius: 1rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.stats-card .h4,
.stats-card .h6 {
  color: var(--brand);
}
.stats-table th{
  color:var(--brand-dark);
}

/*Admin Menu*/
.admin-menu {
  max-height: 765px;
  /* adjust as needed */
  max-width: 950px;
  overflow-y: auto;
  /* vertical scroll inside table */
  overflow-x: auto;
  /* horizontal scroll if needed */
}
.admin-menu-card{
  border-radius: 1rem;
	background: linear-gradient(135deg, var(--brand), var(--brand-light), var(--brand-accent));
	color: #fff;
  border: none;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  width: 103%;
}
.admin-menu-section .admin-menu-card{
  max-height: 840px;
}
.admin-menu-card input.form-control,
.admin-menu-card select.form-select,
.admin-menu-card textarea.form-control {
  border-radius: 6px;
  border: 1px solid var(--brand-accent);
}
.admin-menu-card button,
.admin-menu-card a.btn {
  border-radius: 6px;
  border: none;
  background: var(--brand-accent);
  color: var(--brand-dark);
  transition: background 0.2s ease, color 0.2s ease;
}
.admin-menu-card button:hover,
.admin-menu-card a.btn:hover {
  background: var(--brand-light);
  color: #fff;
}
.admin-menu-card img{
  border-radius: 6px;
}
.admin-menu table{
  background: rgba(255, 255, 255, 0.95);
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  min-width: 800px;
}
.menu-alert {
  border-radius: 1rem;
}

/*Admin Reservations*/
.res-card,
.order-card {
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--brand), var(--brand-light), var(--brand-accent));
  color: #fff;
  border: none;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.res-card select.form-select,
.res-card button,
.order-card select.form-select,
.order-card button {
  border-radius: 6px;
  border: none;
  transition: background 0.2s ease, color 0.2s ease;
}
.res-card select.form-select,
.order-card select.form-select {
  background: #fff;
  color: var(--brand-dark);
}
.res-card button,
.order-card button {
  background: var(--brand-accent);
  color: var(--brand-dark);
}
.res-card button:disabled,
.order-card button:disabled {
  opacity: 0.6;
}
.res-card button:hover:not(:disabled),
.order-card button:hover:not(:disabled) {
  background: var(--brand-light);
  color: #fff;
}
.res-badge,
.order-badge {
text-transform: uppercase;
font-size: 0.75rem;
}
#lastSync {
  font-weight: 400;
}

/*Forgot Password*/

.reset-container input {
  width: 100%;
  margin-bottom: 1rem;
  padding: 10px;
}
#forgot-password{
  display: flex;
  justify-content: center;
  align-items: center;
}
