* { 
  box-sizing: border-box; 
  margin: 0; 
  cursor: none !important; /* Hide all system cursors */
}

/* Additional cursor hiding for specific elements */
a, button, input, textarea, select, [role="button"], [tabindex] {
  cursor: none !important;
}

/* Force cursor hiding on all interactive elements */
*:hover, *:focus, *:active {
  cursor: none !important;
}
html, body { height: 100%; overflow: hidden; }
body { 
  font-family: 'Guyot Press', 'Georgia', serif; 
  background-color: #0002AA; /* Static blue background */
}



@font-face {
  font-family: 'Nautica';
  src: url('./fonts/Nautica Medium.otf') format('opentype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Guyot Press';
  src: url('./fonts/Guyot-Press-Regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Guyot Press';
  src: url('./fonts/Guyot-Press-Italic.otf') format('opentype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: 'Guyot Headline';
  src: url('./fonts/Guyot-Headline-Regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'Guyot Headline';
  src: url('./fonts/Guyot-Headline-Bold.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

.split { display: grid; grid-template-columns: 60% 40%; width: 100vw; height: 100vh; height: 100dvh; }
.col-left { background: transparent; position: relative; }
.col-right { background: #F8F3E7; }
.right-categories {
  padding: 40px;
}
.col-right .cat-title { color: #111; }
.col-right .cat-text { color: #111; opacity: 0.9; }

.right-top-bar {
  position: fixed;
  top: 0;
  right: 0;
  width: 40%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;
  padding: 40px;
  color: #111;
  font-family: 'Guyot Press', 'Georgia', serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.4;
  z-index: 10000;
  pointer-events: auto;
}
.right-top-bar .work { 
  justify-self: start; 
  text-decoration: none; 
  font-style: italic; 
  text-transform: uppercase; 
  padding: 10px;
  margin: -10px;
}
.right-top-bar .musings { 
  justify-self: end; 
  text-decoration: none; 
  font-style: italic; 
  text-transform: uppercase; 
  padding: 10px;
  margin: -10px;
}
.right-top-bar a { transition: color 0.2s ease; position: relative; z-index: 10001; }
.right-top-bar a:hover { color: #85774B; }

.left-top-bar {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;
  padding: 40px;
  color: #ffffff;
  font-family: 'Guyot Press', 'Georgia', serif;
  font-weight: 400;
  font-size: 14px;
  line-height: 1.4;
}
.left-top-bar #clock { justify-self: start; opacity: 0.95; }
.left-top-bar .location { justify-self: end; opacity: 0.95; }

.left-stack {
  position: absolute;
  left: 0;
  right: 0;
  top: 55%;
  transform: translateY(-50%);
  pointer-events: none;
}
.left-stack .name {
  color: #ffffff;
  font-family: 'Nautica', 'Arial', sans-serif;
  font-size: 110px;
  font-weight: 500;
  letter-spacing: 0px;
  text-align: center;
  width: 100%;
  pointer-events: auto;
  transition: color 0.25s ease;
  position: relative;
  z-index: 1;
  font-feature-settings: "liga" 1, "dlig" 1;
  font-variant-ligatures: common-ligatures discretionary-ligatures;
}
.left-stack .name:hover { color: #85774B; }
.left-stack .tagline {
  margin-top: -25px;
  color: #ffffff;
  opacity: 0.9;
  text-align: center;
  font-family: 'Guyot Press', 'Georgia', serif;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.2;
  position: relative;
  z-index: 2; /* above the name */
}
.left-stack .bio {
  max-width: 900px;
  color: #ffffff;
  opacity: 0.9;
  font-family: 'Guyot Press', 'Georgia', serif; /* same as clock */
  font-weight: 400;
  font-size: 16px;
  line-height: 1.3;
  text-align: left;
  padding-left: 40px; /* match clock left padding */
  margin: 40px auto 0;
}
.left-stack .bio, .left-categories { pointer-events: auto; }
.left-stack .bio a {
  color: #ffffff;
  font-style: italic;
  text-transform: uppercase;
  text-decoration: none;
  transition: color 0.2s ease;
  position: relative;
}
.left-stack .bio a:hover { color: #85774B; }
.left-stack .bio a::after,
.cat-text a::after {
  content: "↗";
  position: absolute;
  top: 0;
  left: 100%;
  margin-left: 6px;
  color: currentColor;
  font-family: system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  font-weight: 600;
  opacity: 0;
  transition: opacity 0.2s ease, color 0.2s ease;
}
.left-stack .bio a:hover::after,
.cat-text a:hover::after {
  opacity: 1;
}

.left-categories {
  display: grid;
  grid-template-columns: 1fr 1fr; /* left col groups stack; right col holds Things I Do */
  gap: 16px 32px;
  max-width: 900px;
  padding: 0 40px;
  margin: 40px auto 0;
}
.left-categories .left-col { display: grid; gap: 16px; }
.left-categories .right-col { align-self: start; display: grid; gap: 24px; }
.cat-title {
  color: #ffffff;
  font-family: 'Guyot Press', 'Georgia', serif;
  font-weight: 200;
  font-style: italic;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.cat-text {
  color: #ffffff;
  opacity: 0.9;
  font-family: 'Guyot Press', 'Georgia', serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.3;
}
.cat-text a { color: inherit; text-decoration: underline; transition: color 0.2s ease; position: relative; }
.col-right .cat-text a { color: #111; }
.cat-text a:hover { color: #85774B; }

.draggable-box {
  position: absolute;
  cursor: grab;
  user-select: none;
  z-index: 1000;
  left: 80vw;
  transform: translateX(-50%);
  transition: left 0.2s ease-out, top 0.2s ease-out, transform 0.2s ease-out;
}

.draggable-box.dragging {
  transition: none;
}



.projects-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 999;
  pointer-events: none;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 40px;
  padding-bottom: 500px;
}

.projects-container::-webkit-scrollbar {
  display: none;
}

.projects-container .draggable-box {
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Guyot Headline', 'Georgia', serif;
  font-size: 24px;
  font-weight: 700;
  color: #ffffff;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.5);
}

.projects-container .draggable-box:nth-child(1) {
  background: radial-gradient(circle at 30% 20%, #0002AA 0%, #000000 60%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(2) {
  background: radial-gradient(circle at 70% 80%, #0002AA 0%, #000000 95%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(3) {
  background: radial-gradient(circle at 20% 60%, #0002AA 0%, #000000 75%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(4) {
  background: radial-gradient(circle at 80% 30%, #0002AA 0%, #000000 98%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(5) {
  background: radial-gradient(circle at 40% 70%, #0002AA 0%, #000000 70%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(6) {
  background: radial-gradient(circle at 60% 40%, #0002AA 0%, #000000 85%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(7) {
  background: radial-gradient(circle at 20% 50%, #0002AA 0%, #000000 90%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(8) {
  background: radial-gradient(circle at 90% 10%, #0002AA 0%, #000000 80%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(9) {
  background: radial-gradient(circle at 50% 90%, #0002AA 0%, #000000 88%);
  border-radius: 8px;
}

.projects-container .draggable-box:nth-child(10) {
  pointer-events: auto;
  background: radial-gradient(circle at 25% 80%, #0002AA 0%, #000000 92%);
  border-radius: 8px;
}






