// Swiss design language v2 - Home + Map
// Single hot accent (#FF4D2E), strict grid, big sans, mono for data.
const PHONE_W = 390;
const PHONE_H = 844;
function StatusBar({ time = '14:32', dark = false }) {
const fg = dark ? '#FFFFFF' : '#000000';
return (
{time}
{/* signal */}
{/* wifi */}
{/* battery */}
);
}
function HomeIndicator({ dark = false }) {
return (
);
}
function Frame({ children, dark = false, time = '14:32', bg }) {
return (
{children}
);
}
const SWISS_ACCENT = '#FF4D2E';
const SWISS_INK = '#000000';
const SWISS_PAPER = '#FFFFFF';
const SWISS_GREY_3 = '#888888';
const SWISS_GREY_2 = '#BBBBBB';
const SWISS_GREY_1 = '#E5E5E5';
const SWISS_RULE = '#000000';
// Real photo avatars via Unsplash - round, with optional ring.
// Photo IDs are stable Unsplash IDs of friendly portraits.
const SWISS_PHOTOS = [
// Female-presenting
'photo-1494790108377-be9c29b29330', // young woman, smile
'photo-1438761681033-6461ffad8d80', // young woman, blonde
'photo-1544005313-94ddf0286df2', // young woman, dark hair
'photo-1487412720507-e7ab37603c6f', // woman, brown hair
// Male-presenting
'photo-1500648767791-00dcc994a43e', // young man, friendly
'photo-1472099645785-5658abf4ff4e', // young man, beard
'photo-1507003211169-0a1dd7228f2d', // young man, glasses
];
function SwissAvatar({ variant = 0, size = 32, ring = 'none' /* 'none' | 'ink' | 'accent' */ }) {
const id = SWISS_PHOTOS[variant % SWISS_PHOTOS.length];
const url = `https://images.unsplash.com/${id}?w=160&h=160&fit=crop&crop=faces&q=70`;
const ringPx = ring === 'none' ? 0 : 2;
const ringColor = ring === 'accent' ? SWISS_ACCENT : SWISS_INK;
return (
);
}
// Map kind glyph - round, illustrated, character-driven (kept for reference / unused)
function SwissKindGlyph() { return null; }
window.SwissAvatar = SwissAvatar;
window.SwissKindGlyph = SwissKindGlyph;
// ─── Shared bits ──────────────────────────────────────────────
function SwissMast({ dark = false }) {
const ink = dark ? '#FFF' : SWISS_INK;
return (
Wir. Raus.
14.05.26 / 14:32 / DO
);
}
function Rule({ heavy = false, color = SWISS_RULE }) {
return ;
}
// ─── HOME (extended) ──────────────────────────────────────────
function Swiss_Home() {
return (
{/* Section label */}
Heute / DonnerstagAusgabe 142
{/* Hero number - Swiss poster move */}
22
Orte für heute Nachmittag.
{/* Tiny corner label */}
im radius 4,6 km
{/* Subtitle / rationale */}
18° und sonnig, leichter Westwind. Drei Buddys sind unterwegs. Drei kuratierte Vorschläge wenn du jetzt los willst.