/* === Font Import === */
@font-face {
  font-family: 'Share Tech Mono';
  src: url('fonts/ShareTechMono-Regular.woff2') format('woff2'),
       url('fonts/ShareTechMono-Regular.woff') format('woff'),
       url('fonts/ShareTechMono-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
}

/* === Theme Variables === */
:root {
  --bg-color: #fdfdfd;
  --text-color: #111;
  --card-bg: #fff;
  --card-border: #000;
}

body.dark-mode {
  --bg-color: #111;
  --text-color: #fdfdfd;
  --card-bg: #222;
  --card-border: #666;
}

/* === Base Styles === */
body {
  font-family: 'Share Tech Mono', 'Courier New', monospace;
  background-color: var(--bg-color);
  color: var(--text-color);
  margin: 20px;
  line-height: 1.4;
}

h1 {
  text-align: center;
  font-size: 2em;
  font-weight: bold;
  border-bottom: 4px double #000;
  padding-bottom: 10px;
  margin-bottom: 30px;
  letter-spacing: 2px;
}

h2 {
  font-size: 1.2em;
  text-transform: uppercase;
  background: #000;
  color: #fff;
  padding: 6px 12px;
  margin: 25px 0 15px;
  border: 2px solid #000;
  display: inline-block;
  box-shadow: 3px 3px 0 #666;
}
h2::before { margin-right: 6px; }

/* === Layout === */
.container { display: flex; gap: 20px; }
.character-info { display: flex; gap: 30px; align-items: stretch; margin-bottom: 25px; }
.section { border: 2px solid var(--card-border); background-color: var(--card-bg); box-shadow: 4px 4px 0 #000; padding: 15px; margin-bottom: 25px; flex: 1; }
.skills { display: grid; grid-template-columns: 150px 120px 80px 80px; gap: 10px; align-items: center; }
.divider { grid-column: 1 / -1; border-top: 2px solid #000; margin: 12px 0; padding-top: 5px; font-weight: bold; font-size: 1.1em; letter-spacing: 1px; }

/* === Cards === */
.upload-card {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--card-bg);
  border: 2px solid var(--card-border);
  padding: 20px;
  box-shadow: 4px 4px 0 var(--card-border);
  display: none;   /* hidden until button is clicked */
  z-index: 1000;
  width: 300px;
  text-align: center;
}

.portrait-card, .info-card, .card {
  background-color: var(--card-bg);
  border: 2px solid var(--card-border);
  box-shadow: 4px 4px 0 var(--card-border);
  padding: 15px;
}
.portrait-card { flex: 0 0 220px; display: flex; flex-direction: column; align-items: center; }
.info-card { flex: 1; display: flex; flex-direction: column; }

/* === Portrait Window === */
#portraitWindow {
  width: 200px; height: 200px;
  border: 2px solid #000;
  position: relative;
  resize: both;
  overflow: hidden;
  margin: 0 auto;
}
#portraitImg { width: 100%; height: 100%; object-fit: cover; }
.resize-handle { width: 15px; height: 15px; background: #666; position: absolute; bottom: 0; right: 0; cursor: se-resize; }

/* === Inputs === */
#charName, #charNotes, select, option {
  font-family: inherit;
  font-size: 1em;
  padding: 5px;
  background-color: var(--card-bg);
  border: 2px solid var(--card-border);
  box-shadow: 2px 2px 0 var(--card-border);
  color: var(--text-color);
  min-width: 150px; /* enough space for longer labels */ 
  max-width: 100%; /* don’t overflow the card */
}
#charName { width: 350px; margin-bottom: 10px; }
#charNotes { flex: 1; resize: none; }
.note { font-size: 0.9em; margin-bottom: 10px; color: var(--text-color); }

/* === Buttons === */
button, .upload-btn {
  background: #000;
  color: #fff;
  border: none;
  padding: 5px 10px;
  cursor: pointer;
  font-family: inherit;
  font-weight: bold;
  box-shadow: 2px 2px 0 #666;
}
button:hover, .upload-btn:hover { background: #444; }
.upload-btn { margin-top: 8px; width: 200px; text-align: center; }

/* === Dice Roller === */
#rollResult { font-weight: bold; padding: 6px 10px; border: 2px solid #000; background: #f0f0f0; display: inline-block; margin-top: 8px; }
.success { color: #0066cc; }
.critical { color: #008000; font-weight: bold; }
.failure { color: #555; }
.fumble { color: #cc0000; font-weight: bold; }

/* === Footer === */
footer { text-align: center; font-size: 0.9em; margin-top: 40px; border-top: 3px double #000; padding-top: 12px; }
footer a { color: #0066cc; text-decoration: none; font-weight: bold; }
footer a:hover { text-decoration: underline; }

/* === Special Cases === */
.calcBox {
  border: 1px solid var(--card-border);
  background: #eee;
  text-align: center;
  padding: 3px;
  font-weight: bold;
  color: #000; /* always black */
}
body.dark-mode .calcBox {
  background-color: #ccc; /* darker background in dark mode */
  color: #000;            /* still black text */
}

/* Status colors */
.status-healthy { color: #008000; font-weight: bold; }
.status-bloody { color: orange; font-weight: bold; }
.status-incapacitated { color: red; font-weight: bold; }
