:root {
  --bg:     #e9edf1;
  --text:   #0f172a;
  --muted:  #64748b;
  --brand1: #2b6a7a;
  --brand2: #5ab0a6;
  --card:   #ffffff;
  --shadow: 0 10px 28px rgba(0,0,0,.12);
  /* CV */
  --cv-gap: 28px;
  --meter1: #1e90ff;
  --meter2: #22c55e;
}

/* Base */
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji;color:var(--text);background:var(--bg);line-height:1.55}
a{color:inherit}
ul{padding-left:1.1rem;margin:0}

/* Header — GRADIENT ON CONTAINER ONLY */
header{background:linear-gradient(90deg,var(--brand1),var(--brand2));padding:18px 16px 16px;color:#e7f7f5;box-shadow:var(--shadow)}
.brand{max-width:1100px;margin:0 auto;display:flex;justify-content:center;align-items:center}
.brand h1{background:none !important;color:#e7f7f5 !important;margin:0;font-size:clamp(26px,4vw,46px);letter-spacing:.04em;font-weight:800}
.brand h1::after{content:none !important}

/* Shared cards & wrappers */
.wrap{max-width:1100px;margin:32px auto 64px;padding:0 16px;border-top:1px solid rgba(0,0,0,.05)}
.card{background:var(--card);padding:18px 20px;border-radius:18px;box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column}
.card h2{margin:.1rem 0 .6rem 0;font-size:clamp(18px,2.3vw,28px)}
.muted{color:var(--muted)}

/* Home (unchanged) */
.intro{display:grid;grid-template-columns:1.05fr 1fr 1.35fr;gap:36px;align-items:stretch}
.card.projects{padding-top:12px}
.card.projects h2{margin:.05rem 0 .35rem 0}
.card.projects ul{margin-top:.2rem}
a.link{color:var(--brand1);text-decoration:none;font-weight:600;border-bottom:1px solid transparent;transition:color .15s,border-color .15s}
a.link:hover{color:var(--brand2);border-bottom-color:var(--brand2)}
.card ul a{color:var(--brand1);text-decoration:none;font-weight:600;border-bottom:1px solid transparent;padding:0;transition:color .15s,border-color .15s}
.card ul a:hover{color:var(--brand2);border-bottom-color:var(--brand2)}
.img-card{display:flex;justify-content:center;align-items:center}
.profile-photo{width:100%;max-width:520px;aspect-ratio:1/1;border-radius:50%;object-fit:cover;box-shadow:var(--shadow);border:10px solid #fff;background:#ddd}
.social{margin-top:42px;padding-top:28px;border-top:1px solid #e5e7eb}
.social h3{text-align:center;font-size:clamp(22px,3vw,32px);margin:0 0 22px 0}
.social-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:24px;align-items:stretch}
.sbtn{background:var(--card);box-shadow:var(--shadow);border:1px solid rgba(0,0,0,.05);border-radius:22px;padding:22px 12px 16px;text-align:center;text-decoration:none;transition:transform .08s;color:inherit}
.sbtn:hover{transform:translateY(-3px)}
.social-img{width:140px;height:140px;object-fit:cover;border-radius:50%;display:block;margin:0 auto 10px}
.slabel{font-size:14px;color:var(--muted)}
.contact{margin-top:42px;padding-top:28px;border-top:1px solid #e5e7eb;text-align:center}
.contact h3{font-size:clamp(22px,3vw,32px);margin:0 0 22px 0}
.contact-card{min-height:100px;width:100%;margin:0 auto;padding:24px 20px}
.contact-list{display:flex;justify-content:center;flex-wrap:wrap;gap:18px;padding:14px 0}
.cbtn,.donate-btn{display:inline-flex;align-items:center;gap:12px;padding:14px 24px;border-radius:14px;font-size:17px;min-width:160px;justify-content:center;transition:background .15s,transform .1s}
.cbtn{background:#2b6a7a;color:#fff;border:none;cursor:pointer}
.cbtn:hover{background:#5ab0a6;transform:translateY(-2px)}
.donate-btn{text-decoration:none;background:#ffd54f;color:#000;font-weight:600}
.donate-btn:hover{background:#ffcd32;transform:translateY(-2px)}

/* Responsive */
@media (max-width:1100px){.intro{grid-template-columns:1fr}.social-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:700px){.social-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.social-img{width:120px;height:120px}.contact-card{max-width:100%}}

/* Mini-stats */
.mini-stats{display:flex;flex-wrap:wrap;gap:8px 10px;margin-top:14px}
.stat{display:inline-flex;align-items:center;gap:8px;background:#f3f6f8;border:1px solid rgba(0,0,0,.06);padding:6px 10px;border-radius:999px;font-size:13px;color:#334155}
.stat b{font-weight:800}

/* ===== CV PAGE STYLES ===== */
.cv-wrap{max-width:1000px;margin:32px auto 64px;padding:0 16px;display:grid;grid-auto-rows:min-content;row-gap:var(--cv-gap)}
.cv-header{display:flex;align-items:center;justify-content:space-between;gap:16px}
.cv-title{display:flex;align-items:center;gap:18px}
.cv-header h1{font-size:clamp(26px,4vw,42px);margin:0}
.cv-meta{color:var(--muted);font-size:14px}
.avatar{width:84px;height:84px;border-radius:50%;object-fit:cover;box-shadow:var(--shadow);cursor:zoom-in}
.cv-section{display:flex;flex-direction:column;gap:10px;margin:0}

/* Skills */
.skills-grid{display:grid;grid-template-columns:1fr;gap:12px}
@media (min-width:900px){.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.skill{display:flex;flex-direction:column;gap:6px}
.skill-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.skill-name{font-weight:700}
.skill-val{font-variant-numeric:tabular-nums;color:var(--muted)}
.meter{height:9px;border-radius:999px;background:#eef2f7;overflow:hidden;border:1px solid #e6e9ef}
.meter-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--meter1),var(--meter2));transition:width .4s ease}

/* Timeline */
.timeline{list-style:none;padding:0;margin:0}
.timeline li{position:relative;padding:12px;margin:0;background:var(--card);border-radius:0;border-bottom:1px solid #e5e7eb}
.timeline li:first-child{border-top:1px solid #e5e7eb;border-top-left-radius:12px;border-top-right-radius:12px}
.timeline li:last-child{border-bottom:none;border-bottom-left-radius:12px;border-bottom-right-radius:12px}
.timeline time{font-weight:700;margin-right:10px;white-space:nowrap}
.timeline li + li{margin-top:6px}

/* Table */
.table-wrap{overflow:auto}
table.cv{width:100%;border-collapse:collapse;background:var(--card);box-shadow:var(--shadow);border-radius:12px;overflow:hidden;border:1px solid #e6e9ef}
table.cv thead th{background:#f8fafc;font-weight:800;border-bottom:1px solid #e5e7eb}
table.cv tbody tr{border-bottom:1px solid #e5e7eb}
table.cv tbody tr:last-child{border-bottom:none}
table.cv th,table.cv td{text-align:left;padding:12px 14px;vertical-align:top}

/* Lightbox */
.img-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:60}
.img-modal.is-open{display:flex}
.img-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.7);backdrop-filter:blur(2px)}
.img-modal__content{position:relative;max-width:min(92vw,720px);max-height:80vh;border-radius:16px;box-shadow:var(--shadow);z-index:61}
.img-modal__close{position:absolute;top:16px;right:20px;z-index:62;border:0;background:rgba(255,255,255,.9);padding:6px 10px;border-radius:10px;font-weight:700;cursor:pointer}

/* ---------- Mobile (≤ 640px) ---------- */
@media (max-width:640px){
  /* Basregler för media och rytm */
  img,video,svg{max-width:100%;height:auto}
  body{line-height:1.6}
  .wrap{margin:20px auto 40px;padding:0 12px}

  /* Header/brand */
  header{padding:14px 12px}
  .brand{padding:0 4px}
  .brand h1{letter-spacing:.02em}

  /* Grid och kort */
  .intro{gap:18px}
  .card{padding:16px;border-radius:16px}
  .card.projects{padding-top:10px}

  /* Social-sektion */
  .social{margin-top:28px;padding-top:20px}
  .social-grid{gap:16px}
  .sbtn{padding:16px 10px;border-radius:18px}
  .social-img{width:100px;height:100px}
  .slabel{font-size:13px}

  /* Kontaktknappar – full bredd på mobil */
  .contact{margin-top:28px;padding-top:20px}
  .contact-list{gap:10px}
  .cbtn,.donate-btn{width:100%;min-width:auto}

  /* CV-header staplas */
  .cv-header{flex-direction:column;align-items:flex-start;gap:12px}
  .cv-title{gap:12px;flex-wrap:wrap}
  .avatar{width:72px;height:72px}
  .cv-meta{font-size:13px}

  /* Skills: en kolumn är redan default; bara tajtare spacing */
  .skills-grid{gap:10px}
  .skill{gap:6px}
  .meter{height:8px}

  /* Timeline kompaktare på mobil */
  .timeline li{padding:10px}
  .timeline time{margin-right:8px}

  /* Tabeller: horisontell scroll med min-bredd så layouten inte spräcks */
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .table-wrap table{min-width:600px}
  table.cv th,table.cv td{padding:10px 12px}
}

/* ---------- Very small (≤ 360px) ---------- */
@media (max-width:360px){
  .avatar{width:64px;height:64px}
  .card{padding:14px}
  .sbtn{padding:14px 10px}
  .social-img{width:88px;height:88px}
}

/* Print PDF */
@media print{
  @page{size:A4;margin:12mm}
  body{background:#fff !important;color:#111827 !important}
  header{display:none !important}
  .cv-wrap{max-width:100% !important;margin:0 !important;padding:0 !important;row-gap:12px !important}
  .card{box-shadow:none !important;border:1px solid #cfd8e3 !important;border-radius:8px !important}
  .contact-card,.backlink{display:none !important}
  .meter{background:#e5e7eb !important;border-color:#e5e7eb !important}
  .meter-fill{background:#111827 !important}
  a{text-decoration:underline !important;color:#111827 !important}
  table.cv th,table.cv td{padding:8px 10px !important}
  .timeline li{page-break-inside:avoid}
}

/* --- Hotfix: Mobil overflow & läsbarhet --- */

/* 1) Döda tvingad min-bredd som orsakar horisontell scroll */
@media (max-width: 640px) {
  .table-wrap table,
  table.cv {
    min-width: 0 !important;   /* ta bort min-width 600px */
    width: 100% !important;     /* lås till viewportbredd */
    table-layout: fixed;        /* jämn kolumnbredd på små skärmar */
    word-wrap: break-word;
  }
}

/* 2) Förhindra att något sticker ut i sidled (säkerhetsbälte) */
html, body {
  overflow-x: hidden;           /* lås sidled */
}

/* 3) Se till att alla block följer med in i viewporten */
img, video, svg, canvas {
  max-width: 100%;
  height: auto;
}

/* 4) Låsa in header/brand så skugga/gradient inte orsakar spill */
@media (max-width: 640px) {
  header,
  .brand,
  .wrap,
  .cv-wrap {
    max-width: 100%;
    overflow: hidden;
  }
}

/* 5) H1 och kort tajtare på små skärmar */
@media (max-width: 640px) {
  .cv-header h1,
  .brand h1 {
    font-size: clamp(22px, 6vw, 28px) !important;
  }
  .card {
    margin-left: 0;
    margin-right: 0;
    border-radius: 14px;
  }
}

/* 6) Långa ord/rader bryts istället för att trycka ut layouten */
.card, .cv-wrap, .wrap, table.cv td, table.cv th, p, li {
  overflow-wrap: anywhere;
  word-break: break-word;
}

#image-overlay {
    display: none;              /* gömd som standard */
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.8);
    justify-content: center;
    align-items: center;
    z-index: 9999;
    cursor: zoom-out;
}

#image-overlay img {
    max-width: 90vw;
    max-height: 90vh;
    border-radius: 8px;
}
