/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    font-family:'Inter',-apple-system,sans-serif;
    background:#0e0c0a;
    color:#e8e2d6;
    font-weight:300;
    line-height:1.55;
    font-size:16px;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
}

a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:0;color:inherit;cursor:pointer}
img,svg{display:block;max-width:100%}
em{font-style:italic;color:#c8a96a}

/* ---------- Layout primitives ---------- */
:root{
    --pad:clamp(20px,5vw,80px);
    --gold:#c8a96a;
    --cream:#e8e2d6;
    --ink:#0e0c0a;
    --ink-2:#171411;
    --rule:rgba(232,226,214,.14);
}

section{
    padding:clamp(80px,12vw,160px) var(--pad);
    position:relative;
    border-top:1px solid var(--rule);
}

.section__num{
    position:absolute;
    top:clamp(80px,12vw,160px);
    right:var(--pad);
    font-family:'Cormorant Garamond',serif;
    font-size:13px;
    letter-spacing:.4em;
    color:var(--gold);
    opacity:.7;
}

.section__title{
    font-family:'Cormorant Garamond',serif;
    font-weight:300;
    font-size:clamp(46px,8vw,116px);
    line-height:.95;
    letter-spacing:-.02em;
    color:var(--cream);
}

/* ---------- Nav ---------- */
.nav{
    position:fixed;top:0;left:0;right:0;z-index:50;
    padding:24px var(--pad);
    background:linear-gradient(180deg,rgba(14,12,10,.85),rgba(14,12,10,0));
    backdrop-filter:blur(8px);
    -webkit-backdrop-filter:blur(8px);
}
.nav__inner{
    display:flex;align-items:center;justify-content:space-between;
    gap:24px;
}
.nav__brand{
    display:flex;flex-direction:column;line-height:1;
}
.nav__brand-ru{
    font-family:'Cormorant Garamond',serif;
    font-size:22px;
    font-weight:500;
    letter-spacing:.01em;
}
.nav__brand-en{
    font-size:9px;
    letter-spacing:.5em;
    text-transform:uppercase;
    color:var(--gold);
    margin-top:4px;
}
.nav__links{
    display:flex;gap:36px;
}
.nav__links a{
    font-size:12px;
    letter-spacing:.18em;
    text-transform:uppercase;
    color:var(--cream);
    opacity:.75;
    transition:opacity .25s, color .25s;
}
.nav__links a:hover{opacity:1;color:var(--gold)}
@media(max-width:720px){.nav__links{display:none}}

/* ---------- Hero ---------- */
.hero{
    min-height:100vh;
    padding-top:clamp(140px,20vw,200px);
    padding-bottom:clamp(40px,6vw,80px);
    display:flex;flex-direction:column;
    border-top:0;
    position:relative;
    overflow:hidden;
}
.hero::before{
    content:"";
    position:absolute;
    inset:0;
    background:
        radial-gradient(ellipse at 80% 30%,rgba(200,169,106,.08),transparent 50%),
        radial-gradient(ellipse at 10% 90%,rgba(200,169,106,.05),transparent 50%);
    pointer-events:none;
}
.hero__line{
    font-family:'Cormorant Garamond',serif;
    font-size:14px;
    letter-spacing:.45em;
    color:var(--gold);
    text-transform:uppercase;
    margin-bottom:auto;
}
.hero__title{
    font-family:'Cormorant Garamond',serif;
    font-weight:300;
    font-size:clamp(72px,15vw,220px);
    line-height:.88;
    letter-spacing:-.03em;
    margin:auto 0 32px;
}
.hero__sub{
    max-width:520px;
    font-size:clamp(15px,1.2vw,18px);
    line-height:1.6;
    color:rgba(232,226,214,.78);
    margin-bottom:64px;
}
.hero__bottom{
    display:flex;align-items:flex-end;justify-content:space-between;
    flex-wrap:wrap;gap:24px;
    padding-top:32px;
    border-top:1px solid var(--rule);
}
.hero__meta{
    display:flex;gap:48px;
    font-size:11px;
    letter-spacing:.3em;
    text-transform:uppercase;
    color:rgba(232,226,214,.6);
}
.hero__cta{
    display:inline-flex;align-items:center;gap:18px;
    font-size:13px;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--gold);
    padding-bottom:6px;
    border-bottom:1px solid rgba(200,169,106,.3);
    transition:gap .35s, border-color .35s;
}
.hero__cta:hover{gap:28px;border-color:var(--gold)}
.hero__cta svg{transition:transform .35s}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1.1s ease, transform 1.1s ease}
.reveal.is-in{opacity:1;transform:none}

/* ---------- Manifesto ---------- */
.manifesto__grid{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:clamp(40px,7vw,120px);
    align-items:start;
}
.manifesto__text{
    display:flex;flex-direction:column;gap:24px;
    font-size:clamp(15px,1.1vw,17px);
    color:rgba(232,226,214,.82);
    max-width:46ch;
    padding-top:18px;
}
.manifesto__stats{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    margin-top:clamp(60px,10vw,140px);
    border-top:1px solid var(--rule);
    border-bottom:1px solid var(--rule);
}
.stat{
    padding:36px 24px;
    border-right:1px solid var(--rule);
    display:flex;flex-direction:column;gap:14px;
}
.stat:last-child{border-right:0}
.stat__num{
    font-family:'Cormorant Garamond',serif;
    font-size:clamp(48px,5vw,72px);
    font-weight:300;
    line-height:1;
    color:var(--gold);
}
.stat__label{
    font-size:11px;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:rgba(232,226,214,.6);
}
@media(max-width:880px){
    .manifesto__grid{grid-template-columns:1fr}
    .manifesto__stats{grid-template-columns:repeat(2,1fr)}
    .stat:nth-child(2){border-right:0}
    .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--rule)}
}

/* ---------- Collection ---------- */
.collection__head{
    display:grid;
    grid-template-columns:1.1fr .9fr;
    gap:clamp(40px,7vw,120px);
    align-items:end;
    margin-bottom:clamp(80px,10vw,140px);
}
.collection__lead{
    font-size:clamp(15px,1.1vw,17px);
    color:rgba(232,226,214,.78);
    max-width:42ch;
    padding-bottom:14px;
}
@media(max-width:880px){.collection__head{grid-template-columns:1fr}}

.door{
    display:grid;
    grid-template-columns:.9fr 1.1fr;
    gap:clamp(32px,6vw,100px);
    align-items:center;
    padding:clamp(60px,9vw,110px) 0;
    border-top:1px solid var(--rule);
}
.door:last-of-type{border-bottom:1px solid var(--rule)}
.door--rev{grid-template-columns:1.1fr .9fr}
.door--rev .door__visual{order:2}
.door--rev .door__info{order:1}

.door__visual{
    aspect-ratio:3/5;
    background:#0a0907;
    position:relative;
    overflow:hidden;
    transition:transform .8s cubic-bezier(.2,.6,.2,1);
    box-shadow:
        inset 0 0 0 1px rgba(200,169,106,.12),
        0 40px 90px -30px rgba(0,0,0,.7);
}
.door__visual img{
    width:100%;
    height:108%;
    object-fit:cover;
    transition:filter .8s;
    filter:saturate(.92) contrast(1.02);
    will-change:transform;
}
.door__visual::after{
    content:"";
    position:absolute;inset:0;
    background:linear-gradient(180deg,transparent 60%,rgba(14,12,10,.45) 100%);
    pointer-events:none;
}
.door:hover .door__visual{transform:translateY(-6px)}
.door:hover .door__visual img{filter:saturate(1) contrast(1.04)}

.door__info{
    display:flex;flex-direction:column;gap:22px;
}
.door__index{
    font-family:'Cormorant Garamond',serif;
    font-size:13px;
    letter-spacing:.4em;
    color:var(--gold);
    text-transform:uppercase;
}
.door__name{
    font-family:'Cormorant Garamond',serif;
    font-weight:400;
    font-size:clamp(40px,5.5vw,72px);
    line-height:1;
    letter-spacing:-.01em;
}
.door__desc{
    font-size:clamp(15px,1.05vw,17px);
    color:rgba(232,226,214,.78);
    max-width:46ch;
}
.door__spec{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    border-top:1px solid var(--rule);
    border-bottom:1px solid var(--rule);
    padding:18px 0;
    margin-top:6px;
}
.door__spec dt{
    font-size:10px;
    letter-spacing:.25em;
    text-transform:uppercase;
    color:rgba(232,226,214,.5);
    margin-bottom:8px;
}
.door__spec dd{
    font-family:'Cormorant Garamond',serif;
    font-size:18px;
    color:var(--cream);
}
.door__price{
    display:flex;align-items:baseline;gap:12px;
    margin-top:10px;
}
.door__price-label{
    font-size:11px;
    letter-spacing:.3em;
    text-transform:uppercase;
    color:rgba(232,226,214,.55);
}
.door__price-value{
    font-family:'Cormorant Garamond',serif;
    font-size:clamp(26px,2.4vw,34px);
    color:var(--gold);
    letter-spacing:.01em;
}
@media(max-width:880px){
    .door,.door--rev{grid-template-columns:1fr}
    .door--rev .door__visual{order:0}
    .door--rev .door__info{order:0}
    .door__visual{aspect-ratio:3/4;max-height:62vh}
}

/* ---------- Craft ---------- */
.steps{
    list-style:none;
    margin-top:clamp(60px,8vw,100px);
    counter-reset:step;
}
.step{
    display:grid;
    grid-template-columns:120px 1fr auto;
    gap:clamp(24px,4vw,60px);
    align-items:start;
    padding:36px 0;
    border-top:1px solid var(--rule);
    transition:padding-left .5s;
}
.step:last-child{border-bottom:1px solid var(--rule)}
.step:hover{padding-left:18px}
.step__num{
    font-family:'Cormorant Garamond',serif;
    font-size:clamp(28px,3vw,44px);
    color:var(--gold);
    font-weight:300;
}
.step__body h4{
    font-family:'Cormorant Garamond',serif;
    font-size:clamp(24px,2.5vw,34px);
    font-weight:400;
    margin-bottom:10px;
    letter-spacing:-.005em;
}
.step__body p{
    font-size:15px;
    color:rgba(232,226,214,.74);
    max-width:54ch;
}
.step__time{
    font-size:11px;
    letter-spacing:.25em;
    text-transform:uppercase;
    color:rgba(232,226,214,.5);
    align-self:start;
    padding-top:14px;
    white-space:nowrap;
}
@media(max-width:720px){
    .step{grid-template-columns:60px 1fr;}
    .step__time{grid-column:1/3;padding-top:8px}
}

/* ---------- Visit ---------- */
.visit{background:#0a0907}
.visit__grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:clamp(40px,7vw,120px);
    align-items:start;
    margin-top:30px;
}
.visit__lead{
    margin-top:36px;
    font-size:clamp(15px,1.1vw,17px);
    color:rgba(232,226,214,.78);
    max-width:40ch;
}
.visit__address{
    margin-top:36px;
    font-style:normal;
    font-family:'Cormorant Garamond',serif;
    font-size:20px;
    line-height:1.7;
    color:var(--cream);
    padding-top:28px;
    border-top:1px solid var(--rule);
    max-width:36ch;
}

.visit__form{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px 32px;
    margin-top:30px;
}
.field{
    display:flex;flex-direction:column;gap:8px;
}
.field--full{grid-column:1/-1}
.field span{
    font-size:10px;
    letter-spacing:.3em;
    text-transform:uppercase;
    color:rgba(232,226,214,.55);
}
.field input,.field textarea{
    font:inherit;
    background:transparent;
    border:0;
    border-bottom:1px solid var(--rule);
    color:var(--cream);
    padding:8px 0 12px;
    outline:0;
    font-size:16px;
    transition:border-color .3s;
    resize:none;
}
.field input:focus,.field textarea:focus{
    border-color:var(--gold);
}
.visit__submit{
    grid-column:1/-1;
    justify-self:start;
    display:inline-flex;align-items:center;gap:18px;
    font-size:13px;
    letter-spacing:.22em;
    text-transform:uppercase;
    color:var(--gold);
    padding:14px 0 8px;
    border-bottom:1px solid rgba(200,169,106,.3);
    margin-top:10px;
    transition:gap .35s, border-color .35s, color .25s;
}
.visit__submit:hover{gap:28px;border-color:var(--gold);color:#dcbd83}
.visit__note{
    grid-column:1/-1;
    font-family:'Cormorant Garamond',serif;
    font-size:18px;
    color:var(--gold);
    margin-top:8px;
}
@media(max-width:880px){
    .visit__grid{grid-template-columns:1fr}
    .visit__form{grid-template-columns:1fr}
    .field--full{grid-column:auto}
}

/* ---------- Footer ---------- */
.foot{
    padding:48px var(--pad);
    border-top:1px solid var(--rule);
}
.foot__inner{
    display:flex;justify-content:space-between;align-items:center;
    gap:24px;flex-wrap:wrap;
}
.foot__brand{display:flex;flex-direction:column;line-height:1.1}
.foot__brand span:first-child{
    font-family:'Cormorant Garamond',serif;
    font-size:20px;
}
.foot__brand-en{
    font-size:9px;
    letter-spacing:.5em;
    text-transform:uppercase;
    color:var(--gold);
    margin-top:4px;
}
.foot__cols{
    display:flex;gap:36px;
    font-size:11px;
    letter-spacing:.2em;
    text-transform:uppercase;
    color:rgba(232,226,214,.55);
    flex-wrap:wrap;
}
.foot__cols em{font-style:italic;text-transform:none;letter-spacing:0}

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