:root {
  --bg: #fff;
  --text: #111;
  --muted: #666;
  --border: #ddd;
  --primary: #1a1f4c;
  --primary-hover: #333a80;
  --danger: #d9534f;
  --danger-hover: #c12e2a;
  --alert-bg: #ffdddd;
  --alert-border: #ff0000;
}

* { box-sizing: border-box; }

body {
  margin:0;
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
}

header {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 28px;
  border-bottom:1px solid var(--border);
  font-size:15px;
}

.logo { font-weight:500; }

nav a { margin-left:18px; color:var(--text); text-decoration:none; }
nav a.admin-link { margin-left:12px; font-size:13px; opacity:0.8; }
nav a:hover { text-decoration:underline; }

main { padding:28px; min-height:60vh; }

/* grid for projects */
.grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap:20px;
}

/* projektkort styling */
.project {
  display: flex;
  flex-direction: column;
  background: #fafafa;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  text-decoration: none;
  color: var(--text);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.project:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 24px rgba(0,0,0,0.15);
}

.project img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.project:hover img {
  transform: scale(1.05);
}

.project-content {
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.project h3 {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
}

.project-url {
  font-size: 14px;
  color: var(--muted);
  word-break: break-all;
  transition: color 0.3s ease;
}

.project:hover .project-url {
  color: #111;
}

/* footer */
footer {
  border-top:1px solid var(--border);
  padding:22px 28px;
  display:flex;
  justify-content:center;
  align-items:center;
  font-size:14px;
  color:var(--muted);
}

/* social media samlet */
.footer-social {
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  justify-content:center;
}

.footer-social a {
  display:flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:var(--text);
  transition: color 0.3s ease;
}

.footer-social a:hover {
  color: var(--primary);
}

/* social media icons + animation */
.social-icon {
  width: 22px;
  height: 22px;
  transition: transform 0.3s ease, filter 0.3s ease;
}

.footer-social a:hover .social-icon {
  transform: scale(1.2) rotate(5deg);
  filter: drop-shadow(0 0 6px var(--primary));
}

/* admin styles */
.admin-area { max-width:920px; margin:auto; display:grid; gap:18px; }
.card { background:#fafafa; padding:16px; border:1px solid var(--border); border-radius:8px; }
label { display:block; margin:8px 0; font-size:14px; }
input[type="text"], input[type="password"], input[type="email"], textarea {
  width:100%; padding:8px; border:1px solid var(--border); border-radius:6px; font-size:14px;
}
button { padding:8px 12px; border-radius:6px; border:none; background: var(--primary); color:#fff; cursor:pointer; margin-top:6px; transition: background 0.3s; }
button:hover { background: var(--primary-hover); }
#logout-btn { background: var(--danger); }
#logout-btn:hover { background: var(--danger-hover); }
.project-edit { margin-bottom:8px; }
.project-edit .row { display:flex; gap:8px; margin-top:6px; }
.hint { font-size:13px; color:var(--muted); margin-top:8px; }
.editor-actions { display:flex; gap:8px; margin-top:12px; flex-wrap:wrap; }

/* alert box */
.alert-box {
  background-color: var(--alert-bg);
  color: var(--danger);
  padding: 12px 20px;
  border-left: 6px solid var(--alert-border);
  margin-bottom: 24px;
  border-radius: 6px;
  font-weight: bold;
  text-align: center;
}

/* responsive */
@media (max-width:600px){
  header { padding:12px; }
  main { padding:12px; }
  footer { flex-direction:column; padding:12px; }
  .footer-social { gap:12px; }
}

/* intro-box styling */
.intro-box {
  background: #fafafa; /* match projektkort */
  padding: 1.5rem;
  margin: 2rem auto;
  border: 1px solid var(--border);
  border-radius: 8px;
  max-width: 800px;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  animation: fadeSlideIn 0.6s ease-out forwards;
  opacity: 0;
  transform: translateY(20px);
}

.intro-box:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.08);
}

.intro-box h2 {
  margin-bottom: 1rem;
  color: #222;
  font-size: 1.8rem;
}

.intro-box p {
  color: #444;
  line-height: 1.6;
  margin-bottom: 1rem;
  font-size: 1rem;
}

/* about-box styling */
.about-box {
  background: #fafafa;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1.5rem;
  margin: 2rem auto;
  max-width: 900px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  animation: fadeSlideIn 0.6s ease-out forwards;
  opacity: 0;
  transform: translateY(20px);
}

.about-box:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.08);
}

.about-content {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
}

/* større billede */
.about-image img {
  width: 250px;
  height: 250px;
  object-fit: cover;
  border-radius: 8px;
}

.about-text {
  flex: 1;
  font-size: 1rem;
  line-height: 1.6;
}

/* nye sektioner under Om mig */
.about-extra {
  max-width: 800px;
  margin: 2rem auto;
  padding: 1.5rem;
  background: #fafafa;
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  opacity: 0;
  transform: translateY(20px);
  animation: fadeSlideIn 0.6s ease-out forwards;
}

.about-extra:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.08);
}

.about-extra h3 {
  margin-top: 1.5rem;
  color: #222;
  font-size: 1.4rem;
}

.about-extra p {
  color: #444;
  line-height: 1.6;
  margin-top: 0.5rem;
}

/* animation */
@keyframes fadeSlideIn {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Fix logo/titel: ingen linje, ingen anden farve */
#site-title {
  text-decoration: none; /* fjern understregning */
  border-bottom: none;   /* fjern eventuel border */
  color: inherit;        /* behold samme farve som headeren */
}
