/*-----------------------------------*\
  #OMAR.DEV - dimden.dev inspired
  Retro Web / Neocities Aesthetic
\*-----------------------------------*/

/*-----------------------------------*\
  #CSS VARIABLES
\*-----------------------------------*/

:root {
  /* Background Colors */
  --bg-dark: #0d0d0d;
  --bg-box: #111115;
  --bg-box-header: #181820;
  --bg-input: #0a0a0e;
  
  /* Border Colors */
  --border-main: #2a2a3a;
  --border-hover: #3a3a5a;
  
  /* Text Colors */
  --text-primary: #e8e8e8;
  --text-secondary: #a0a0b0;
  --text-dim: #6a6a7a;
  --text-cyan: #7dd3fc;
  --text-green: #86efac;
  --text-yellow: #fde047;
  --text-pink: #f9a8d4;
  --text-purple: #c4b5fd;
  
  /* Status Colors */
  --status-ok: #22c55e;
  --status-warn: #eab308;
  --status-error: #ef4444;
  
  /* Accent */
  --accent-moon: #ffffd4;
  --accent-link: #93c5fd;
  --accent-link-hover: #f9a8d4;
  
  /* Typography */
  --font-main: 'VT323', 'Courier New', monospace;
  --font-pixel: 'Pixelify Sans', 'VT323', monospace;
  
  /* Sizes */
  --border-radius: 0px;
  --box-padding: 10px;
  
  /* Transitions */
  --transition: 0.15s ease;
}

/*-----------------------------------*\
  #CSS RESET
\*-----------------------------------*/

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

html {
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-main);
  font-size: 18px;
  line-height: 1.5;
  color: var(--text-primary);
  background: var(--bg-dark);
  min-height: 100vh;
}

a {
  color: var(--accent-link);
  text-decoration: none;
  transition: color var(--transition);
}

a:hover {
  color: var(--accent-link-hover);
}

ul, ol {
  list-style: none;
}

img {
  max-width: 100%;
  display: inline-block;
  vertical-align: middle;
}

button, input, textarea {
  font-family: inherit;
  font-size: inherit;
}

button {
  cursor: pointer;
}

/*-----------------------------------*\
  #CANVAS BACKGROUND
\*-----------------------------------*/

#background-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
}

/*-----------------------------------*\
  #SITE CONTAINER
\*-----------------------------------*/

.site-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 20px;
}

/*-----------------------------------*\
  #COLUMNS
\*-----------------------------------*/

.column {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.column-left {
  /* Main content column */
}

.column-right {
  /* Sidebar column */
}

/*-----------------------------------*\
  #BOX COMPONENT
\*-----------------------------------*/

.box {
  background: var(--bg-box);
  border: 1px solid var(--border-main);
  border-radius: var(--border-radius);
}

.box-header {
  background: var(--bg-box-header);
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-main);
  font-size: 16px;
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.box-content {
  padding: var(--box-padding);
}

/*-----------------------------------*\
  #WELCOME BOX
\*-----------------------------------*/

.welcome-box .box-header {
  font-size: 18px;
}

.moon-icon {
  width: 20px;
  height: 20px;
  image-rendering: pixelated;
}

.avatar-small {
  width: 32px;
  height: 32px;
  border-radius: 4px;
  margin-left: auto;
}

.mood-link {
  font-size: 14px;
  color: var(--text-green);
  margin-left: 10px;
}

.mood-link:hover {
  color: var(--text-yellow);
}

.welcome-content {
  font-size: 17px;
  line-height: 1.6;
}

.welcome-content p {
  margin-bottom: 12px;
}

.highlight-text {
  text-decoration: underline;
  text-decoration-style: dotted;
}

.text-cyan { color: var(--text-cyan); }
.text-green { color: var(--text-green); }
.text-yellow { color: var(--text-yellow); }
.text-pink { color: var(--text-pink); }
.text-purple { color: var(--text-purple); }

.moon-inline {
  color: var(--accent-moon);
  text-shadow: 0 0 10px var(--accent-moon);
}

.quick-facts-title {
  color: var(--text-secondary);
  margin-top: 15px;
}

.quick-facts {
  margin: 10px 0 15px 0;
}

.quick-facts li {
  padding: 3px 0;
  padding-left: 15px;
  position: relative;
}

.quick-facts li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: var(--text-dim);
}

/*-----------------------------------*\
  #BLOG BOX
\*-----------------------------------*/

.rss-link {
  margin-left: auto;
  font-size: 14px;
}

.view-all-link {
  margin-left: auto;
  font-size: 14px;
  color: var(--text-cyan);
}

.view-all-link:hover {
  color: var(--text-pink);
}

.blog-list li {
  padding: 6px 0;
  border-bottom: 1px dotted var(--border-main);
}

.blog-list li:last-child {
  border-bottom: none;
}

.blog-bullet {
  color: var(--text-pink);
  font-weight: bold;
  margin-right: 5px;
}

.blog-date {
  color: var(--text-dim);
  font-size: 14px;
}

/*-----------------------------------*\
  #PROJECTS BOX
\*-----------------------------------*/

.projects-list li {
  padding: 10px 0;
  border-bottom: 1px dotted var(--border-main);
}

.projects-list li:last-child {
  border-bottom: none;
}

.project-link {
  font-size: 18px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.project-icon {
  color: var(--accent-moon);
}

.project-stars {
  font-size: 14px;
  color: var(--text-yellow);
  margin-left: 10px;
}

.project-desc {
  font-size: 15px;
  color: var(--text-secondary);
  margin-top: 5px;
  padding-left: 22px;
}

.other-projects {
  margin-top: 15px;
  padding-top: 10px;
  border-top: 1px solid var(--border-main);
  font-size: 15px;
  color: var(--text-secondary);
}

.other-projects a {
  margin: 0 5px;
}

/*-----------------------------------*\
  #SKILLS BOX
\*-----------------------------------*/

.skills-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px;
}

.skill-group h4 {
  font-size: 14px;
  color: var(--text-cyan);
  margin-bottom: 8px;
  font-weight: normal;
}

.skill-tag {
  display: inline-block;
  font-size: 14px;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.05);
  padding: 2px 8px;
  margin: 2px;
  border: 1px solid var(--border-main);
}

/*-----------------------------------*\
  #EXPERIENCE BOX
\*-----------------------------------*/

.exp-item {
  padding: 12px 0;
  border-bottom: 1px dotted var(--border-main);
}

.exp-item:last-child {
  border-bottom: none;
}

.exp-title {
  font-size: 17px;
  color: var(--text-cyan);
}

.exp-meta {
  font-size: 14px;
  color: var(--text-green);
  margin-bottom: 8px;
}

.exp-list {
  font-size: 15px;
  color: var(--text-secondary);
}

.exp-list li {
  padding: 2px 0;
  padding-left: 15px;
  position: relative;
}

.exp-list li::before {
  content: '├─';
  position: absolute;
  left: 0;
  color: var(--text-dim);
  font-size: 12px;
}

.exp-list li:last-child::before {
  content: '└─';
}

/*-----------------------------------*\
  #STATUS BOX
\*-----------------------------------*/

.status-ok-text {
  color: var(--status-ok);
}

.status-content {
  padding: 8px !important;
}

.status-item {
  font-size: 15px;
  padding: 4px 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.status-item.clickable {
  cursor: pointer;
  transition: background var(--transition);
}

.status-item.clickable:hover {
  background: rgba(234, 179, 8, 0.1);
}

.status-ok {
  color: var(--status-ok);
  font-weight: bold;
}

.status-warn {
  color: var(--status-warn);
  font-weight: bold;
}

.status-error {
  color: var(--status-error);
  font-weight: bold;
}

/*-----------------------------------*\
  #CHAT BOX
\*-----------------------------------*/

.chat-icon {
  width: 18px;
  height: 18px;
}

.chat-messages {
  height: 150px;
  overflow-y: auto;
  background: var(--bg-input);
  border: 1px solid var(--border-main);
  padding: 8px;
  margin-bottom: 10px;
  font-size: 14px;
}

.chat-msg {
  padding: 3px 0;
}

.chat-user {
  font-weight: bold;
}

.chat-user.system { color: var(--text-yellow); }
.chat-user.visitor { color: var(--text-cyan); }
.chat-user.omar { color: var(--text-green); }

.chat-text {
  color: var(--text-secondary);
}

.chat-input-area {
  display: flex;
  gap: 8px;
}

.chat-input-area input {
  flex: 1;
  background: var(--bg-input);
  border: 1px solid var(--border-main);
  color: var(--text-primary);
  padding: 6px 10px;
  font-size: 14px;
}

.chat-input-area input:focus {
  outline: none;
  border-color: var(--text-cyan);
}

.chat-input-area button {
  background: var(--bg-box-header);
  border: 1px solid var(--border-main);
  color: var(--text-primary);
  padding: 6px 15px;
  transition: all var(--transition);
}

.chat-input-area button:hover {
  background: var(--text-cyan);
  color: var(--bg-dark);
}

/*-----------------------------------*\
  #NOW PLAYING BOX
\*-----------------------------------*/

.nowplaying-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.track-link {
  display: flex;
  flex-direction: column;
}

.track-name {
  font-size: 16px;
  color: var(--text-primary);
}

.track-artist {
  font-size: 14px;
  color: var(--text-secondary);
}

.track-time {
  font-size: 13px;
  color: var(--text-dim);
}

/*-----------------------------------*\
  #NAV LINKS BOX
\*-----------------------------------*/

.elec-icon {
  width: 16px;
  height: 16px;
}

.nav-links li {
  padding: 4px 0;
}

.nav-link {
  font-size: 16px;
  display: block;
  padding: 4px 8px;
  transition: all var(--transition);
}

.nav-link:hover {
  background: rgba(147, 197, 253, 0.1);
}

/*-----------------------------------*\
  #ONLINE STATUS
\*-----------------------------------*/

.online-box {
  text-align: center;
}

.online-indicator {
  padding: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.online-dot {
  width: 10px;
  height: 10px;
  background: var(--status-ok);
  border-radius: 50%;
  animation: pulse 2s infinite;
  box-shadow: 0 0 10px var(--status-ok);
}

@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.6; transform: scale(1.2); }
}

.online-text {
  color: var(--status-ok);
  font-weight: bold;
}

/*-----------------------------------*\
  #CURRENT STATUS
\*-----------------------------------*/

.twitter-status {
  font-size: 15px;
}

.status-username {
  color: var(--text-cyan);
  font-weight: bold;
}

.status-text {
  color: var(--text-secondary);
  margin-top: 5px;
}

/*-----------------------------------*\
  #LOCATION BOX
\*-----------------------------------*/

.location-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.location-city {
  color: var(--text-primary);
}

.location-time {
  color: var(--text-cyan);
  font-weight: bold;
}

/*-----------------------------------*\
  #BANNERS BOX
\*-----------------------------------*/

.banners-content {
  padding: 10px;
  position: relative;
  overflow: hidden;
  background: var(--bg-box);
}

.banners-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 0;
  position: relative;
  z-index: 1;
}

.banner-link {
  display: block;
  text-decoration: none;
  transition: all 0.3s ease;
  position: relative;
  max-width: 150px;
  margin: 0 auto;
  opacity: 0.8;
}

.banner-img {
  display: block;
  width: 100%;
  max-width: 150px;
  height: auto;
  image-rendering: pixelated;
  image-rendering: -moz-crisp-edges;
  image-rendering: crisp-edges;
  transition: all 0.3s ease;
  filter: brightness(0.85);
}

/* Floating banners animation - gentle up and down */
.banner-link.floating .banner-img {
  animation: float 4s ease-in-out infinite;
}

@keyframes float {
  0%, 100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-8px);
  }
}

/* Gliding banners animation - subtle horizontal movement */
.banner-link.gliding .banner-img {
  animation: glide 5s ease-in-out infinite;
}

@keyframes glide {
  0%, 100% {
    transform: translateX(0px);
  }
  50% {
    transform: translateX(8px);
  }
}

/* Neon glow effects on hover */
.banner-link:hover .banner-img {
  filter: brightness(1.3) drop-shadow(0 0 8px rgba(125, 211, 252, 0.8)) drop-shadow(0 0 12px rgba(125, 211, 252, 0.6)) drop-shadow(0 0 16px rgba(125, 211, 252, 0.4));
  transform: scale(1.05);
  opacity: 1;
}

.banner-link:hover {
  opacity: 1;
}

/* Variant neon effects for different banners */
.banner-link:nth-child(1):hover .banner-img {
  filter: brightness(1.4) drop-shadow(0 0 10px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 15px rgba(255, 255, 255, 0.7)) drop-shadow(0 0 20px rgba(255, 255, 255, 0.5));
}

.banner-link:nth-child(2):hover .banner-img {
  filter: brightness(1.3) drop-shadow(0 0 8px rgba(249, 168, 212, 0.8)) drop-shadow(0 0 12px rgba(249, 168, 212, 0.6)) drop-shadow(0 0 16px rgba(249, 168, 212, 0.4));
}

.banner-link:nth-child(3):hover .banner-img {
  filter: brightness(1.35) drop-shadow(0 0 9px rgba(125, 211, 252, 0.85)) drop-shadow(0 0 14px rgba(125, 211, 252, 0.65)) drop-shadow(0 0 18px rgba(125, 211, 252, 0.45));
}

.banner-link:nth-child(4):hover .banner-img {
  filter: brightness(1.3) drop-shadow(0 0 8px rgba(253, 224, 71, 0.8)) drop-shadow(0 0 12px rgba(253, 224, 71, 0.6)) drop-shadow(0 0 16px rgba(253, 224, 71, 0.4));
}

.banner-link:nth-child(5):hover .banner-img {
  filter: brightness(1.3) drop-shadow(0 0 8px rgba(249, 168, 212, 0.8)) drop-shadow(0 0 12px rgba(249, 168, 212, 0.6)) drop-shadow(0 0 16px rgba(249, 168, 212, 0.4));
}

.banner-link:nth-child(6):hover .banner-img {
  filter: brightness(1.3) drop-shadow(0 0 8px rgba(125, 211, 252, 0.8)) drop-shadow(0 0 12px rgba(125, 211, 252, 0.6)) drop-shadow(0 0 16px rgba(125, 211, 252, 0.4));
}

.banner-link:active .banner-img {
  transform: scale(0.95);
}

/*-----------------------------------*\
  #88x31 BUTTONS
\*-----------------------------------*/

.buttons-content {
  padding: 10px;
}

.buttons-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 15px;
}

.button-88x31 {
  width: 88px;
  height: 31px;
  background: linear-gradient(180deg, #333 0%, #111 100%);
  border: 1px solid var(--border-main);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-primary);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  transition: all var(--transition);
  text-decoration: none;
}

.button-88x31:hover {
  border-color: var(--text-cyan);
  box-shadow: 0 0 8px rgba(125, 211, 252, 0.3);
  color: var(--text-cyan);
}

.button-88x31.special {
  background: linear-gradient(180deg, #442266 0%, #221133 100%);
  border-color: var(--text-pink);
}

.button-88x31.special:hover {
  border-color: var(--text-pink);
  box-shadow: 0 0 8px rgba(249, 168, 212, 0.3);
  color: var(--text-pink);
}

.button-88x31-img {
  width: 88px;
  height: 31px;
  background: linear-gradient(180deg, #222 0%, #0a0a0a 100%);
  border: 1px solid var(--border-main);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 9px;
  color: var(--text-secondary);
  text-decoration: none;
}

.button-88x31-img:hover {
  border-color: var(--accent-link);
}

.cool-sites {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px dotted var(--border-main);
}

.cool-sites p {
  font-size: 14px;
  color: var(--text-dim);
  margin-bottom: 8px;
}

.cool-sites-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.my-button-section {
  margin-bottom: 15px;
  padding-bottom: 15px;
  border-bottom: 1px dotted var(--border-main);
}

.my-button {
  background: linear-gradient(180deg, #1a3a5a 0%, #0a1520 100%);
  border-color: var(--text-cyan);
  margin-bottom: 8px;
}

.hotlink-code {
  font-size: 12px;
}

.hotlink-code code {
  display: block;
  background: var(--bg-input);
  padding: 5px;
  border: 1px solid var(--border-main);
  color: var(--text-dim);
  font-size: 10px;
  word-break: break-all;
}

.hotlink-note {
  color: var(--text-green);
  font-size: 12px;
  margin-top: 5px;
}

.webring {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 14px;
}

.webring-link {
  color: var(--text-cyan);
  font-weight: bold;
}

.webring-name {
  color: var(--text-secondary);
}

/*-----------------------------------*\
  #GUESTBOOK
\*-----------------------------------*/

.guestbook-entries {
  max-height: 200px;
  overflow-y: auto;
  margin-bottom: 15px;
  padding-right: 5px;
}

.gb-entry {
  padding: 10px;
  background: var(--bg-input);
  border: 1px solid var(--border-main);
  margin-bottom: 8px;
}

.gb-name {
  color: var(--text-cyan);
  font-weight: bold;
}

.gb-date {
  color: var(--text-dim);
  font-size: 12px;
  margin-left: 10px;
}

.gb-msg {
  color: var(--text-secondary);
  margin-top: 5px;
  font-size: 15px;
}

.guestbook-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.guestbook-form input,
.guestbook-form textarea {
  background: var(--bg-input);
  border: 1px solid var(--border-main);
  color: var(--text-primary);
  padding: 8px;
  font-size: 14px;
}

.guestbook-form input:focus,
.guestbook-form textarea:focus {
  outline: none;
  border-color: var(--text-cyan);
}

.guestbook-form textarea {
  min-height: 60px;
  resize: vertical;
}

.guestbook-form button {
  background: var(--bg-box-header);
  border: 1px solid var(--border-main);
  color: var(--text-primary);
  padding: 8px 15px;
  align-self: flex-start;
  transition: all var(--transition);
}

.guestbook-form button:hover {
  background: var(--text-cyan);
  color: var(--bg-dark);
}

/*-----------------------------------*\
  #CONTROLS BOX
\*-----------------------------------*/

.controls-content {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.control-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--text-secondary);
  cursor: pointer;
}

.control-item input {
  accent-color: var(--text-cyan);
}

.control-item:hover {
  color: var(--text-primary);
}

/*-----------------------------------*\
  #FOOTER
\*-----------------------------------*/

.site-footer {
  text-align: center;
  padding: 20px;
  margin-top: 20px;
  font-size: 14px;
  color: var(--text-dim);
}

.site-footer a {
  color: var(--text-secondary);
}

/*-----------------------------------*\
  #SCROLLBAR
\*-----------------------------------*/

::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

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

::-webkit-scrollbar-thumb {
  background: var(--border-main);
}

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

/*-----------------------------------*\
  #SELECTION
\*-----------------------------------*/

::selection {
  background: var(--text-pink);
  color: var(--bg-dark);
}

/*-----------------------------------*\
  #RESPONSIVE - TABLET
\*-----------------------------------*/

@media (max-width: 900px) {
  .site-container {
    grid-template-columns: 1fr;
  }
  
  .column-right {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
  
  .buttons-box {
    grid-column: 1 / -1;
  }
  
  .guestbook-box {
    grid-column: 1 / -1;
  }
}

/*-----------------------------------*\
  #RESPONSIVE - MOBILE
\*-----------------------------------*/

@media (max-width: 600px) {
  .site-container {
    padding: 10px;
  }
  
  .column-right {
    grid-template-columns: 1fr;
  }
  
  .skills-grid {
    grid-template-columns: 1fr;
  }
  
  .box-header {
    font-size: 14px;
  }
  
  .welcome-content {
    font-size: 15px;
  }
  
  .buttons-grid {
    justify-content: center;
  }
}

/*-----------------------------------*\
  #RAIN DROPS (for rain effect)
\*-----------------------------------*/

.rain-drop {
  position: fixed;
  top: -50px;
  width: 2px;
  height: 20px;
  background: linear-gradient(180deg, transparent, rgba(125, 211, 252, 0.4));
  pointer-events: none;
  z-index: -1;
}

/*-----------------------------------*\
  #NOTIFICATION
\*-----------------------------------*/

.notification {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-box);
  border: 1px solid var(--text-cyan);
  color: var(--text-primary);
  padding: 12px 24px;
  font-size: 14px;
  z-index: 1000;
  animation: slide-down 0.3s ease;
}

@keyframes slide-down {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}
