/* ═══════════════════════════════════════════════════════════════════════════
   HACKATHON HUB DESIGN TOKENS
   Централизованная система дизайн-токенов для полной тематизации.
   Меняя значения в :root - меняется весь внешний вид сайта.
   ═══════════════════════════════════════════════════════════════════════════ */

:root {
    /* ─────────────────────────────────────────────────────────────────────────
       PRIMARY PALETTE
       Основные 5 цветов бренда
       ───────────────────────────────────────────────────────────────────────── */
    --amber-gold: #ffbe0b;
    --blaze-orange: #fb5607;
    --neon-pink: #ff006e;
    --blue-violet: #8338ec;
    --azure-blue: #3a86ff;

    /* ─────────────────────────────────────────────────────────────────────────
       DERIVED TINTS (10%, 20% opacity on white)
       ───────────────────────────────────────────────────────────────────────── */
    --amber-gold-10: #fff9e6;
    --amber-gold-20: #fff3cc;
    --blaze-orange-10: #fff0e6;
    --blaze-orange-20: #ffe1cc;
    --neon-pink-10: #ffe6f0;
    --neon-pink-20: #ffcce1;
    --blue-violet-10: #f3ebfd;
    --blue-violet-20: #e7d7fb;
    --azure-blue-10: #ebf3ff;
    --azure-blue-20: #d6e7ff;

    /* ─────────────────────────────────────────────────────────────────────────
       HOVER/ACTIVE STATES (darkened versions)
       ───────────────────────────────────────────────────────────────────────── */
    --amber-gold-hover: #e5ab0a;
    --azure-blue-hover: #2970e0;
    --azure-blue-dark: #1d5cc7;
    --neon-pink-hover: #d9005d;
    --blue-violet-hover: #6f2dc7;

    /* ─────────────────────────────────────────────────────────────────────────
       EXTENDED PALETTE (Semantic additions)
       ───────────────────────────────────────────────────────────────────────── */
    --emerald-green: #10b981;
    --emerald-green-hover: #059669;
    --emerald-green-10: #d1fae5;
    --emerald-green-20: #a7f3d0;

    /* ─────────────────────────────────────────────────────────────────────────
       SEMANTIC COLOR MAPPING
       Используйте эти переменные в коде
       ───────────────────────────────────────────────────────────────────────── */
    --color-primary: var(--amber-gold);
    --color-primary-hover: var(--amber-gold-hover);
    --color-primary-bg: var(--amber-gold-10);

    --color-secondary: var(--azure-blue);
    --color-secondary-hover: var(--azure-blue-hover);
    --color-secondary-bg: var(--azure-blue-10);

    --color-accent: var(--neon-pink);
    --color-accent-bg: var(--neon-pink-10);

    --color-success: var(--azure-blue);
    --color-success-bg: var(--azure-blue-10);

    --color-warning: var(--blaze-orange);
    --color-warning-bg: var(--blaze-orange-10);

    --color-danger: var(--neon-pink);
    --color-danger-hover: var(--neon-pink-hover);
    --color-danger-bg: var(--neon-pink-10);

    --color-info: var(--blue-violet);
    --color-info-bg: var(--blue-violet-10);

    /* ─────────────────────────────────────────────────────────────────────────
       NEUTRALS (with subtle violet undertone for brand consistency)
       ───────────────────────────────────────────────────────────────────────── */
    --neutral-900: #1a1625;
    --neutral-800: #2d2839;
    --neutral-700: #3d3654;
    --neutral-600: #524a6b;
    --neutral-500: #6b6183;
    --neutral-400: #8a829f;
    --neutral-300: #a9a3b8;
    --neutral-200: #d4d1dc;
    --neutral-100: #eae8ee;
    --neutral-50: #f5f4f7;
    --neutral-0: #ffffff;

    /* ─────────────────────────────────────────────────────────────────────────
       TEXT COLORS
       ───────────────────────────────────────────────────────────────────────── */
    --color-text: var(--neutral-900);
    --color-text-secondary: var(--neutral-700);
    --color-text-muted: var(--neutral-500);
    --color-text-inverse: var(--neutral-0);
    --color-text-on-primary: var(--neutral-900);
    --color-text-on-secondary: var(--neutral-0);
    --color-text-link: var(--azure-blue);
    --color-text-link-hover: var(--azure-blue-dark);

    /* ─────────────────────────────────────────────────────────────────────────
       BACKGROUND COLORS
       ───────────────────────────────────────────────────────────────────────── */
    --color-bg: var(--neutral-0);
    --color-bg-subtle: var(--neutral-50);
    --color-bg-muted: var(--neutral-100);
    --color-bg-page: var(--neutral-50);

    /* ─────────────────────────────────────────────────────────────────────────
       BORDER COLORS
       ───────────────────────────────────────────────────────────────────────── */
    --color-border: var(--neutral-200);
    --color-border-light: var(--neutral-100);
    --color-border-focus: var(--azure-blue);

    /* ─────────────────────────────────────────────────────────────────────────
       COMPONENT SIZES
       ───────────────────────────────────────────────────────────────────────── */
    --page-header-media-size: 72px;

    /* ─────────────────────────────────────────────────────────────────────────
       TYPOGRAPHY
       ───────────────────────────────────────────────────────────────────────── */
    --font-base: "Inter", "Segoe UI", system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --font-mono: "JetBrains Mono", "Fira Code", ui-monospace, monospace;

    --font-size-2xs: 11px;
    --font-size-xs: 12px;
    --font-size-xs-plus: 13px;
    --font-size-sm: 14px;
    --font-size-sm-plus: 15px;
    --font-size-base: 16px;
    --font-size-h4: 18px;
    --font-size-h3: 20px;
    --font-size-h2: 24px;
    --font-size-h2-plus: 28px;
    --font-size-h1: 32px;
    --font-size-display: 40px;
    --font-size-display-lg: 48px;
    --guestbook-emoji-scale: 2;

    --line-height-tight: 1.25;
    --line-height-base: 1.5;
    --line-height-relaxed: 1.625;

    --font-weight-normal: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;

    /* ─────────────────────────────────────────────────────────────────────────
       SPACING SCALE (4px base unit)
       ───────────────────────────────────────────────────────────────────────── */
    --spacing-xs: 4px;
    --spacing-sm: 8px;
    --spacing-md: 16px;
    --spacing-lg: 24px;
    --spacing-xl: 32px;
    --spacing-2xl: 48px;
    --spacing-3xl: 64px;

    /* ─────────────────────────────────────────────────────────────────────────
       AVATAR SIZES
       ───────────────────────────────────────────────────────────────────────── */
    --avatar-size-sm: 40px;
    --avatar-size-md: 48px;
    --avatar-size-lg: 96px;

    /* ─────────────────────────────────────────────────────────────────────────
       BORDER RADIUS
       ───────────────────────────────────────────────────────────────────────── */
    --radius-none: 0;
    --radius-sm: 4px;
    --radius-base: 8px;
    --radius-md: 10px;
    --radius-lg: 12px;
    --radius-xl: 16px;
    --radius-2xl: 20px;
    --radius-full: 9999px;

    /* ─────────────────────────────────────────────────────────────────────────
       SHADOWS
       ───────────────────────────────────────────────────────────────────────── */
    --shadow-sm: 0 1px 2px rgba(26, 22, 37, 0.05);
    --shadow-base: 0 1px 3px rgba(26, 22, 37, 0.1), 0 1px 2px rgba(26, 22, 37, 0.06);
    --shadow-md: 0 4px 6px rgba(26, 22, 37, 0.1), 0 2px 4px rgba(26, 22, 37, 0.06);
    --shadow-lg: 0 10px 15px rgba(26, 22, 37, 0.1), 0 4px 6px rgba(26, 22, 37, 0.05);
    --shadow-xl: 0 20px 25px rgba(26, 22, 37, 0.1), 0 8px 10px rgba(26, 22, 37, 0.04);
    --shadow-card: 0 24px 48px -40px rgba(26, 22, 37, 0.4);
    --shadow-focus: 0 0 0 3px rgba(58, 134, 255, 0.15);

    /* ─────────────────────────────────────────────────────────────────────────
       LAYOUT
       ───────────────────────────────────────────────────────────────────────── */
    --max-width: 960px;
    --max-width-wide: 1200px;
    --content-max-width: var(--max-width-wide);

    /* ─────────────────────────────────────────────────────────────────────────
       TRANSITIONS
       ───────────────────────────────────────────────────────────────────────── */
    --transition-fast: 150ms ease;
    --transition-base: 200ms ease;
    --transition-slow: 300ms ease;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESET & BASE STYLES
   ═══════════════════════════════════════════════════════════════════════════ */

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: var(--font-base);
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--color-text);
    background: var(--color-bg-page);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    white-space: nowrap;
    border: 0;
}

.icon-registry {
    position: absolute;
    width: 0;
    height: 0;
    overflow: hidden;
}