383 lines
16 KiB
HTML
383 lines
16 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=390, initial-scale=1">
|
|
<title>Kalei — Session Reflection</title>
|
|
<link rel="stylesheet" href="../../assets/design-system.css">
|
|
<style>
|
|
.summary-card {
|
|
background: var(--kalei-navy);
|
|
border: 1px solid var(--twilight);
|
|
border-radius: var(--radius-xl);
|
|
padding: var(--space-4);
|
|
margin-bottom: var(--space-4);
|
|
}
|
|
.summary-stats {
|
|
display: flex;
|
|
gap: var(--space-3);
|
|
margin-bottom: var(--space-4);
|
|
}
|
|
.summary-stat {
|
|
flex: 1;
|
|
background: var(--deep-glass);
|
|
border-radius: var(--radius-lg);
|
|
padding: var(--space-3);
|
|
text-align: center;
|
|
}
|
|
.summary-stat-value {
|
|
font-family: var(--font-display);
|
|
font-size: 22px;
|
|
font-weight: 700;
|
|
color: var(--pure-light);
|
|
}
|
|
.summary-stat-label {
|
|
font-size: 10px;
|
|
color: var(--dim-light);
|
|
text-transform: uppercase;
|
|
letter-spacing: 0.05em;
|
|
margin-top: 2px;
|
|
}
|
|
.fragments-found {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: var(--space-2);
|
|
flex-wrap: wrap;
|
|
}
|
|
.fragments-found-label {
|
|
font-size: 12px;
|
|
color: var(--dim-light);
|
|
margin-right: var(--space-1);
|
|
}
|
|
.frag-chip {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
gap: 4px;
|
|
height: 24px;
|
|
padding: 0 9px;
|
|
border-radius: var(--radius-full);
|
|
font-size: 11px;
|
|
font-weight: 500;
|
|
background: rgba(245,158,11,0.12);
|
|
color: var(--amber-light);
|
|
border: 1px solid rgba(245,158,11,0.2);
|
|
}
|
|
/* Mood check */
|
|
.mood-section {
|
|
margin-bottom: var(--space-4);
|
|
}
|
|
.mood-label {
|
|
font-size: 14px;
|
|
font-weight: 500;
|
|
color: var(--soft-light);
|
|
margin-bottom: var(--space-3);
|
|
}
|
|
.mood-options {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
gap: var(--space-2);
|
|
}
|
|
.mood-option {
|
|
flex: 1;
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
gap: 6px;
|
|
padding: var(--space-2) 0;
|
|
border-radius: var(--radius-md);
|
|
cursor: pointer;
|
|
border: 1px solid transparent;
|
|
transition: all 0.15s;
|
|
}
|
|
.mood-option.selected {
|
|
background: rgba(245,158,11,0.08);
|
|
border-color: rgba(245,158,11,0.3);
|
|
}
|
|
.mood-option-label {
|
|
font-size: 10px;
|
|
color: var(--dim-light);
|
|
}
|
|
/* Themes */
|
|
.themes-row {
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
gap: var(--space-2);
|
|
margin-top: var(--space-2);
|
|
}
|
|
.theme-chip {
|
|
display: inline-flex;
|
|
align-items: center;
|
|
height: 28px;
|
|
padding: 0 12px;
|
|
border-radius: var(--radius-full);
|
|
font-size: 12px;
|
|
font-weight: 500;
|
|
background: var(--deep-glass);
|
|
color: var(--soft-light);
|
|
border: 1px solid var(--twilight);
|
|
}
|
|
.btn-save-session {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
height: 52px;
|
|
background: var(--amber);
|
|
color: var(--void);
|
|
font-size: 16px;
|
|
font-weight: 600;
|
|
border-radius: var(--radius-lg);
|
|
text-decoration: none;
|
|
box-shadow: var(--glow-amber);
|
|
margin-bottom: var(--space-3);
|
|
transition: all 0.2s ease-out;
|
|
}
|
|
.btn-save-session:hover { background: var(--amber-light); box-shadow: 0 0 28px rgba(245,158,11,0.4); }
|
|
.amber-aura {
|
|
position: absolute;
|
|
top: 30%;
|
|
left: 50%;
|
|
transform: translate(-50%, -50%);
|
|
width: 200px;
|
|
height: 200px;
|
|
border-radius: 50%;
|
|
background: radial-gradient(circle, rgba(245,158,11,0.1) 0%, transparent 70%);
|
|
filter: blur(40px);
|
|
animation: breathing 6s ease-in-out infinite;
|
|
pointer-events: none;
|
|
z-index: 0;
|
|
}
|
|
</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;">Session Reflection</span>
|
|
<span style="font-size:11px; color:var(--dim-light);">Feb 21 — Evening</span>
|
|
</div>
|
|
<span class="nav-action"></span>
|
|
</div>
|
|
|
|
<div class="screen-content" style="padding-bottom: 24px; position: relative;">
|
|
<div class="amber-aura"></div>
|
|
|
|
<div class="mt-3" style="position:relative;z-index:1;">
|
|
|
|
<!-- Summary stats -->
|
|
<div class="summary-card">
|
|
<div class="summary-stats">
|
|
<div class="summary-stat">
|
|
<div class="summary-stat-value">12</div>
|
|
<div class="summary-stat-label">Minutes</div>
|
|
</div>
|
|
<div class="summary-stat">
|
|
<div class="summary-stat-value">847</div>
|
|
<div class="summary-stat-label">Words</div>
|
|
</div>
|
|
<div class="summary-stat">
|
|
<div class="summary-stat-value" style="color: var(--amber-light);">3</div>
|
|
<div class="summary-stat-label">Fragments</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="label text-dim mb-2">Fragments Detected</div>
|
|
<div class="fragments-found">
|
|
<!-- Mind Reading — hexagonal head with inner diamond (icons-distortions.svg) -->
|
|
<span class="frag-chip">
|
|
<svg width="10" height="10" viewBox="-12 -12 24 24" fill="none">
|
|
<defs>
|
|
<linearGradient id="s19-amGr1" x1="0" y1="0" x2="0" y2="1">
|
|
<stop offset="0%" stop-color="#FDE68A"/>
|
|
<stop offset="100%" stop-color="#D97706"/>
|
|
</linearGradient>
|
|
</defs>
|
|
<path d="M 0,-10 L 8,-5 L 8,5 L 0,10 L -8,5 L -8,-5 Z" fill="none" stroke="#F59E0B" stroke-width="1" opacity="0.7"/>
|
|
<path d="M 0,-4 L 4,0 L 0,4 L -4,0 Z" fill="url(#s19-amGr1)" opacity="0.8"/>
|
|
<path d="M 0,-4 L 4,0 L -4,0 Z" fill="#fff" opacity="0.15"/>
|
|
</svg>
|
|
Mind Reading
|
|
</span>
|
|
<!-- Catastrophizing — cascading shard (icons-distortions.svg) -->
|
|
<span class="frag-chip">
|
|
<svg width="10" height="10" viewBox="-12 -12 24 24" fill="none">
|
|
<defs>
|
|
<linearGradient id="s19-amGr2" x1="0" y1="0" x2="0" y2="1">
|
|
<stop offset="0%" stop-color="#FDE68A"/>
|
|
<stop offset="100%" stop-color="#D97706"/>
|
|
</linearGradient>
|
|
</defs>
|
|
<path d="M 0,-10 L 5,0 L 0,10 L -5,0 Z" fill="url(#s19-amGr2)" opacity="0.9"/>
|
|
<path d="M 0,-10 L 5,0 L -5,0 Z" fill="#fff" opacity="0.15"/>
|
|
<path d="M -8,6 L -5,10 L -9,12 L -11,8 Z" fill="#F59E0B" opacity="0.5"/>
|
|
<path d="M 7,8 L 10,12 L 8,14 L 5,11 Z" fill="#F59E0B" opacity="0.4"/>
|
|
</svg>
|
|
Catastrophizing
|
|
</span>
|
|
<!-- Should Statements — rigid ruler/bracket (icons-distortions.svg) -->
|
|
<span class="frag-chip">
|
|
<svg width="10" height="10" viewBox="-12 -12 24 24" fill="none">
|
|
<path d="M -6,-10 L -6,10 L 6,10" fill="none" stroke="#F59E0B" stroke-width="1.2" stroke-linejoin="miter"/>
|
|
<line x1="-6" y1="-6" x2="-3" y2="-6" stroke="#FCD34D" stroke-width="0.6" opacity="0.5"/>
|
|
<line x1="-6" y1="-2" x2="-3" y2="-2" stroke="#FCD34D" stroke-width="0.6" opacity="0.5"/>
|
|
<line x1="-6" y1="2" x2="-3" y2="2" stroke="#FCD34D" stroke-width="0.6" opacity="0.5"/>
|
|
<line x1="-6" y1="6" x2="-3" y2="6" stroke="#FCD34D" stroke-width="0.6" opacity="0.5"/>
|
|
<path d="M 2,-4 L 3,-1 L 1,-1 Z" fill="#FCD34D" opacity="0.6"/>
|
|
<circle cx="2" cy="1" r="0.8" fill="#FCD34D" opacity="0.6"/>
|
|
</svg>
|
|
Should Statements
|
|
</span>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Mood check -->
|
|
<div class="mood-section">
|
|
<div class="subheading text-pure mb-3">How are you feeling now?</div>
|
|
<div class="mood-options">
|
|
|
|
<!-- Mood 1: Settled (small nested diamond) -->
|
|
<div class="mood-option" onclick="selectMood(this)">
|
|
<svg width="32" height="32" viewBox="0 0 32 32">
|
|
<path d="M16 4L26 16L16 28L6 16Z" fill="var(--twilight)" stroke="var(--faint-light)" stroke-width="1" fill-opacity="0.5"/>
|
|
<path d="M16 10L22 16L16 22L10 16Z" fill="var(--emerald)" opacity="0.5"/>
|
|
</svg>
|
|
<span class="mood-option-label">Settled</span>
|
|
</div>
|
|
|
|
<!-- Mood 2: Lighter (rising diamond) -->
|
|
<div class="mood-option" onclick="selectMood(this)">
|
|
<svg width="32" height="32" viewBox="0 0 32 32">
|
|
<path d="M16 8L24 16L16 24L8 16Z" fill="var(--sapphire)" opacity="0.3" stroke="var(--sapphire-light)" stroke-width="1"/>
|
|
<path d="M16 4L20 8" stroke="var(--sapphire-light)" stroke-width="1.5" stroke-linecap="round"/>
|
|
<path d="M12 4L16 8" stroke="var(--sapphire-light)" stroke-width="1" stroke-linecap="round" opacity="0.5"/>
|
|
<path d="M20 4L24 8" stroke="var(--sapphire-light)" stroke-width="1" stroke-linecap="round" opacity="0.5"/>
|
|
</svg>
|
|
<span class="mood-option-label">Lighter</span>
|
|
</div>
|
|
|
|
<!-- Mood 3: Neutral (balanced diamond) -->
|
|
<div class="mood-option selected" onclick="selectMood(this)">
|
|
<svg width="32" height="32" viewBox="0 0 32 32">
|
|
<path d="M16 6L26 16L16 26L6 16Z" fill="var(--amber)" opacity="0.2" stroke="var(--amber-light)" stroke-width="1.2"/>
|
|
<line x1="10" y1="16" x2="22" y2="16" stroke="var(--amber-light)" stroke-width="1.5" stroke-linecap="round"/>
|
|
</svg>
|
|
<span class="mood-option-label" style="color:var(--amber-light);">Neutral</span>
|
|
</div>
|
|
|
|
<!-- Mood 4: Heavy (dense diamond) -->
|
|
<div class="mood-option" onclick="selectMood(this)">
|
|
<svg width="32" height="32" viewBox="0 0 32 32">
|
|
<path d="M16 6L26 16L16 26L6 16Z" fill="var(--amethyst)" opacity="0.25" stroke="var(--amethyst-light)" stroke-width="1"/>
|
|
<path d="M16 10L22 16L16 22L10 16Z" fill="var(--amethyst)" opacity="0.3"/>
|
|
<path d="M16 13L19 16L16 19L13 16Z" fill="var(--amethyst)" opacity="0.6"/>
|
|
</svg>
|
|
<span class="mood-option-label">Heavy</span>
|
|
</div>
|
|
|
|
<!-- Mood 5: Turbulent (spiky diamond) -->
|
|
<div class="mood-option" onclick="selectMood(this)">
|
|
<svg width="32" height="32" viewBox="0 0 32 32">
|
|
<path d="M16 4L20 12L28 12L22 18L24 26L16 22L8 26L10 18L4 12L12 12Z" fill="var(--ruby)" opacity="0.2" stroke="var(--ruby)" stroke-width="0.8"/>
|
|
</svg>
|
|
<span class="mood-option-label">Turbulent</span>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Key themes -->
|
|
<div class="mb-4">
|
|
<div class="section-header">
|
|
<span class="section-title">Key Themes</span>
|
|
</div>
|
|
<div class="themes-row">
|
|
<span class="theme-chip">Public speaking anxiety</span>
|
|
<span class="theme-chip">Manager judgment</span>
|
|
<span class="theme-chip">Self-criticism</span>
|
|
<span class="theme-chip">Freeze response</span>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- The Guide noticed section -->
|
|
<div style="position: relative; border-radius: var(--radius-lg); margin-bottom: var(--space-4);">
|
|
<!-- Prismatic gradient border -->
|
|
<div style="position: absolute; inset: -1px; border-radius: var(--radius-lg); background: linear-gradient(135deg, #8B5CF6, #3B82F6, #10B981, #F59E0B, #EC4899, #8B5CF6); z-index: 0; background-size: 300% 300%; animation: prismaticShift 6s ease-in-out infinite;"></div>
|
|
<div style="position: relative; z-index: 1; background: var(--kalei-navy); border-radius: calc(var(--radius-lg) - 1px); padding: var(--space-4);">
|
|
<div style="display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3);">
|
|
<!-- 6-blade kaleidoscope icon -->
|
|
<svg width="16" height="16" viewBox="0 0 16 16" fill="none">
|
|
<defs>
|
|
<linearGradient id="s19-guideGrad" x1="0" y1="0" x2="1" y2="1">
|
|
<stop offset="0%" stop-color="#8B5CF6"/>
|
|
<stop offset="50%" stop-color="#3B82F6"/>
|
|
<stop offset="100%" stop-color="#10B981"/>
|
|
</linearGradient>
|
|
</defs>
|
|
<polygon points="8,1 15,8 8,15 1,8" fill="none" stroke="url(#s19-guideGrad)" stroke-width="1.5" stroke-linejoin="round"/>
|
|
<circle cx="8" cy="8" r="2" fill="url(#s19-guideGrad)" opacity="0.7"/>
|
|
</svg>
|
|
<span style="font-family: var(--font-display); font-size: 13px; font-weight: 600; color: var(--soft-light); text-transform: uppercase; letter-spacing: 0.06em;">The Guide noticed...</span>
|
|
</div>
|
|
<p style="font-size: 13px; color: var(--dim-light); line-height: 1.6; margin-bottom: var(--space-2);">Today's session connects to your Lens goal <span style="color: var(--emerald-light); font-weight: 500;">"Present with confidence"</span>. The Mind Reading pattern you named — assuming your manager's verdict — is the exact thought that derails you before presentations begin.</p>
|
|
<p style="font-size: 13px; color: var(--dim-light); line-height: 1.6; margin-bottom: var(--space-3);">Your if-then plan for this goal is ready to rehearse. <span style="color: var(--emerald-light); font-weight: 500;">14-day streak</span> — you're building something real.</p>
|
|
<a href="../lens/20-lens-dashboard.html" style="font-size: 13px; font-weight: 500; color: var(--emerald-light); text-decoration: none; display: inline-flex; align-items: center; gap: 4px; transition: opacity 0.2s ease-out;">Check your Lens goals
|
|
<svg width="12" height="12" viewBox="0 0 12 12" fill="none">
|
|
<path d="M4 2l4 4-4 4" stroke="currentColor" stroke-width="1.3" stroke-linecap="round" stroke-linejoin="round"/>
|
|
</svg>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Actions -->
|
|
<a href="#" class="btn-save-session" onclick="this.textContent='Saved'; return false;">
|
|
Save session
|
|
</a>
|
|
<a href="../turn/10-turn-home.html" class="btn btn-secondary" style="text-decoration:none;">
|
|
Start a Turn
|
|
</a>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<script>
|
|
function selectMood(el) {
|
|
document.querySelectorAll('.mood-option').forEach(o => {
|
|
o.classList.remove('selected');
|
|
o.querySelector('.mood-option-label').style.color = '';
|
|
});
|
|
el.classList.add('selected');
|
|
el.querySelector('.mood-option-label').style.color = 'var(--amber-light)';
|
|
}
|
|
</script>
|
|
</body>
|
|
</html>
|