/* =============================================================
   IAC — Design Tokens
   Единый источник правды для цветов, шрифтов и интервалов.
   Палитра и пропорции взяты из ТЗ заказчика.
   ============================================================= */

:root {
    /* ========== ЦВЕТА ========== */
    --c-navy:       #0F2747;    /* Midnight Navy Blue — основной фон 70% */
    --c-navy-2:     #132f55;    /* чуть светлее — для слоёв */
    --c-navy-3:     #0a1c35;    /* чуть темнее — для hover */
    --c-graphite:   #1C1F26;    /* Graphite Black — доп. фон 20% */
    --c-ivory:      #F7F3EB;    /* Soft Ivory — баланс/текст 7% */
    --c-gold:       #C9A55C;    /* Premium Gold — luxury accent 3% */
    --c-gold-soft:  #D9BB7A;    /* gold hover */
    --c-gold-dark:  #A4843F;    /* gold pressed */
    --c-red:        #A62828;    /* Deep Red — strong CTA 3% */
    --c-red-soft:   #C03232;    /* red hover */

    /* Служебные оттенки (полу-прозрачные от ivory/navy) */
    --c-ivory-90:   rgba(247, 243, 235, 0.90);
    --c-ivory-70:   rgba(247, 243, 235, 0.70);
    --c-ivory-50:   rgba(247, 243, 235, 0.50);
    --c-ivory-20:   rgba(247, 243, 235, 0.20);
    --c-ivory-10:   rgba(247, 243, 235, 0.10);
    --c-navy-80:    rgba(15, 39, 71, 0.80);
    --c-navy-50:    rgba(15, 39, 71, 0.50);
    --c-gold-30:    rgba(201, 165, 92, 0.30);
    --c-gold-15:    rgba(201, 165, 92, 0.15);

    /* ========== ТИПОГРАФИКА ========== */
    --ff-display: "Playfair Display", "Cormorant Garamond", Georgia, serif;
    --ff-body:    "Inter", "Lato", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

    /* Размеры (fluid clamp) */
    --fs-hero:    clamp(3rem, 7vw, 6rem);       /* 48 -> 96 */
    --fs-h1:      clamp(2.25rem, 4vw, 3.5rem);  /* 36 -> 56 */
    --fs-h2:      clamp(1.75rem, 3vw, 2.5rem);  /* 28 -> 40 */
    --fs-h3:      clamp(1.25rem, 2vw, 1.5rem);  /* 20 -> 24 */
    --fs-lead:    clamp(1rem, 1.5vw, 1.25rem);  /* 16 -> 20 */
    --fs-body:    16px;
    --fs-small:   14px;
    --fs-micro:   12px;

    /* Трекинг */
    --tracking-tight:   -0.02em;
    --tracking-normal:  0;
    --tracking-wide:    0.05em;
    --tracking-caps:    0.18em;

    /* ========== ОТСТУПЫ ========== */
    --sp-1:  4px;
    --sp-2:  8px;
    --sp-3:  12px;
    --sp-4:  16px;
    --sp-5:  24px;
    --sp-6:  32px;
    --sp-7:  48px;
    --sp-8:  64px;
    --sp-9:  96px;
    --sp-10: 128px;

    /* ========== РАДИУСЫ / ТЕНИ ========== */
    --radius-xs: 2px;
    --radius-sm: 4px;
    --radius-md: 6px;
    --radius-lg: 10px;

    --shadow-sm:  0 1px 3px rgba(0, 0, 0, 0.08);
    --shadow-md:  0 6px 20px rgba(10, 20, 40, 0.18);
    --shadow-lg:  0 20px 60px rgba(10, 20, 40, 0.40);
    --shadow-gold: 0 6px 24px rgba(201, 165, 92, 0.25);

    /* ========== АНИМАЦИИ ========== */
    --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
    --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
    --t-fast:  150ms;
    --t-base:  280ms;
    --t-slow:  600ms;
}

/* =============================================================
   БАЗОВЫЕ ЭЛЕМЕНТЫ
   ============================================================= */

html {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

body {
    font-family: var(--ff-body);
    font-size: var(--fs-body);
    color: var(--c-graphite);
    background: var(--c-ivory);
    line-height: 1.6;
    letter-spacing: var(--tracking-normal);
}

h1, h2, h3, h4, .display {
    font-family: var(--ff-display);
    color: var(--c-navy);
    font-weight: 700;
    line-height: 1.15;
    letter-spacing: var(--tracking-tight);
}

/* =============================================================
   ПРЕМИУМ-УТИЛИТЫ
   ============================================================= */

/* Тонкая золотая линия под заголовком — ключевой luxury-признак */
.gold-rule {
    display: inline-block;
    width: 48px;
    height: 2px;
    background: var(--c-gold);
    margin: 0 0 var(--sp-5);
}

.gold-rule--center {
    display: block;
    margin: 0 auto var(--sp-5);
}

/* Золотой текст */
.text-gold { color: var(--c-gold); }
.text-ivory { color: var(--c-ivory); }
.text-navy { color: var(--c-navy); }
.text-red { color: var(--c-red); }

/* Фон */
.bg-navy { background: var(--c-navy); }
.bg-graphite { background: var(--c-graphite); }
.bg-ivory { background: var(--c-ivory); }

/* Labels — маленький uppercase текст с gold */
.eyebrow {
    display: inline-block;
    font-family: var(--ff-body);
    font-size: var(--fs-micro);
    font-weight: 600;
    letter-spacing: var(--tracking-caps);
    text-transform: uppercase;
    color: var(--c-gold);
}

.eyebrow--ivory { color: var(--c-ivory-70); }

/* Serif display заголовки */
.display-xl {
    font-family: var(--ff-display);
    font-size: var(--fs-hero);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: var(--tracking-tight);
}

.display-lg {
    font-family: var(--ff-display);
    font-size: var(--fs-h1);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: var(--tracking-tight);
}

.display-md {
    font-family: var(--ff-display);
    font-size: var(--fs-h2);
    font-weight: 700;
    line-height: 1.2;
}

/* =============================================================
   ПРЕМИУМ-КНОПКИ
   ============================================================= */

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    padding: 14px 32px;
    font-family: var(--ff-body);
    font-size: var(--fs-small);
    font-weight: 600;
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
    border-radius: var(--radius-xs);
    cursor: pointer;
    transition: all var(--t-base) var(--ease-out);
    border: 1px solid transparent;
    text-decoration: none;
    white-space: nowrap;
}

/* Основная CTA — красная (из ТЗ: Strong CTA = Deep Red) */
.btn--primary {
    background: var(--c-red);
    color: var(--c-ivory);
}
.btn--primary:hover {
    background: var(--c-red-soft);
    transform: translateY(-1px);
    box-shadow: 0 8px 24px rgba(166, 40, 40, 0.35);
}

/* Золотая premium-кнопка */
.btn--gold {
    background: var(--c-gold);
    color: var(--c-navy);
}
.btn--gold:hover {
    background: var(--c-gold-soft);
    transform: translateY(-1px);
    box-shadow: var(--shadow-gold);
}

/* Outline-кнопка (на тёмном фоне) */
.btn--outline {
    background: transparent;
    color: var(--c-ivory);
    border: 1px solid var(--c-gold);
}
.btn--outline:hover {
    background: var(--c-gold);
    color: var(--c-navy);
}

/* Outline тёмная (на светлом фоне) */
.btn--outline-dark {
    background: transparent;
    color: var(--c-navy);
    border: 1px solid var(--c-navy);
}
.btn--outline-dark:hover {
    background: var(--c-navy);
    color: var(--c-ivory);
}

.btn--lg {
    padding: 18px 40px;
    font-size: var(--fs-body);
}

.btn--sm {
    padding: 10px 20px;
    font-size: var(--fs-micro);
}

/* =============================================================
   КАРТОЧКИ
   ============================================================= */

.card {
    background: var(--c-ivory);
    padding: var(--sp-6);
    border: 1px solid rgba(15, 39, 71, 0.08);
    transition: all var(--t-base) var(--ease-out);
    position: relative;
}
.card:hover {
    border-color: var(--c-gold);
    box-shadow: var(--shadow-md);
    transform: translateY(-4px);
}

/* Тёмная карточка (на светлом фоне) */
.card--dark {
    background: var(--c-navy);
    color: var(--c-ivory);
    border-color: var(--c-navy-2);
}
.card--dark:hover {
    border-color: var(--c-gold);
}

/* =============================================================
   HAIRLINES / DIVIDERS
   ============================================================= */

.hairline {
    border: 0;
    border-top: 1px solid var(--c-ivory-20);
}

.hairline--gold {
    border-top: 1px solid var(--c-gold);
}

.hairline--thick {
    border-top: 2px solid var(--c-gold);
}

/* =============================================================
   NAV LINKS (шапка)
   ============================================================= */

.nav-link {
    position: relative;
    font-family: var(--ff-body);
    font-size: var(--fs-micro);
    font-weight: 600;
    letter-spacing: var(--tracking-caps);
    text-transform: uppercase;
    color: var(--c-ivory-70);
    text-decoration: none;
    padding: var(--sp-3) 0;
    transition: color var(--t-fast) var(--ease-out);
}
.nav-link:hover,
.nav-link.is-active {
    color: var(--c-ivory);
}
.nav-link::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 0;
    height: 1px;
    background: var(--c-gold);
    transform: translateX(-50%);
    transition: width var(--t-base) var(--ease-out);
}
.nav-link:hover::after,
.nav-link.is-active::after {
    width: 100%;
}

/* Тёмная версия (для светлой шапки, если нужна) */
.nav-link--dark {
    color: var(--c-navy);
}
.nav-link--dark:hover {
    color: var(--c-navy-3);
}

/* =============================================================
   ВЫБОРОЧНОЕ ВЫДЕЛЕНИЕ
   ============================================================= */

::selection {
    background: var(--c-gold);
    color: var(--c-navy);
}

/* =============================================================
   SCROLLBAR (premium)
   ============================================================= */

::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
::-webkit-scrollbar-track {
    background: var(--c-ivory);
}
::-webkit-scrollbar-thumb {
    background: var(--c-navy);
    border: 2px solid var(--c-ivory);
    border-radius: var(--radius-sm);
}
::-webkit-scrollbar-thumb:hover {
    background: var(--c-gold);
}
