/* Cyberpunk YunoHost CSS Stylesheet
 * A dark, neon-accented theme for YunoHost admin interface
 */

:root {
  /* Main colors */
  --primary-color: #00ffff;          /* Cyan */
  --secondary-color: #ff00ff;        /* Magenta */
  --tertiary-color: #fcee0c;         /* Yellow */
  --accent-color: #ff3378;           /* Pink */
  
  /* Background colors */
  --bg-dark: #0d0e12;                /* Dark background */
  --bg-medium: #181c25;              /* Medium dark panels */
  --bg-light: #242836;               /* Lighter elements */
  
  /* Text colors */
  --text-primary: #e6e6e6;           /* Main text */
  --text-secondary: #a1a1a1;         /* Secondary text */
  --text-accent: var(--primary-color); /* Accent text */
  
  /* Status colors */
  --success-color: #00ff66;          /* Success green */
  --warning-color: var(--tertiary-color); /* Warning yellow */
  --error-color: #ff3333;            /* Error red */
  
  /* Shadows and glows */
  --neon-glow: 0 0 5px rgba(0, 255, 255, 0.5), 0 0 10px rgba(0, 255, 255, 0.3);
  --neon-glow-magenta: 0 0 5px rgba(255, 0, 255, 0.5), 0 0 10px rgba(255, 0, 255, 0.3);
  --box-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
  
  /* Logo background (replace with actual SVG URL) */
  --logo-background: url('/yunohost/admin/images/pagel-it-logo.svg');
}

/* Global styles */
body {
  background-color: var(--bg-dark);
  color: var(--text-primary);
  font-family: 'Courier New', monospace;
  margin: 0;
  padding: 0;
  background-image: linear-gradient(to bottom, rgba(13, 14, 18, 0.95), rgba(13, 14, 18, 0.98)), 
                    url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h100v100H0z' fill='none'/%3E%3Cpath d='M0 0h1v1H0z' fill='%23ffffff' fill-opacity='0.03'/%3E%3Cpath d='M0 10h1v1H0z' fill='%23ffffff' fill-opacity='0.03'/%3E%3Cpath d='M10 0h1v1H10z' fill='%23ffffff' fill-opacity='0.03'/%3E%3Cpath d='M50 0h1v1H50z' fill='%23ffffff' fill-opacity='0.03'/%3E%3Cpath d='M0 50h1v1H0z' fill='%23ffffff' fill-opacity='0.03'/%3E%3Cpath d='M50 50h1v1H50z' fill='%23ffffff' fill-opacity='0.03'/%3E%3C/svg%3E");
  background-attachment: fixed;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  color: var(--text-accent);
  font-family: 'Arial', sans-serif;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 1rem;
}

h1 {
  font-size: 2rem;
  border-bottom: 2px solid var(--primary-color);
  padding-bottom: 0.5rem;
  text-shadow: var(--neon-glow);
}

a {
  color: var(--primary-color);
  text-decoration: none;
  transition: color 0.3s ease, text-shadow 0.3s ease;
}

a:hover {
  color: var(--secondary-color);
  text-shadow: var(--neon-glow-magenta);
}

/* Header and navigation */
.navbar, #masthead, .header {
  background-color: var(--bg-medium);
  border-bottom: 1px solid var(--primary-color);
  box-shadow: var(--neon-glow), var(--box-shadow);
  padding: 0.5rem 2rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.navbar a, .nav-link, .header a {
  color: var(--text-primary);
  font-weight: bold;
  text-transform: uppercase;
  padding: 0.5rem 1rem;
  border-radius: 4px;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.navbar a:hover, .nav-link:hover, .header a:hover {
  background-color: var(--bg-light);
  color: var(--accent-color);
}

.navbar .active, .nav-link.active, .header .active {
  background-color: rgba(0, 255, 255, 0.1);
  color: var(--primary-color);
  box-shadow: inset 0 0 5px rgba(0, 255, 255, 0.2);
}

/* Sidebar */
.sidebar, aside, .menu {
  background-color: var(--bg-medium);
  border-right: 1px solid var(--primary-color);
  padding: 1rem;
}

.sidebar .logo, aside .logo {
  width: 100%;
  height: auto;
  max-height: 150px;
  margin: 1rem auto 2rem auto;
  display: flex;
  justify-content: center;
}

.sidebar ul, aside ul, .menu ul {
  list-style: none;
  padding: 0;
}

.sidebar li, aside li, .menu li {
  margin-bottom: 0.5rem;
}

/* Cards and panels */
.card, .panel, .box, .portal-app {
  background-color: var(--bg-medium);
  border-radius: 5px;
  border: 1px solid var(--bg-light);
  margin-bottom: 1.5rem;
  padding: 1.5rem;
  box-shadow: var(--box-shadow);
  transition: box-shadow 0.3s ease, transform 0.3s ease;
  position: relative;
  z-index: 1;
}

.card:hover, .panel:hover, .box:hover, .portal-app:hover {
  box-shadow: var(--neon-glow);
  transform: translateY(-2px);
}

.card-header, .panel-header, .box-header {
  border-bottom: 1px solid var(--bg-light);
  margin-bottom: 1rem;
  padding-bottom: 1rem;
}

/* Form elements */
input, select, textarea, button {
  background-color: var(--bg-light);
  border: 1px solid var(--text-secondary);
  border-radius: 4px;
  color: var(--text-primary);
  font-family: 'Courier New', monospace;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  width: 100%;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

input:focus, select:focus, textarea:focus {
  border-color: var(--primary-color);
  box-shadow: var(--neon-glow);
  outline: none;
}

button, .btn, input[type="submit"] {
  background-color: transparent;
  border: 2px solid var(--primary-color);
  color: var(--primary-color);
  cursor: pointer;
  font-weight: bold;
  letter-spacing: 1px;
  padding: 0.75rem 1.5rem;
  text-transform: uppercase;
  transition: background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
  width: auto;
}

button:hover, .btn:hover, input[type="submit"]:hover {
  background-color: var(--primary-color);
  color: var(--bg-dark);
  box-shadow: var(--neon-glow);
}

button.secondary, .btn-secondary {
  border-color: var(--secondary-color);
  color: var(--secondary-color);
}

button.secondary:hover, .btn-secondary:hover {
  background-color: var(--secondary-color);
  color: var(--bg-dark);
  box-shadow: var(--neon-glow-magenta);
}

/* Status indicators */
.status-success, .success, .ok {
  color: var(--success-color);
}

.status-warning, .warning {
  color: var(--warning-color);
}

.status-error, .error {
  color: var(--error-color);
}

/* Tables */
table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 1.5rem;
}

th {
  background-color: var(--bg-light);
  color: var(--text-accent);
  font-weight: bold;
  padding: 1rem;
  text-align: left;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-bottom: 2px solid var(--primary-color);
}

td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--bg-light);
}

tr:hover td {
  background-color: rgba(0, 255, 255, 0.05);
}

/* Progress bars */
.progress, progress {
  background-color: var(--bg-light);
  border-radius: 10px;
  height: 10px;
  overflow: hidden;
  margin-bottom: 1rem;
}

.progress-bar, progress::-webkit-progress-bar {
  background-color: var(--bg-light);
  border-radius: 10px;
}

progress::-webkit-progress-value {
  background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
  border-radius: 10px;
}

progress::-moz-progress-bar {
  background: linear-gradient(90deg, var(--primary-color), var(--secondary-color));
  border-radius: 10px;
}

/* Notifications and alerts */
.alert, .notification {
  border-radius: 4px;
  margin-bottom: 1.5rem;
  padding: 1rem;
  border-left: 4px solid transparent;
}

.alert-info, .notification-info {
  background-color: rgba(0, 255, 255, 0.1);
  border-left-color: var(--primary-color);
}

.alert-success, .notification-success {
  background-color: rgba(0, 255, 102, 0.1);
  border-left-color: var(--success-color);
}

.alert-warning, .notification-warning {
  background-color: rgba(252, 238, 12, 0.1);
  border-left-color: var(--warning-color);
}

.alert-error, .notification-error {
  background-color: rgba(255, 51, 51, 0.1);
  border-left-color: var(--error-color);
}

/* Footer */
.footer, footer {
  background-color: var(--bg-medium);
  border-top: 1px solid var(--primary-color);
  color: var(--text-secondary);
  font-size: 0.875rem;
  padding: 1.5rem 2rem;
  text-align: center;
}

.footer .logo, footer .logo {
  margin: 0 auto 1rem auto;
  height: 60px;
}

/* Badges and tags */
.badge, .tag, .label {
  background-color: var(--bg-light);
  border-radius: 10px;
  color: var(--text-primary);
  display: inline-block;
  font-size: 0.75rem;
  padding: 0.25rem 0.75rem;
  margin: 0 0.25rem 0.25rem 0;
  text-transform: uppercase;
}

.badge-primary, .tag-primary {
  background-color: rgba(0, 255, 255, 0.2);
  color: var(--primary-color);
  border: 1px solid var(--primary-color);
}

.badge-secondary, .tag-secondary {
  background-color: rgba(255, 0, 255, 0.2);
  color: var(--secondary-color);
  border: 1px solid var(--secondary-color);
}

/* Modals */
.modal, .dialog {
  background-color: var(--bg-medium);
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  box-shadow: var(--neon-glow), var(--box-shadow);
  max-width: 600px;
  padding: 2rem;
}

.modal-header, .dialog-header {
  border-bottom: 1px solid var(--bg-light);
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
}

.modal-footer, .dialog-footer {
  border-top: 1px solid var(--bg-light);
  margin-top: 1.5rem;
  padding-top: 1rem;
  text-align: right;
}

/* Scrollbar */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-dark);
}

::-webkit-scrollbar-thumb {
  background: var(--bg-light);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--primary-color);
}

/* YunoHost specific elements */
#yunohost-app-container, .yunohost-content {
  padding: 2rem;
}

/* Logo styling */
.logo, .site-logo, .yunohost-logo, .brand-logo, header .logo {
  width: auto;
  height: 80px;
  display: block;
  margin: 0.5rem 0;
}

.navbar .logo, .header .logo {
  max-height: 90px;
}

.logo img, .site-logo img, .brand-logo img {
  height: 100%;
  width: auto;
  object-fit: contain;
}

.tile-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 1.5rem;
}

.app-tile {
  background-color: var(--bg-medium);
  border-radius: 5px;
  border: 1px solid var(--bg-light);
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.5rem;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.app-tile:hover {
  transform: translateY(-5px);
  box-shadow: var(--neon-glow);
}

.app-icon {
  height: 64px;
  width: 64px;
  margin-bottom: 1rem;
}

.app-name {
  color: var(--text-accent);
  font-weight: bold;
  margin-bottom: 0.5rem;
  text-align: center;
}

.app-desc {
  color: var(--text-secondary);
  font-size: 0.875rem;
  text-align: center;
}

/* System status section */
.system-status {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.status-card {
  background-color: var(--bg-medium);
  border-radius: 5px;
  padding: 1.5rem;
  position: relative;
  overflow: hidden;
}

.status-card::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 8px;
  height: 100%;
  background: linear-gradient(to bottom, var(--primary-color), var(--secondary-color));
}

.status-card h3 {
  margin-top: 0;
}

/* Loading animations */
.loading {
  border: 4px solid var(--bg-light);
  border-top: 4px solid var(--primary-color);
  border-radius: 50%;
  width: 30px;
  height: 30px;
  animation: spin 1.5s linear infinite;
  margin: 0 auto;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.loading-bar {
  height: 4px;
  width: 100%;
  background-color: var(--bg-light);
  overflow: hidden;
  position: relative;
}

.loading-bar::after {
  content: '';
  display: block;
  position: absolute;
  left: -50%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent, var(--primary-color), var(--secondary-color), transparent);
  animation: loading 1.5s infinite;
}

@keyframes loading {
  0% { left: -50%; }
  100% { left: 100%; }
}

/* Dashboard */
.dashboard {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.5rem;
}

.dashboard-card {
  background-color: var(--bg-medium);
  border-radius: 5px;
  padding: 1.5rem;
}

.dashboard-card h3 {
  margin-top: 0;
  display: flex;
  align-items: center;
}

.dashboard-card h3 svg, .dashboard-card h3 i {
  margin-right: 0.5rem;
}

/* Terminal-like elements */
.terminal {
  background-color: var(--bg-dark);
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  color: var(--text-primary);
  font-family: 'Courier New', monospace;
  padding: 1rem;
  margin-bottom: 1.5rem;
  position: relative;
}

.terminal::before {
  content: '> ';
  color: var(--primary-color);
}

.terminal-header {
  background-color: var(--bg-light);
  border-bottom: 1px solid var(--primary-color);
  border-radius: 5px 5px 0 0;
  color: var(--text-primary);
  font-size: 0.875rem;
  padding: 0.5rem 1rem;
  margin: -1rem -1rem 1rem -1rem;
}

/* Code blocks */
pre, code {
  background-color: var(--bg-dark);
  border: 1px solid var(--bg-light);
  border-radius: 3px;
  color: var(--text-primary);
  font-family: 'Courier New', monospace;
  font-size: 0.875rem;
  overflow-x: auto;
}

code {
  padding: 0.2rem 0.4rem;
}

pre {
  padding: 1rem;
  margin-bottom: 1.5rem;
}

pre code {
  border: none;
  padding: 0;
}

/* Media queries for responsiveness */
@media (max-width: 768px) {
  .dashboard, .system-status {
    grid-template-columns: 1fr;
  }
  
  .navbar, #masthead, .header {
    padding: 0.5rem 1rem;
  }
  
  #yunohost-app-container, .yunohost-content {
    padding: 1rem;
  }
  
  .logo, .site-logo, .yunohost-logo, .brand-logo {
    height: 60px;
  }
  
  .sidebar .logo, aside .logo {
    max-height: 100px;
  }
}

@media (max-width: 480px) {
  .logo, .site-logo, .yunohost-logo, .brand-logo {
    height: 50px;
  }
  
  .sidebar .logo, aside .logo {
    max-height: 80px;
  }
}

/* Print styles */
@media print {
  body {
    background: white;
    color: black;
  }
  
  .navbar, .sidebar, .footer, button, .btn, input[type="submit"] {
    display: none;
  }
  
  .card, .panel, .box, .alert, .notification {
    border: 1px solid #ddd;
    box-shadow: none;
  }
}