220 lines
9.0 KiB
HTML
220 lines
9.0 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=390, initial-scale=1">
|
|
<title>Kalei — Mirror Session</title>
|
|
<link rel="stylesheet" href="../../assets/design-system.css">
|
|
<style>
|
|
.chat-area {
|
|
flex: 1;
|
|
overflow-y: auto;
|
|
padding: var(--space-4) var(--space-4) var(--space-2);
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
.chat-area::-webkit-scrollbar { display: none; }
|
|
.chat-session-frame {
|
|
display: flex;
|
|
flex-direction: column;
|
|
height: calc(var(--device-height) - var(--status-bar-height) - var(--nav-header-height) - 64px);
|
|
}
|
|
.input-accessory {
|
|
height: 64px;
|
|
background: var(--kalei-navy);
|
|
border-top: 1px solid var(--twilight);
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--space-2);
|
|
padding: 0 var(--space-3);
|
|
flex-shrink: 0;
|
|
}
|
|
.chat-input {
|
|
flex: 1;
|
|
height: 40px;
|
|
background: var(--deep-glass);
|
|
border: 1px solid var(--twilight);
|
|
border-radius: var(--radius-full);
|
|
padding: 0 var(--space-4);
|
|
font-family: var(--font-primary);
|
|
font-size: 15px;
|
|
color: var(--pure-light);
|
|
outline: none;
|
|
}
|
|
.chat-input::placeholder { color: var(--faint-light); }
|
|
.send-btn {
|
|
width: 40px;
|
|
height: 40px;
|
|
border-radius: 50%;
|
|
background: var(--amber);
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
cursor: pointer;
|
|
border: none;
|
|
flex-shrink: 0;
|
|
box-shadow: var(--glow-amber);
|
|
transition: all 0.2s ease-out;
|
|
text-decoration: none;
|
|
}
|
|
.send-btn:hover { background: var(--amber-light); box-shadow: 0 0 24px rgba(245,158,11,0.5); }
|
|
.ai-thinking {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 4px;
|
|
padding: var(--space-2) var(--space-3);
|
|
margin-bottom: var(--space-3);
|
|
width: 56px;
|
|
background: var(--kalei-navy);
|
|
border: 1px solid var(--twilight);
|
|
border-radius: var(--radius-xl);
|
|
border-bottom-left-radius: var(--space-1);
|
|
}
|
|
.thinking-dot {
|
|
width: 6px;
|
|
height: 6px;
|
|
border-radius: 50%;
|
|
background: var(--amber);
|
|
animation: thinkingPulse 1.2s ease-in-out infinite;
|
|
}
|
|
.thinking-dot:nth-child(2) { animation-delay: 0.2s; }
|
|
.thinking-dot:nth-child(3) { animation-delay: 0.4s; }
|
|
@keyframes thinkingPulse {
|
|
0%, 80%, 100% { opacity: 0.3; transform: scale(0.8); }
|
|
40% { opacity: 1; transform: scale(1); }
|
|
}
|
|
.session-timer {
|
|
font-size: 12px;
|
|
color: var(--dim-light);
|
|
font-variant-numeric: tabular-nums;
|
|
}
|
|
.nav-close {
|
|
width: 32px;
|
|
height: 32px;
|
|
border-radius: 50%;
|
|
background: var(--deep-glass);
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
cursor: pointer;
|
|
text-decoration: none;
|
|
transition: background 0.2s ease-out;
|
|
}
|
|
.nav-close:hover { background: var(--twilight); }
|
|
</style>
|
|
</head>
|
|
<body>
|
|
<div class="device-frame">
|
|
|
|
<div class="status-bar">
|
|
<span class="time">9:41</span>
|
|
<div class="icons">
|
|
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
<rect x="1" y="7" width="2.5" height="5" rx="0.5" fill="#E2E8F0" opacity="0.4"/>
|
|
<rect x="4.5" y="5" width="2.5" height="7" rx="0.5" fill="#E2E8F0" opacity="0.6"/>
|
|
<rect x="8" y="3" width="2.5" height="9" rx="0.5" fill="#E2E8F0" opacity="0.8"/>
|
|
<rect x="11.5" y="1" width="2.5" height="11" rx="0.5" fill="#E2E8F0"/>
|
|
</svg>
|
|
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
<path d="M 2,8 C 4,4 12,4 14,8" stroke="#E2E8F0" stroke-width="1.2" fill="none" stroke-linecap="round"/>
|
|
<path d="M 4,10 C 6,7 10,7 12,10" stroke="#E2E8F0" stroke-width="1" fill="none" opacity="0.8" stroke-linecap="round"/>
|
|
<circle cx="8" cy="12" r="1.2" fill="#E2E8F0"/>
|
|
</svg>
|
|
<svg width="24" height="12" viewBox="0 0 24 12" fill="none">
|
|
<rect x="0.5" y="0.5" width="21" height="11" rx="2.5" stroke="#E2E8F0" stroke-width="1" opacity="0.5"/>
|
|
<rect x="22" y="3" width="2" height="6" rx="1" fill="#E2E8F0" opacity="0.3"/>
|
|
<rect x="2" y="2" width="16" height="8" rx="1.5" fill="#10B981" opacity="0.9"/>
|
|
</svg>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="nav-header">
|
|
<a class="nav-back" href="15-mirror-home.html">
|
|
<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
<path d="M12 4L6 10L12 16" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
|
|
</svg>
|
|
</a>
|
|
<div style="display:flex; flex-direction:column; align-items:center; position:absolute; left:50%; transform:translateX(-50%);">
|
|
<span class="nav-title" style="position:static; transform:none;">Mirror Session</span>
|
|
<span class="session-timer" id="timer">0:00</span>
|
|
</div>
|
|
<a class="nav-close" href="19-mirror-reflection.html">
|
|
<svg width="14" height="14" viewBox="0 0 14 14" fill="none">
|
|
<path d="M2 2L12 12M12 2L2 12" stroke="var(--dim-light)" stroke-width="1.5" stroke-linecap="round"/>
|
|
</svg>
|
|
</a>
|
|
</div>
|
|
|
|
<div class="chat-session-frame">
|
|
<div class="chat-area">
|
|
|
|
<!-- AI opening -->
|
|
<div class="chat-bubble ai" style="animation: fadeIn 0.4s ease-out;">
|
|
Welcome back. I'm here to listen and reflect with you. What's on your mind today? There's no right way to start — just begin wherever feels natural.
|
|
</div>
|
|
|
|
<!-- User message 1 -->
|
|
<div class="chat-bubble user" style="animation: fadeIn 0.4s ease-out 0.1s both; opacity:0;">
|
|
I gave this big presentation today to the whole department — the quarterly results. I completely bombed it. I lost my place twice, my voice was shaking, and I could see people checking their phones. I just fell apart in front of everyone.
|
|
</div>
|
|
|
|
<!-- AI response 1 -->
|
|
<div class="chat-bubble ai" style="animation: fadeIn 0.4s ease-out 0.2s both; opacity:0;">
|
|
That sounds like a really unsettling experience — the kind where you're in the middle of it and every small thing feels amplified. When you say you "completely bombed it," what actually happened from start to finish?
|
|
</div>
|
|
|
|
<!-- User message 2 -->
|
|
<div class="chat-bubble user" style="animation: fadeIn 0.4s ease-out 0.3s both; opacity:0;">
|
|
I mean I got through it, technically. But I stumbled on the revenue slide, and my manager was in the front row. She had this expression — I could tell she was embarrassed for me. She probably thinks I'm incompetent now. I always freeze under pressure. I'm just not someone who can handle this kind of visibility.
|
|
</div>
|
|
|
|
<!-- AI response 2 -->
|
|
<div class="chat-bubble ai" style="animation: fadeIn 0.4s ease-out 0.4s both; opacity:0;">
|
|
I want to stay with something you said — that you got through it. Then you moved to your manager's expression, then to what she must be thinking, then to a conclusion about who you are as a person. That's a lot of ground covered in a few seconds. What do you actually know about her reaction, versus what you're filling in?
|
|
</div>
|
|
|
|
<!-- User message 3 -->
|
|
<div class="chat-bubble user" style="animation: fadeIn 0.4s ease-out 0.5s both; opacity:0;">
|
|
Honestly, I don't know what she was actually thinking. She asked a question at the end about the margin numbers — that could mean anything. I just immediately jumped to the worst interpretation. I always do that.
|
|
</div>
|
|
|
|
<!-- AI response 3 -->
|
|
<div class="chat-bubble ai" style="animation: fadeIn 0.4s ease-out 0.6s both; opacity:0;">
|
|
Notice that shift you just made — from "she probably thinks I'm incompetent" to "I don't actually know what she was thinking." That move, right there, is what we're working on. The first version is a story. The second version is honest. Which one do you want to act from?
|
|
</div>
|
|
|
|
<!-- AI thinking indicator -->
|
|
<div class="ai-thinking" style="animation: fadeIn 0.4s ease-out 0.7s both; opacity:0;">
|
|
<div class="thinking-dot"></div>
|
|
<div class="thinking-dot"></div>
|
|
<div class="thinking-dot"></div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<!-- Input accessory bar -->
|
|
<div class="input-accessory">
|
|
<input class="chat-input" type="text" placeholder="Write freely...">
|
|
<a class="send-btn" href="17-mirror-fragment-highlight.html">
|
|
<svg width="18" height="18" viewBox="0 0 18 18" fill="none">
|
|
<path d="M15 9L3 4L5.5 9L3 14L15 9Z" fill="var(--void)" stroke="none"/>
|
|
</svg>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<script>
|
|
let seconds = 0;
|
|
const timerEl = document.getElementById('timer');
|
|
setInterval(() => {
|
|
seconds++;
|
|
const m = Math.floor(seconds / 60);
|
|
const s = seconds % 60;
|
|
timerEl.textContent = m + ':' + String(s).padStart(2, '0');
|
|
}, 1000);
|
|
</script>
|
|
</body>
|
|
</html>
|