@import "https://unpkg.com/open-props";

/* Base (light mode) */
:root {
  --bg-main: var(--blue-0);
  --bg-panel: var(--gray-0);
  --text-main: var(--gray-9);
  --text-secondary: var(--gray-7);
  --border-main: var(--gray-4);
  --button-bg: var(--blue-6);
  --button-hover: var(--blue-7);
  --flash-error-bg: var(--red-1);
  --flash-error-border: var(--red-4);
  --flash-error-text: var(--red-9);
  --flash-success-bg: var(--green-1);
  --flash-success-border: var(--green-4);
  --flash-success-text: var(--green-9);
}

/* Dark mode override */
@media (prefers-color-scheme: dark) {
  :root {
    --bg-main: #46464b; /* very dark, almost black */
    --bg-panel: #343436; /* dark grayish-blue */
    --text-main: #ffffff; /* light gray */
    --text-secondary: #b0b0b0; /* medium gray */
    --border-main: #4c4cc7; /* darker border */
    --button-bg: #3b82f6; /* pastel blue but darker */
    --button-hover: #2563eb; /* deeper blue on hover */
    --flash-error-bg: #5a1e1e; /* dark red bg */
    --flash-error-border: #7f2a2a;
    --flash-error-text: #fca5a5; /* pastel red text */
    --flash-success-bg: #164e36; /* dark green bg */
    --flash-success-border: #1e6b48;
    --flash-success-text: #a7f3d0; /* pastel green text */
  }
}

/* Reset */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

body {
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background-color: var(--bg-main);
  color: var(--text-main);
  line-height: var(--font-lineheight-3);
  padding: var(--size-6);
}

/* Headings */
h1, h2 {
  color: var(--button-bg);
  margin-bottom: var(--size-4);
}

/* Nav */
nav {
  background-color: var(--bg-panel);
  padding: var(--size-3) var(--size-4);
  margin-bottom: var(--size-5);
  border-radius: var(--radius-3);
  box-shadow: 0 0 10px rgba(0 0 0 / 0.4);
}

nav a {
  color: var(--button-bg);
  text-decoration: none;
  margin-right: var(--size-4);
  font-weight: 500;
  font-size: var(--font-size-2);
}

nav a:hover {
  text-decoration: underline;
}

/* Flash messages */
.flash {
  padding: var(--size-3) var(--size-4);
  margin-bottom: var(--size-4);
  border-radius: var(--radius-2);
  font-weight: 600;
  box-shadow: 0 0 8px rgba(0 0 0 / 0.4);
}

.flash.error {
  background-color: var(--flash-error-bg);
  color: var(--flash-error-text);
  border: 1px solid var(--flash-error-border);
}

.flash.success {
  background-color: var(--flash-success-bg);
  color: var(--flash-success-text);
  border: 1px solid var(--flash-success-border);
}

/* Forms */
form {
  max-width: 500px;
  margin-bottom: var(--size-5);
  padding: var(--size-4);
  background-color: var(--bg-panel);
  border-radius: var(--radius-3);
  box-shadow: 0 0 10px rgba(0 0 0 / 0.3);
}

input[type="text"],
input[type="email"],
input[type="password"] {
  width: 100%;
  padding: var(--size-2) var(--size-3);
  margin-bottom: var(--size-3);
  border: 1px solid var(--border-main);
  border-radius: var(--radius-2);
  font-size: var(--font-size-2);
  background-color: var(--bg-main);
  color: var(--text-main);
}

input:focus {
  border-color: var(--button-bg);
  outline: none;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.7);
}

/* Buttons */
button {
  background-color: var(--button-bg);
  color: white;
  border: none;
  padding: var(--size-2) var(--size-5);
  font-size: var(--font-size-2);
  border-radius: var(--radius-2);
  cursor: pointer;
  transition: background-color 0.3s ease, transform 0.1s ease;
  box-shadow: 0 4px 6px rgba(0 0 0 / 0.3);
}

button:hover,
button:focus {
  background-color: var(--button-hover);
  transform: translateY(-1px);
  outline: none;
}

/* Lists */
ul {
  list-style: none;
  padding-left: 0;
  margin-bottom: var(--size-5);
}

li {
  background-color: var(--bg-panel);
  padding: var(--size-3);
  margin-bottom: var(--size-2);
  border-radius: var(--radius-2);
  box-shadow: 0 4px 8px rgba(0 0 0 / 0.15);
  border: 1px solid var(--border-main);
  color: var(--text-main);
}

/* Visitor Counter */
#visitor-count {
  font-weight: bold;
  color: var(--button-bg);
  font-size: var(--font-size-3);
}

/* Chat Box */
#chat-box {
  border: 1px solid var(--border-main);
  border-radius: var(--radius-3);
  padding: var(--size-4);
  height: 300px;
  overflow-y: auto;
  background-color: var(--bg-panel);
  margin-bottom: var(--size-4);
  box-shadow: 0 0 12px rgba(0 0 0 / 0.35);
}

#chat-box p {
  margin-bottom: var(--size-2);
  padding: var(--size-2);
  background-color: var(--bg-main);
  border-radius: var(--radius-2);
  box-shadow: 0 2px 4px rgba(0 0 0 / 0.15);
  color: var(--text-main);
}

/* Chat Input */
#chat-form {
  display: flex;
  gap: var(--size-2);
}

#chat-form input[type="text"] {
  flex: 1;
  background-color: var(--bg-main);
  color: var(--text-main);
  border: 1px solid var(--border-main);
}

/* Pong Canvas */
#pong {
  display: block;
  margin: var(--size-6) auto;
  border: 2px solid var(--button-bg);
  border-radius: var(--radius-2);
  background-color: var(--bg-panel);
  box-shadow: 0 0 15px rgba(0 0 0 / 0.4);
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--size-5);
  background-color: var(--bg-panel);
  box-shadow: 0 0 10px rgba(0 0 0 / 0.3);
  border-radius: var(--radius-2);
  overflow: hidden;
}

th, td {
  padding: var(--size-3);
  text-align: left;
  border-bottom: 1px solid var(--border-main);
  color: var(--text-main);
}

th {
  background-color: #2a4a8a; /* deeper blue */
  color: white;
}

td {
  background-color: var(--bg-main);
  color: var(--text-main);
}


/* ------------------------------ */
/* Products / Product Cards       */
/* ------------------------------ */
.product-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--size-4);
  justify-content: flex-start;
}

.product-card {
  background-color: var(--bg-panel);
  border: 1px solid var(--border-main);
  border-radius: var(--radius-3);
  padding: var(--size-4);
  width: 220px; /* slightly bigger */
  box-shadow: 0 6px 12px rgba(0 0 0 / 0.2);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.product-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 18px rgba(0 0 0 / 0.25);
}

.product-image {
  width: 100%;
  height: 150px;
  object-fit: cover;
  border-radius: var(--radius-2);
  margin-bottom: var(--size-3);
}

.quantity-input {
  width: 60px;
  margin-right: var(--size-2);
  padding: var(--size-1);
  border-radius: var(--radius-2);
  border: 1px solid var(--border-main);
  background-color: var(--bg-main);
  color: var(--text-main);
}

.add-cart-btn, .delete-btn {
  margin-top: var(--size-2);
  width: 100%;
}

.delete-btn {
  background-color: #d9534f;
  color: #fff;
}

.delete-btn:hover {
  background-color: #c9302c;
}

/* Quantity input */
.quantity-input {
  width: 50px;
  padding: var(--size-1);
  border: 1px solid var(--border-main);
  border-radius: var(--radius-2);
  text-align: center;
  margin-bottom: var(--size-2);
}

/* ------------------------------ */
/* Cart Table (cart.html)         */
/* ------------------------------ */
.cart-table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--size-5);
}

.cart-table th,
.cart-table td {
  padding: var(--size-3);
  border-bottom: 1px solid var(--border-main);
  color: var(--text-main);
  text-align: left;
}

.cart-table th {
  background-color: #2a4a8a;
  color: white;
}

.cart-table td {
  background-color: var(--bg-main);
}

/* Checkout Page */
.checkout-form {
  display: flex;
  flex-direction: column;
  gap: var(--size-3);
}

.payment-method {
  display: flex;
  gap: var(--size-3);
  margin-bottom: var(--size-4);
}

.payment-method input[type="radio"] {
  margin-right: var(--size-2);
}

/* Buttons in checkout */
.checkout-btn {
  background-color: var(--button-bg);
  color: white;
  padding: var(--size-2) var(--size-4);
  border-radius: var(--radius-2);
  cursor: pointer;
  border: none;
  font-size: var(--font-size-2);
  transition: background-color 0.2s ease, transform 0.1s ease;
}

.checkout-btn:hover {
  background-color: var(--button-hover);
  transform: translateY(-1px);
}


#snakeCanvas {
    display: block;
    margin: 1rem auto; /* center the canvas */
    border: 2px solid var(--button-bg); /* themed border */
    background-color: var(--bg-panel); /* dark panel bg */
}
