:root {
  /* Palette: #0F1021, #D01257, #FB90B7, #2C3D4F */
  --primary-color: #D01257; /* Raspberry */
  --secondary-color: #0F1021; /* Deep Dark Blue */
  --accent-color: #FB90B7; /* Light Pink */
  --light-color: #2C3D4F; /* Blue Grey (used as light contrast on dark) */
  --dark-color: #05050b; /* Almost Black */
  --gradient-primary: linear-gradient(135deg, #D01257 0%, #AB0E86 100%);
  --hover-color: #A00E44;
  --background-color: #0F1021; /* Dark Background */
  --text-color: #F2F2F2; /* Light Text */
  --border-color: rgba(208, 18, 87, 0.3);
  --divider-color: rgba(251, 144, 183, 0.1);
  --shadow-color: rgba(0, 0, 0, 0.5);
  --highlight-color: #FFD700; /* Gold */
  --main-font: 'Roboto', sans-serif;
  --alt-font: 'Montserrat', sans-serif;
}

body {
    font-family: var(--main-font);
    color: var(--text-color);
    background-color: var(--background-color);
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--alt-font);
    letter-spacing: 0.5px;
}

.glass-panel {
    background: rgba(44, 61, 79, 0.3);
    backdrop-filter: blur(10px);
    border: 1px solid var(--border-color);
}

/* Abstract Geo Pattern SVG as bg */
.geo-pattern {
    background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23FB90B7' fill-opacity='0.05' fill-rule='evenodd'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/svg%3E");
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    z-index: 0;
}