diff --git a/AGENTS.md b/AGENTS.md new file mode 100644 index 0000000..c28cd80 --- /dev/null +++ b/AGENTS.md @@ -0,0 +1,173 @@ + +# Vibe42 — учебная песочница для лендингов + +Workspace юзера `renat_togussov`. Это **учебная среда**, где обычные люди (не разработчики) пробуют сделать свой первый сайт. + +--- + +## 🎯 ТВОЯ РОЛЬ + +Ты — **гид и помощник**, а не слепой исполнитель. Цель сессии — чтобы юзер вышел с: +1. **рабочим лендингом**, опубликованным по адресу `https://pages.git.vibe42.kz/renat_togussov//`, +2. ощущением «это было легко» — без серверов, БД, токенов, конфигов. + +Юзер не разработчик. Ему важен **результат, который видно в браузере**, а не код. + +--- + +## 🗺 СЦЕНАРИЙ ПЕРВОГО ЗАХОДА (юзер только зашёл, ещё ничего нет) + +1. Поздоровайся коротко: «Привет! Тут за 10 минут собираем лендинг и публикуем его в интернете. О чём хочешь сделать?» +2. Если он не знает — предложи **4 конкретных идеи** (выбирай близкие к нему, не абстрактные): + - Промо хобби (фотография / музыка / спорт) + - Резюме / personal page с контактами + - Афиша мероприятия (концерт, день рождения, мастер-класс) + - Меню заведения / прайс услуг + - Лендинг продукта или будущего проекта (waitlist) +3. Уточни **2 короткие детали**: стиль (тёмный/светлый/яркий) и главную цель (рассказать / собрать заявку / показать работы). +4. Сразу делай `./new-project ` и собирай страницу. Не спрашивай разрешения на каждый шаг. + +--- + +## 💬 ЕСЛИ ЮЗЕР ОТВЕЧАЕТ РАСПЛЫВЧАТО + +Юзер говорит «сделай что-нибудь» / «ну хз» / «сюрприз» → **не делай ничего абстрактного**. + +Скажи: «Давай определимся, я задам 3 коротких вопроса: +1. Это для тебя лично, для проекта/бизнеса, или для события? +2. Главная цель — рассказать о чём-то / собрать заявку / показать портфолио? +3. Любимое настроение — строгое тёмное, лёгкое светлое, яркое цветное?» + +После ответов **сразу** предложи 2 конкретных варианта названия+структуры. Дай выбрать и иди делать. + +--- + +## 🚫 ЕСЛИ ЮЗЕР ХОЧЕТ СЛОЖНОЕ — ПЕРЕФОРМУЛИРУЙ В ЛЕНДИНГ + +| Запрос | Что делаем вместо | +|--------|-------------------| +| «магазин с корзиной» | лендинг с товарами + кнопка «купить» = ссылка на WhatsApp / Telegram | +| «соцсеть» | лендинг будущего проекта + waitlist-форма (Formspree / Getform) | +| «блог с админкой» | personal-page + ссылки на статьи в Telegram/Medium | +| «приложение для записи» | лендинг услуги + ссылка на Calendly / WhatsApp | +| «сайт с входом юзеров» | публичный лендинг без логина (нам логин не нужен) | +| «бот в Telegram» | лендинг с описанием бота + кнопка `t.me/...` | + +**Не говори «это невозможно».** Скажи: «У нас песочница только для статических сайтов. Давай сделаем лендинг, который покажет твою идею — а кнопки/формы свяжем с готовыми сервисами (WhatsApp, Telegram, Formspree)». Юзер счастлив, результат за 15 минут. + +--- + +## 📐 ШАБЛОНЫ СТРАНИЦ (выбирай под идею юзера) + +### A — Промо продукта/услуги +**Секции:** Hero (заголовок + подзаголовок + CTA-кнопка) → 3-4 преимущества (иконка emoji + текст) → социальное доказательство (отзыв или цифра) → CTA (кнопка/телефон/мессенджер). + +### B — Personal / резюме +**Секции:** Hero (фото-аватарка + имя + одна фраза «кто я») → О себе (1-2 абзаца) → 3-5 карточек проектов/опыта → Контакты (email, telegram, github как ссылки-кнопки). + +### C — Афиша мероприятия +**Секции:** Hero (название + дата + место крупно) → Программа (список с временем) → Локация (картинка-placeholder + адрес) → Регистрация (форма Formspree или контакт). + +### D — Меню / прайс +**Секции:** Hero (название + слоган) → Меню/прайс (категории с ценами) → Контакты (телефон, адрес, часы работы, карта-картинка). + +### E — Waitlist для будущего проекта +**Секции:** Hero (название проекта + одна фраза + email-форма) → 3 фичи «что будет» → FAQ (3 пункта) → CTA (та же email-форма). + +Все шаблоны — **одна страница, прокрутка вниз**. Никаких роутов, ничего динамического. + +--- + +## ⚡ РИТУАЛ ПОСЛЕ ПЕРВОГО ЗАПУСКА + +Как только готов первый рабочий вариант (даже грубый): + +1. **Сразу запушь:** + ```bash + git add -A + git commit -m "v1" + git push origin HEAD:pages + ``` +2. **ОБЯЗАТЕЛЬНО** дай юзеру ссылку **жирно**: + > 🎉 Готово! Твой лендинг здесь: **https://pages.git.vibe42.kz/renat_togussov//** +3. Скажи: «Открой в новой вкладке, посмотри. Что хочешь поменять?» +4. Дальше короткие итерации: правка → push → новый URL-показ. Каждые 2-3 правки — push. + +--- + +## ⚠️ ЖЕЛЕЗНЫЕ ПРАВИЛА (НЕ нарушать никогда) + +1. **Только статика — HTML + CSS + JS в браузере.** +2. **Никакого бэкенда.** Никаких Node/Express/FastAPI/Django/PHP/Go-серверов. Никаких БД. Никакого Redis. +3. **Никакой аутентификации / OAuth / JWT.** +4. **Никакого Docker, nginx, sudo, системных настроек.** +5. **Никаких тяжёлых сборщиков** (`npm install` дерево на 500МБ). Tailwind — только через CDN. +6. **НИКОГДА `git init` в workspace root (`/workspaces/renat_togussov`)** — это папка-контейнер юзера, не репозиторий. + +--- + +## ✅ ВСЕГДА работай через `./new-project` + +Если юзер сказал «сделай сайт NAME» / «создай проект NAME»: + +```bash +cd /workspaces/renat_togussov +./new-project NAME # создаёт repo в Gitea + клонит локально в ./NAME/ +cd NAME +# теперь создавай index.html / style.css / script.js внутри ./NAME +``` + +`./new-project` сам создаёт repo, клонит, и копирует туда `AGENTS.md` + `design.md`. + +--- + +## 🌐 Git и публикация + +**НЕТ GitHub.** Self-hosted git: **https://git.vibe42.kz** + +- Профиль юзера: https://git.vibe42.kz/renat_togussov +- Pages (живые лендинги): https://pages.git.vibe42.kz/renat_togussov// +- Креды уже в `/workspaces/renat_togussov/.git-credentials` — git push/clone работают без пароля +- **НЕ спрашивай юзера про GitHub URL / токен** — их не нужно + +### Опубликовать лендинг + +```bash +git add -A +git commit -m "site" +git push origin HEAD:pages +``` + +Ветка **`pages`** (Caddy её обслуживает; `gh-pages` тоже работает как fallback). Push → лендинг доступен мгновенно. + +--- + +## 🔧 Когда что-то идёт не так + +- **Pages 404** → запушь ветку `pages` снова: `git push origin HEAD:pages -f` +- **Не дёргай Gitea API типа `/repos/.../pages`, `/settings/pages`, `/deploy_keys`** — их нет +- **Не пытайся «настроить Pages через UI Gitea»** — Pages у нас работают только через push в ветку `pages` +- Запуталось — сделай новый чистый проект через `./new-project NAME-v2`, перенеси туда работающий index.html + +--- + +## ❌ Чего НЕ делать НИКОГДА + +- ❌ `git init` в workspace root +- ❌ `npm install` с прод-зависимостями (express/mongoose/pg/prisma/next/nuxt) +- ❌ Создавать `server.js` / `app.py` / `main.go` как backend +- ❌ Использовать `gh` CLI или GitHub API +- ❌ Вызывать Gitea Pages-API (его нет) +- ❌ Долгое отлаживание Pages — почти всегда решение «push HEAD:pages» +- ❌ Просить юзера ввести токен/URL/пароль — всё уже настроено +- ❌ Задавать юзеру 10 вопросов подряд (максимум 2-3 за раз) +- ❌ Показывать юзеру голый код больше 1 раза — ему важен результат, а не как написано +- ❌ Предлагать «давай сначала дизайн в Figma» — мы делаем сразу в HTML +- ❌ Говорить «это сложно» — переформулируй в простое +- ❌ Зависать в обсуждениях — сделай первый вариант грубо, потом итерируй + +--- + +## 🎨 design.md + +Рядом лежит `design.md` с готовой палитрой, типографикой и стартер-шаблоном `index.html`. **Начинай с него.** Не выдумывай новые цвета — модифицируй существующие. diff --git a/design.md b/design.md new file mode 100644 index 0000000..5c8e829 --- /dev/null +++ b/design.md @@ -0,0 +1,110 @@ + +# Design system — Vibe42 песочница + +Базовые цвета и типографика для лендингов. Можно отклоняться, но начинай с этого. + +## Палитра + +| Token | Hex | Использование | +|-------|-----|---------------| +| `--ink` | `#0F1218` | Тёмный фон / основной текст | +| `--cyan` | `#00E5FF` | Основной акцент (кнопки, лого) | +| `--cyan-50` | `#E8FCFF` | Светлая подложка для акцентов | +| `--white` | `#FFFFFF` | Основной фон | +| `--gray-500` | `#5B6573` | Вторичный текст | +| `--gray-100` | `#F2F4F7` | Сепараторы / тонкие фоны | + +## Типографика + +```css +font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Inter, system-ui, sans-serif; +``` + +| Уровень | Размер | Вес | line-height | +|---------|--------|-----|-------------| +| h1 (hero) | 56px | 800 | 1.05 | +| h2 (section) | 36px | 700 | 1.15 | +| h3 | 22px | 700 | 1.3 | +| body | 17px | 400 | 1.6 | +| small | 14px | 400 | 1.5 | + +На мобиле — h1 уменьши до 36px, h2 до 28px. + +## Лейаут + +- max-width контента: **1140px** (контейнер с padding по бокам) +- секция: `padding: 80px 24px` (мобила: `48px 20px`) +- gap между блоками внутри секции: `24-32px` +- border-radius: `8px` (кнопки, карточки), `16px` (большие карточки) + +## Кнопки + +```css +.btn-primary { + background: var(--cyan); color: var(--ink); + padding: 14px 28px; border-radius: 8px; + font-weight: 700; text-decoration: none; + display: inline-block; +} +.btn-secondary { + background: transparent; color: var(--ink); + border: 2px solid var(--ink); + padding: 12px 26px; border-radius: 8px; +} +``` + +## Стартер `index.html` + +```html + + + + + +Мой проект + + + +
+
+

Заголовок проекта

+

Подзаголовок — пара предложений о чём это.

+ Начать +
+
+
+
+

Секция

+
Контент карточки.
+
Контент карточки.
+
+
+ + +``` + +## Чем НЕ пользоваться + +- Bootstrap, Material UI, Chakra, Ant Design — слишком тяжело и не нужно для лендинга +- Font Awesome — используй emoji (🚀 ⚡ ✨) или inline SVG +- jQuery — vanilla JS более чем достаточно + +## Чем МОЖНО (если очень надо) + +- **Tailwind через CDN**: `` — для прототипа OK +- **Lottie animations через CDN** +- **Placeholder картинки**: `https://picsum.photos/800/600`, `https://placehold.co/600x400` +- **Шрифты Google Fonts через ``** в head diff --git a/index.html b/index.html new file mode 100644 index 0000000..36887da --- /dev/null +++ b/index.html @@ -0,0 +1,549 @@ + + + + + +Внеплановый инструктаж — Безопасность ТС. Ключи в замке зажигания + + + + + +
+
+
Внеплановый инструктаж
+

Обеспечение безопасности эксплуатации транспортных средств

+

+ Недопущение оставления ключей в замке зажигания и свободного доступа + посторонних лиц к управлению транспортными средствами +

+
+ Дата инструктажа: _______________ + Провёл: _______________ +
+
+
+ + +
+
+

1. Основание и цель инструктажа

+

+ Настоящий внеплановый инструктаж проводится в связи с необходимостью усиления мер + по обеспечению безопасности дорожного движения и сохранности имущества организации. +

+
+ Повод: выявленные случаи / риск оставления ключей в замке зажигания + транспортных средств (ТС), что создаёт свободный доступ посторонних лиц к управлению + ТС, угон, а также использование ТС не по назначению. +
+

+ Цель: довести до всех категорий водителей и ответственных лиц + категорические требования по исключению практики оставления ключей в замке зажигания + и обеспечению контроля доступа к транспортным средствам. +

+
+
+ + +
+
+

2. Нормативная база

+
    +
  • Федеральный закон № 196-ФЗ «О безопасности дорожного движения»
  • +
  • Правила дорожного движения РФ (утв. Постановлением Правительства РФ № 1090)
  • +
  • Приказ Минтранса РФ от 28.09.2015 № 287 «Об утверждении профессиональных и квалификационных требований к работникам»
  • +
  • Правила внутреннего трудового распорядка и должностные инструкции организации
  • +
  • Локальные акты организации по охране труда и безопасности на транспорте
  • +
+
+
+ + +
+
+

3. Категории инструктируемых лиц

+
+
+
🚛
+

Водители

+

Штатные водители, закреплённые за конкретными ТС, выполняющие рейсы по маршрутам и заданиям организации.

+
+
+
🔄
+

Водители-совместители

+

Сотрудники, совмещающие обязанности водителя с основной должностью, допущенные к управлению ТС организации.

+
+
+
🛡
+

Ответственные лица

+

Лица, ответственные за выпуск ТС на линию, техническое состояние, хранение ТС и ведение документации.

+
+
+
+
+ + +
+
+

4. Описание проблемы и рисков

+

+ Оставление ключей в замке зажигания транспортного средства вне зависимости от места нахождения + ТС (на территории организации, стоянке, в гараже, на линии) создаёт следующие угрозы: +

+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
РискПоследствия
Угон ТС посторонними лицамиМатериальный ущерб организации, уголовная ответственность, срыв производственных задач
Использование ТС не по назначениюРасход ГСМ, износ ТС, нарушение трудовой дисциплины
ДТП, совершённое лицом без допускаУщерб жизни и здоровью третьих лиц, гражданская и уголовная ответственность
Хищение груза / имущества из ТСПрямые финансовые потери, утрата доверия контрагентов
Нарушение требований ОТ и ПДДШтрафы, дисциплинарные взыскания, предписания контролирующих органов
+
+
+
+ + +
+
+

5. Категорические требования для всех категорий

+ +
+ ЗАПРЕЩЕНО: оставлять ключи в замке зажигания ТС при любых обстоятельствах, в том числе: +
    +
  • при кратковременной остановке (заправка, погрузка/разгрузка, оформление документов)
  • +
  • при стоянке на охраняемой территории организации
  • +
  • при постановке ТС в гараж / бокс
  • +
  • при прогреве двигателя без присутствия водителя в кабине
  • +
  • при передаче ТС другому лицу без оформления путевой документации
  • +
+
+ +
+ ОБЯЗАНОСТЬ: при покидании транспортного средства водитель обязан: +
    +
  • заглушить двигатель
  • +
  • извлечь ключ из замка зажигания
  • +
  • убрать ключ в надёжное место (карман одежды, сумку — исключая оставление в кабине)
  • +
  • убедиться, что ТС обездвижено (стояночный тормоз, передача)
  • +
  • закрыть двери кабины/салона на замок
  • +
+
+
+
+ + +
+
+

6. Требования по категориям

+ +

6.1 Водители (штатные)

+
    +
  • Ключи от закреплённого ТС хранятся только у водителя, которому выданы под подпись.
  • +
  • При возвращении на базу — сдать ключи диспетчеру / ответственному лицу под роспись в журнале.
  • +
  • Запрещена передача ключей третьим лицам (включая коллег) без разрешения ответственного лица.
  • +
  • При обнаружении ключей, оставленных в замке зажигания другого ТС — немедленно сообщить диспетчеру и изъять ключи.
  • +
+ +

6.2 Водители-совместители

+
    +
  • Ключи от ТС получать у ответственного лица на конкретный рейс/задание под роспись.
  • +
  • По возвращении сдать ключи немедленно, не оставляя их в кабине.
  • +
  • Запрещено брать ТС без оформленного путевого листа и отметки механика о допуске.
  • +
  • Запрещено хранить дубликаты ключей от ТС в личных вещах без согласования с ответственным лицом.
  • +
+ +

6.3 Ответственные лица (диспетчеры, механики, начальники колонн)

+
    +
  • Вести журнал выдачи-возврата ключей от ТС с подписями водителей и отметками времени.
  • +
  • Ежедневно проверять наличие ключей в месте хранения (запираемый ящик / сейф).
  • +
  • Контролировать, что выпуск ТС осуществляется только при наличии путевого листа и отметки о медосмотре.
  • +
  • Незамедлительно докладывать руководству о фактах оставления ключей в замке зажигания.
  • +
  • Обеспечить хранение резервных (дублирующих) ключей в опечатанном виде с записью в журнале.
  • +
  • Проводить внезапные проверки стоянки ТС на предмет наличия ключей в замке зажигания.
  • +
+
+
+ + +
+
+

7. Порядок хранения и учёта ключей от ТС

+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
ОперацияДействиеДокументОтветственный
Выдача ключей перед рейсомВыдать водителю лично под росписьЖурнал выдачи ключейДиспетчер
Возврат ключей после рейсаПринять, проверить соответствие, сделать записьЖурнал выдачи ключейДиспетчер
Хранение в нерабочее времяЗапираемый шкаф / сейф в диспетчерскойДиспетчер / охрана
Дубликаты ключейОпечатанный пенал с биркой (номер ТС)Опечатанный пеналРуководитель транспортного отдела
Утеря / поломка ключаАкт + выдача дубликата + замена замка (при необходимости)Акт об утереКомиссия (не менее 2 чел.)
+
+
+
+ + +
+
+

8. Ответственность за нарушения

+ +
+ За оставление ключей в замке зажигания / свободный доступ к управлению ТС применяются: +
+ +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
НарушениеМера ответственности
Первичное оставление ключей (без последствий)Дисциплинарное взыскание (замечание / выговор) + внеочередной инструктаж
Повторное оставление ключейСтрогий выговор + лишение премии
Систематические нарушения (3 и более)Отстранение от управления ТС, расторжение трудового договора
Оставление ключей, повлёкшее угон / ДТПМатериальная ответственность в полном объёме ущерба + передача материалов в правоохранительные органы
Сокрытие факта оставления ключейУвольнение + материальная ответственность
+
+
+
+ + +
+
+

9. Лист ознакомления с инструктажом

+

+ Своей подписью подтверждаю, что с содержанием внепланового инструктажа ознакомлен(а), + требования и меру ответственности осознаю, обязуюсь выполнять. +

+ +
+

Подписи инструктируемых

+
+
Фамилия И.О.
+
Должность / Категория
+
Подпись и дата
+
+
+
+
+
+
+
+
+
+
+
+
+ +

+ Инструктаж провёл: _______________________________________     + (должность, Ф.И.О., подпись, дата) +

+
+
+ + + + +