:root {
  --c-primary:    #1a3a5c;
  --c-secondary:  #c8a84b;
  --c-accent:     #8b2020;
  --c-dark:       #0d1f2d;
  --c-darker:     #070f16;
  --c-light:      #f4e8c1;
  --c-sea:        #1e6091;
  --c-wood:       #3a1f0d;
  --c-panel:      rgba(13,31,45,0.92);
  --c-border:     rgba(200,168,75,0.35);
  --c-text:       #e8dcc8;
  --c-muted:      #8a9aaa;

  --radius:       6px;
  --radius-lg:    12px;
  --shadow:       0 4px 20px rgba(0,0,0,0.5);
  --transition:   0.2s ease;

  --font-title:   'IM Fell English', 'Palatino Linotype', Georgia, serif;
  --font-body:    'Crimson Text', Georgia, serif;
  --font-ui:      'Source Sans 3', 'Segoe UI', sans-serif;
}

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

html, body {
  height: 100%;
  background: var(--c-darker);
  color: var(--c-text);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
}

a { color: var(--c-secondary); text-decoration: none; transition: color var(--transition); }
a:hover { color: #e8c860; }

h1, h2, h3 { font-family: var(--font-title); color: var(--c-secondary); font-weight: normal; }
h1 { font-size: 2.5rem; }
h2 { font-size: 1.8rem; }
h3 { font-size: 1.3rem; }

/* Buttons */
.btn {
  display: inline-block;
  padding: 0.5rem 1.2rem;
  border: 1px solid var(--c-secondary);
  background: transparent;
  color: var(--c-secondary);
  font-family: var(--font-ui);
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  cursor: pointer;
  border-radius: var(--radius);
  transition: all var(--transition);
}
.btn:hover {
  background: var(--c-secondary);
  color: var(--c-dark);
}
.btn-primary {
  background: var(--c-secondary);
  color: var(--c-dark);
  font-weight: 600;
}
.btn-primary:hover {
  background: #e8c860;
  border-color: #e8c860;
}
.btn-danger {
  border-color: var(--c-accent);
  color: #e05050;
}
.btn-danger:hover {
  background: var(--c-accent);
  color: #fff;
}
.btn-sm { padding: 0.3rem 0.8rem; font-size: 0.8rem; }

/* Panel */
.panel {
  background: var(--c-panel);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  backdrop-filter: blur(8px);
}

/* Forms */
.form-group { margin-bottom: 1rem; }
.form-group label { display: block; font-family: var(--font-ui); font-size: 0.85rem; color: var(--c-muted); margin-bottom: 0.3rem; }
.form-group input, .form-group select {
  width: 100%;
  padding: 0.5rem 0.75rem;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  color: var(--c-text);
  font-family: var(--font-ui);
  font-size: 0.95rem;
  outline: none;
  transition: border-color var(--transition);
}
.form-group input:focus, .form-group select:focus { border-color: var(--c-secondary); }

/* Notification */
#notification {
  position: fixed;
  top: 1rem;
  right: 1rem;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.notif {
  padding: 0.75rem 1.2rem;
  border-radius: var(--radius);
  font-family: var(--font-ui);
  font-size: 0.9rem;
  animation: slideIn 0.3s ease;
  max-width: 320px;
}
.notif-ok      { background: #1a4a2a; border: 1px solid #3a8a4a; color: #8fe0a0; }
.notif-error   { background: #4a1a1a; border: 1px solid #8a3a3a; color: #e08080; }
.notif-info    { background: #1a2a4a; border: 1px solid #3a5a8a; color: #80b0e0; }
@keyframes slideIn { from { opacity:0; transform: translateX(30px); } to { opacity:1; transform: translateX(0); } }

/* Scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--c-darker); }
::-webkit-scrollbar-thumb { background: var(--c-primary); border-radius: 3px; }

/* Gold color */
.gold { color: var(--c-secondary); }
.muted { color: var(--c-muted); }
.danger { color: #e05050; }
.success { color: #5eca80; }

/* Badge */
.badge {
  display: inline-block;
  padding: 0.1rem 0.5rem;
  border-radius: 99px;
  font-size: 0.75rem;
  font-family: var(--font-ui);
}
.badge-gold { background: rgba(200,168,75,0.2); color: var(--c-secondary); border: 1px solid rgba(200,168,75,0.4); }
.badge-blue { background: rgba(30,96,145,0.3); color: #80c0f0; border: 1px solid rgba(80,150,200,0.4); }
.badge-red  { background: rgba(139,32,32,0.3); color: #e08080; border: 1px solid rgba(180,60,60,0.4); }
