/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/65cf83d2-ee46-4642-86db-0aa9c7a6eaea.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/dbad6699-acf4-4a52-9bf5-c66ff5bb83cf.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 300;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/7bbe58b6-5db9-4b73-89e3-c14a9345995f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/65cf83d2-ee46-4642-86db-0aa9c7a6eaea.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/dbad6699-acf4-4a52-9bf5-c66ff5bb83cf.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 400;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/7bbe58b6-5db9-4b73-89e3-c14a9345995f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/65cf83d2-ee46-4642-86db-0aa9c7a6eaea.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/dbad6699-acf4-4a52-9bf5-c66ff5bb83cf.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Archivo';
  font-style: normal;
  font-weight: 500;
  font-stretch: 100%;
  font-display: swap;
  src: url("../fonts/7bbe58b6-5db9-4b73-89e3-c14a9345995f.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/92eb1876-bffa-4d07-9f5a-045160e046bb.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/8a1a63b6-5967-48bf-be68-a70c6445e5ea.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/c83c75d6-6d4a-4b9a-85e5-770fd9fdddd9.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/a66f8a9d-ef44-430d-b11b-6f750fa34244.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/c3802555-119a-4299-9911-08abb351b637.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/a0a38e38-f4af-4170-89f6-0a4a1b5657e8.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/03f79176-1fb7-4a9d-9c06-d7de3ea57e88.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/6d009303-230a-4999-b2fc-d211293edcd7.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/1f2b215b-ddaa-44ea-b443-fed6ae7d2ed1.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/dc818336-c6d7-4289-bf58-10253b064f66.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'DM Serif Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/9751940a-f5d6-41ec-a35f-08936288124d.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'DM Serif Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/2f0e9ba0-738b-4d57-ba9a-25538b360352.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'DM Serif Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/fbc126e6-ca18-4a9f-b317-a7db56a270bc.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'DM Serif Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/b12ca05e-5e77-4f0a-8748-bf48915b4461.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/7141f646-2ce7-4ddf-9188-6d3ff158b91a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/bfda57c2-064f-4dfa-9069-837e20fdf87c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/250ee26b-423d-44b2-ab78-45f296d0ed79.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/7141f646-2ce7-4ddf-9188-6d3ff158b91a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/bfda57c2-064f-4dfa-9069-837e20fdf87c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/250ee26b-423d-44b2-ab78-45f296d0ed79.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/7141f646-2ce7-4ddf-9188-6d3ff158b91a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/bfda57c2-064f-4dfa-9069-837e20fdf87c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/250ee26b-423d-44b2-ab78-45f296d0ed79.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/7141f646-2ce7-4ddf-9188-6d3ff158b91a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/bfda57c2-064f-4dfa-9069-837e20fdf87c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/250ee26b-423d-44b2-ab78-45f296d0ed79.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/7141f646-2ce7-4ddf-9188-6d3ff158b91a.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/bfda57c2-064f-4dfa-9069-837e20fdf87c.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Darker Grotesque';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/250ee26b-423d-44b2-ab78-45f296d0ed79.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/436aaa3f-6965-4a84-83c9-7f24f7829e88.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/1e41e010-6acb-40e9-a012-382c4c0a778b.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/099bf082-1f5c-4277-ba6d-dc46a364b0dc.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/d238d45a-b3b2-4d23-9192-6754bd98b3d6.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/1b89ee48-208a-42fd-b593-d1409e1edd0e.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/425c1837-3461-4004-ad76-8c15f2c492d8.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/436aaa3f-6965-4a84-83c9-7f24f7829e88.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/1e41e010-6acb-40e9-a012-382c4c0a778b.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/099bf082-1f5c-4277-ba6d-dc46a364b0dc.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/d238d45a-b3b2-4d23-9192-6754bd98b3d6.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/1b89ee48-208a-42fd-b593-d1409e1edd0e.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/425c1837-3461-4004-ad76-8c15f2c492d8.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/bf611c2a-7e31-4880-a975-e3132185ebb2.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/10c95a4e-1504-4015-8d9d-8d4ccc2df780.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/263866bb-857c-4dac-8f34-bdfaa3b37759.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/bf611c2a-7e31-4880-a975-e3132185ebb2.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/10c95a4e-1504-4015-8d9d-8d4ccc2df780.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Jost';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/263866bb-857c-4dac-8f34-bdfaa3b37759.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("../fonts/b800cb1c-f52b-4392-9013-97a3a9fc0262.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("../fonts/149d2378-8763-437c-b4a5-07f2707e9bef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("../fonts/6fc1520e-7f8a-4984-b231-ded5060c23dd.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("../fonts/8f60cead-ad48-4da0-8b9c-c9fc4b54e523.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("../fonts/6ab46780-1d91-4fd6-b56c-8ef714faca68.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200;
  font-display: swap;
  src: url("../fonts/04d5c576-0541-45bc-b4cf-8a015b6118f2.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/b800cb1c-f52b-4392-9013-97a3a9fc0262.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/149d2378-8763-437c-b4a5-07f2707e9bef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/6fc1520e-7f8a-4984-b231-ded5060c23dd.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/8f60cead-ad48-4da0-8b9c-c9fc4b54e523.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/6ab46780-1d91-4fd6-b56c-8ef714faca68.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url("../fonts/04d5c576-0541-45bc-b4cf-8a015b6118f2.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/b800cb1c-f52b-4392-9013-97a3a9fc0262.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/149d2378-8763-437c-b4a5-07f2707e9bef.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/6fc1520e-7f8a-4984-b231-ded5060c23dd.woff2") format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/8f60cead-ad48-4da0-8b9c-c9fc4b54e523.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/6ab46780-1d91-4fd6-b56c-8ef714faca68.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/04d5c576-0541-45bc-b4cf-8a015b6118f2.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/a58c2141-2123-4b4a-92ee-d0cdc4367bdf.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/4d7a3ae9-82cd-47f3-84d6-90b437ee47d0.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/97c94050-64bc-4653-83df-2a8c1a45a2f8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/dbfbee85-2f9c-4d09-9d11-48d077b5431a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/a58c2141-2123-4b4a-92ee-d0cdc4367bdf.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/4d7a3ae9-82cd-47f3-84d6-90b437ee47d0.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/97c94050-64bc-4653-83df-2a8c1a45a2f8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/dbfbee85-2f9c-4d09-9d11-48d077b5431a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/a58c2141-2123-4b4a-92ee-d0cdc4367bdf.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/4d7a3ae9-82cd-47f3-84d6-90b437ee47d0.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/97c94050-64bc-4653-83df-2a8c1a45a2f8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/dbfbee85-2f9c-4d09-9d11-48d077b5431a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/a58c2141-2123-4b4a-92ee-d0cdc4367bdf.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/4d7a3ae9-82cd-47f3-84d6-90b437ee47d0.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/97c94050-64bc-4653-83df-2a8c1a45a2f8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/dbfbee85-2f9c-4d09-9d11-48d077b5431a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/a58c2141-2123-4b4a-92ee-d0cdc4367bdf.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/4d7a3ae9-82cd-47f3-84d6-90b437ee47d0.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/97c94050-64bc-4653-83df-2a8c1a45a2f8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/dbfbee85-2f9c-4d09-9d11-48d077b5431a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/a58c2141-2123-4b4a-92ee-d0cdc4367bdf.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/4d7a3ae9-82cd-47f3-84d6-90b437ee47d0.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/97c94050-64bc-4653-83df-2a8c1a45a2f8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/dbfbee85-2f9c-4d09-9d11-48d077b5431a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/27200c5e-82e9-43cf-a69c-ca51d70ea8cc.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/e37a4230-1703-4ff1-9fb8-fc756fcf82cb.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/8dc6e9da-488c-4808-a570-cd52643e9942.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/f32aae4e-6758-4048-a849-3b174fb6aff4.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/27200c5e-82e9-43cf-a69c-ca51d70ea8cc.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/e37a4230-1703-4ff1-9fb8-fc756fcf82cb.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/8dc6e9da-488c-4808-a570-cd52643e9942.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/f32aae4e-6758-4048-a849-3b174fb6aff4.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/27200c5e-82e9-43cf-a69c-ca51d70ea8cc.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/e37a4230-1703-4ff1-9fb8-fc756fcf82cb.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/8dc6e9da-488c-4808-a570-cd52643e9942.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("../fonts/f32aae4e-6758-4048-a849-3b174fb6aff4.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/27200c5e-82e9-43cf-a69c-ca51d70ea8cc.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/e37a4230-1703-4ff1-9fb8-fc756fcf82cb.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/8dc6e9da-488c-4808-a570-cd52643e9942.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/f32aae4e-6758-4048-a849-3b174fb6aff4.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/27200c5e-82e9-43cf-a69c-ca51d70ea8cc.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/e37a4230-1703-4ff1-9fb8-fc756fcf82cb.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/8dc6e9da-488c-4808-a570-cd52643e9942.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("../fonts/f32aae4e-6758-4048-a849-3b174fb6aff4.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/27200c5e-82e9-43cf-a69c-ca51d70ea8cc.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/e37a4230-1703-4ff1-9fb8-fc756fcf82cb.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/8dc6e9da-488c-4808-a570-cd52643e9942.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/f32aae4e-6758-4048-a849-3b174fb6aff4.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic */
@font-face {
  font-family: 'Tenor Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/2ab427b8-61b1-455c-8251-e16c6beec647.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* latin-ext */
@font-face {
  font-family: 'Tenor Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/b9ecee7e-a616-4df0-ae33-868f8928c837.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Tenor Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/7e69b1cd-aac9-41f8-8c6e-1bf90cba5f52.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* 22Fotoholic — Editorial photography studio
   Type: Cormorant Garamond (display) + Jost (sans)
   Palette: ivory / paper / beige / taupe / ink
*/

:root {
  --ivory: #FFFFFF;
  --paper: #FFFFFF;
  --beige: #F2F2F2;
  --taupe: #000000;
  --taupe-soft: #BFBFBF;
  --line: #E2E2E2;
  --ink: #0A0A0A;
  --ink-soft: #3A3A3A;
  --muted: #8A8A8A;

  --serif: "Playfair Display", "Times New Roman", serif;
  --sans: "Darker Grotesque", "Helvetica Neue", Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Type scale — strict, professional editorial */
  --t-display-xl: clamp(44px, 7vw, 96px);
  --t-display-l:  clamp(38px, 5.4vw, 76px);
  --t-display-m:  clamp(30px, 4vw, 56px);
  --t-display-s:  clamp(24px, 2.8vw, 38px);
  --t-h1: clamp(28px, 3.2vw, 44px);
  --t-h2: clamp(24px, 3vw, 40px);
  --t-h3: clamp(18px, 1.8vw, 24px);
  --t-body:    16px;
  --t-body-sm: 14px;
  --t-label:   11px;
  --t-mono:    10px;

  --max: 1400px;
  --gutter: clamp(28px, 4vw, 56px);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body.dark {
  background: #0A0A0A;
  color: #FFFFFF;
}

img, svg { display: block; max-width: 100%; }

button { font-family: inherit; cursor: pointer; }

a { color: inherit; text-decoration: none; }

::selection { background: var(--ink); color: var(--ivory); }

/* ----- Typography utilities ----- */
.label {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.label.muted { color: var(--muted); }
.label.ivory { color: var(--ivory); opacity: 0.7; }

.eyebrow {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.36em;
  text-transform: uppercase;
}

.serif {
  font-family: var(--serif);
  font-weight: 400;
}
.serif-italic {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
}

.display {
  font-family: var(--serif);
  font-weight: 400;
  line-height: 0.92;
  letter-spacing: -0.015em;
}

.h-mono {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ----- Layout ----- */
.container {
  width: 100%;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.full {
  width: 100%;
  padding: 0 var(--gutter);
}

.hairline {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 0;
}
.hairline.ink {
  border-color: rgba(0,0,0,0.18);
}
.hairline.ivory {
  border-color: rgba(255,255,255,0.18);
}

/* ----- Buttons ----- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 26px;
  border: 1px solid var(--ink);
  background: transparent;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 400;
  border-radius: 999px;
  transition: all 0.5s var(--ease);
}
.btn:hover {
  background: var(--ink);
  color: var(--ivory);
}
.btn .arrow { display: inline-block; transition: transform 0.5s var(--ease); }
.btn:hover .arrow { transform: translateX(6px); }

.btn.solid {
  background: var(--ink);
  color: var(--ivory);
}
.btn.solid:hover {
  background: transparent;
  color: var(--ink);
}

.btn.ivory {
  border-color: var(--ivory);
  color: var(--ivory);
}
.btn.ivory:hover {
  background: var(--ivory);
  color: var(--ink);
}

.btn.ghost {
  border: none;
  padding: 8px 0;
  border-radius: 0;
  border-bottom: 1px solid currentColor;
  letter-spacing: 0.22em;
}
.btn.ghost:hover {
  background: transparent;
  color: var(--ink);
  letter-spacing: 0.28em;
}

.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 400;
  border-bottom: 1px solid currentColor;
  padding-bottom: 4px;
  transition: gap 0.4s var(--ease);
}
.link-arrow:hover { gap: 18px; }

/* ----- Placeholders ----- */
.ph {
  position: relative;
  width: 100%;
  overflow: hidden;
  background:
    repeating-linear-gradient(
      135deg,
      rgba(0,0,0,0.04) 0 1px,
      transparent 1px 9px
    ),
    linear-gradient(180deg, #E8E8E8 0%, #C9C9C9 100%);
  color: var(--ink);
}
.ph.dark {
  background:
    repeating-linear-gradient(
      135deg,
      rgba(255,255,255,0.05) 0 1px,
      transparent 1px 9px
    ),
    linear-gradient(180deg, #2B2B2B 0%, #0A0A0A 100%);
  color: #FFFFFF;
}
.ph.warm {
  background:
    repeating-linear-gradient(
      135deg,
      rgba(0,0,0,0.04) 0 1px,
      transparent 1px 9px
    ),
    linear-gradient(180deg, #DCDCDC 0%, #A8A8A8 100%);
}
.ph.green {
  background:
    repeating-linear-gradient(
      135deg,
      rgba(0,0,0,0.04) 0 1px,
      transparent 1px 9px
    ),
    linear-gradient(180deg, #B5B5B5 0%, #707070 100%);
}
.ph .ph-label {
  position: absolute;
  top: 14px;
  left: 14px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.65;
}
.ph .ph-num {
  position: absolute;
  bottom: 14px;
  right: 14px;
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.18em;
  opacity: 0.55;
}
.ph .ph-center {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(20px, 3vw, 38px);
  opacity: 0.55;
}

/* hover zoom wrapper */
.zoom {
  overflow: hidden;
}
.zoom .ph {
  transition: transform 1.4s var(--ease);
}
.zoom:hover .ph {
  transform: scale(1.04);
}

/* ----- Nav ----- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 80;
  padding: 18px var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  transition: background 0.5s var(--ease), backdrop-filter 0.5s var(--ease), padding 0.4s var(--ease), color 0.4s var(--ease);
}
.nav.scrolled {
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(0,0,0,0.06);
  padding: 12px var(--gutter);
}
.nav.dark.scrolled {
  background: rgba(0,0,0,0.78);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.nav.dark { color: var(--ivory); }
/* When mobile drawer is open, swap nav colors to dark over the drawer */
.nav.open { color: #FFFFFF; }
.nav.open.scrolled { background: transparent; backdrop-filter: none; border-bottom-color: transparent; }

.nav .brand {
  font-family: var(--serif);
  font-style: italic;
  font-size: 20px;
  letter-spacing: 0.01em;
  display: flex;
  align-items: baseline;
  gap: 6px;
  white-space: nowrap;
}
.nav .brand .mark {
  font-family: var(--serif);
  font-style: normal;
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--muted);
}
.nav.dark .brand .mark, .nav.open .brand .mark { color: var(--taupe-soft); }

.nav-links {
  display: flex;
  gap: 30px;
  align-items: center;
}
.nav-link {
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  position: relative;
  padding: 6px 0;
  color: inherit;
  background: none;
  border: 0;
  cursor: pointer;
  font-family: var(--sans);
  white-space: nowrap;
}
.nav-link::after {
  content: "";
  position: absolute;
  left: 0; right: 100%;
  bottom: 0;
  height: 1px;
  background: currentColor;
  transition: right 0.5s var(--ease);
}
.nav-link:hover::after,
.nav-link.active::after { right: 0; }

.nav-right {
  display: flex;
  align-items: center;
  gap: 14px;
}
.nav-cta {
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 10px 18px;
  border: 1px solid currentColor;
  border-radius: 999px;
  background: none;
  color: inherit;
  cursor: pointer;
  transition: all 0.4s var(--ease);
  font-family: var(--sans);
  white-space: nowrap;
}
.nav-cta:hover {
  background: currentColor;
}
.nav-cta:hover span { color: var(--paper); }
.nav.dark .nav-cta:hover span, .nav.open .nav-cta:hover span { color: var(--ink); }

.nav-burger {
  display: none;
  width: 40px; height: 40px;
  border: 1px solid currentColor;
  border-radius: 999px;
  background: transparent;
  color: inherit;
  cursor: pointer;
  position: relative;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  transition: background 0.4s var(--ease);
}
.nav-burger span {
  display: block;
  width: 14px; height: 1px;
  background: currentColor;
  transition: transform 0.4s var(--ease), opacity 0.3s var(--ease);
}
.nav-burger.on span:nth-child(1) { transform: rotate(45deg) translate(2px, 3px); }
.nav-burger.on span:nth-child(2) { transform: rotate(-45deg) translate(2px, -3px); }

/* ----- Language switcher (TranslatePress, optional) ----- */
/* Rendered only when a multilingual plugin is active (see
   fotoholic_classic_lang_switcher). The wrapper inherits the nav's current
   colour; the inner rules neutralise TranslatePress's default chrome so the
   switcher reads as plain uppercase nav text in both the bar and the drawer. */
.nav-lang {
  display: inline-flex;
  align-items: center;
  gap: 10px; /* keep VI / EN from reading as one word */
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  font-weight: 500;
  color: inherit;
}
.nav-lang--bar .trp_language_switcher_shortcode > *:not(:last-child)::after,
.nav-lang--bar > a:not(:last-child)::after {
  content: "/";
  margin-left: 10px;
  opacity: 0.4;
}
.nav-lang .trp-language-switcher,
.nav-lang .trp-language-switcher-container { display: inline-flex; align-items: center; }
.nav-lang a,
.nav-lang select,
.nav-lang .trp_language_switcher_shortcode {
  color: inherit;
  background: none;
  border: 0;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  cursor: pointer;
  opacity: 0.65;
  transition: opacity 0.3s var(--ease);
}
.nav-lang a:hover,
.nav-lang a.trp-ls-disabled-language { opacity: 1; }
.nav-lang img { display: none; } /* drop flag images — keep it text-only */

.nav-lang--drawer {
  margin: 28px 0 0;
  font-size: 13px;
  color: #FFFFFF;
}

/* Mobile breakpoints */
@media (max-width: 1080px) {
  .nav-links { display: none; }
  .nav-burger { display: inline-flex; }
  .nav-lang--bar { display: none; } /* the drawer carries the switcher on mobile */
}
@media (max-width: 560px) {
  .nav-cta { display: none; }
}

/* ----- Nav drawer (mobile) ----- */
.nav-drawer {
  position: fixed;
  inset: 0;
  z-index: 75;
  background: #0A0A0A;
  color: #FFFFFF;
  transform: translateY(-100%);
  transition: transform 0.6s cubic-bezier(0.7, 0, 0.2, 1);
  pointer-events: none;
}
.nav-drawer.on {
  transform: translateY(0);
  pointer-events: auto;
}
.nav-drawer-inner {
  padding: 100px var(--gutter) 40px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 40px;
  overflow-y: auto;
}
.nav-drawer-eyebrow {
  font-family: var(--sans);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--taupe-soft);
}
.nav-drawer-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  flex: 1;
}
.nav-drawer-link {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 20px 0;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  color: #FFFFFF;
  font-family: var(--serif);
  font-size: clamp(28px, 5.5vw, 44px);
  font-weight: 400;
  letter-spacing: -0.01em;
  cursor: pointer;
  text-align: left;
  opacity: 0;
  transform: translateX(-20px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease), padding-left 0.4s var(--ease);
}
.nav-drawer.on .nav-drawer-link {
  opacity: 1;
  transform: translateX(0);
}
.nav-drawer-link:hover { padding-left: 12px; }
.nav-drawer-link.active .lbl { font-style: italic; }
.nav-drawer-link .n {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--taupe-soft);
}
.nav-drawer-link .ar {
  font-family: var(--sans);
  font-size: 18px;
  opacity: 0.5;
  transition: opacity 0.4s, transform 0.4s var(--ease);
}
.nav-drawer-link:hover .ar { opacity: 1; transform: translateX(6px); }

.nav-drawer-foot {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  padding-top: 30px;
  border-top: 1px solid rgba(255,255,255,0.18);
  font-size: 13px;
  line-height: 1.7;
  color: var(--taupe-soft);
  overflow-wrap: anywhere;
}
.nav-drawer-foot .label {
  display: block;
  margin-bottom: 10px;
  color: var(--taupe-soft);
}

/* ----- Footer ----- */
.footer {
  background: var(--ink);
  color: var(--ivory);
  padding: 100px var(--gutter) 40px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 60px;
  align-items: start;
}
.footer-headline {
  font-family: var(--serif);
  font-size: var(--t-display-m);
  line-height: 0.96;
  letter-spacing: -0.015em;
  max-width: 9ch;
}
.footer-headline em { font-style: italic; color: var(--taupe-soft); }
.footer h5 {
  font-family: var(--sans);
  font-weight: 400;
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  margin: 0 0 22px;
  color: var(--taupe-soft);
}
.footer ul {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer ul a {
  font-size: 14px;
  letter-spacing: 0.01em;
  opacity: 0.88;
  overflow-wrap: anywhere;
  transition: opacity 0.3s, padding-left 0.4s var(--ease);
}
.footer ul a:hover { opacity: 1; padding-left: 6px; }
.footer-base {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 40px;
  margin-top: 80px;
  border-top: 1px solid rgba(255,255,255,0.12);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--taupe-soft);
}

/* ----- Page transitions ----- */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(24px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes pageEnter {
  0% { opacity: 0; transform: translateY(40px) scale(0.99); filter: blur(4px); }
  60% { filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}
@keyframes lineReveal {
  from { transform: scaleX(0); }
  to { transform: scaleX(1); }
}
.fade-up {
  animation: fadeUp 1s var(--ease) both;
}
.fade-up.d1 { animation-delay: 0.1s; }
.fade-up.d2 { animation-delay: 0.2s; }
.fade-up.d3 { animation-delay: 0.3s; }
.fade-up.d4 { animation-delay: 0.4s; }
.fade-up.d5 { animation-delay: 0.5s; }
.fade-up.d6 { animation-delay: 0.6s; }

/* ----- Section base ----- */
section { position: relative; }
/* Vertical rhythm only — must NOT set horizontal padding, or the shorthand would
   clobber the inline gutter from a same-element `.container` (e.g.
   `.section-pad.container`) and push the section content flush to the screen edge.
   Horizontal gutter is owned by `.container` (same element or an inner wrapper). */
.section-pad { padding-block: clamp(72px, 9vw, 130px); }
.section-pad-sm { padding-block: clamp(64px, 8vw, 110px); }

/* ----- HERO ----- */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 120px var(--gutter) 60px;
  overflow: hidden;
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-bg .ph {
  position: absolute;
  inset: 0;
  filter: brightness(0.95);
}
.hero-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0) 60%, rgba(0,0,0,0.5) 100%);
}
.hero-inner {
  position: relative;
  z-index: 2;
  color: var(--ivory);
}
.hero-meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 40px;
  gap: 40px;
  flex-wrap: wrap;
}
.hero-title {
  font-family: var(--serif);
  font-size: var(--t-display-xl);
  line-height: 0.9;
  letter-spacing: -0.02em;
  margin: 0;
  font-weight: 400;
  text-wrap: balance;
}
.hero-title em {
  font-style: italic;
  font-weight: 400;
}
.hero-bottom {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 40px;
  margin-top: 50px;
  flex-wrap: wrap;
}
.hero-tag {
  max-width: 360px;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255,255,255,0.85);
}
.hero-counter {
  display: flex;
  gap: 40px;
}
.hero-counter > div {
  text-align: right;
}
.hero-counter .num {
  font-family: var(--serif);
  font-size: 44px;
  line-height: 1;
}

/* ----- Marquee ----- */
.marquee {
  overflow: hidden;
  padding: 28px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--ivory);
}
.marquee-track {
  display: flex;
  gap: 60px;
  animation: marquee 40s linear infinite;
  white-space: nowrap;
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(22px, 2.6vw, 36px);
  color: var(--ink-soft);
}
.marquee-track span { display: inline-flex; align-items: center; gap: 60px; }
.marquee-track .dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--taupe);
}
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ----- About split ----- */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 60px);
  align-items: start;
}
.about-image-stack {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.about-image-stack .ph.tall { aspect-ratio: 3 / 4.4; grid-row: span 2; margin-top: 60px; }
.about-image-stack .ph.short { aspect-ratio: 3 / 4; }
.about-copy h2 {
  font-family: var(--serif);
  font-size: var(--t-display-m);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 30px 0 30px;
  font-weight: 400;
  text-wrap: balance;
}
.about-copy h2 em { font-style: italic; color: var(--taupe); }
.about-copy p {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 46ch;
  margin: 0 0 22px;
}
.signature {
  font-family: var(--serif);
  font-style: italic;
  font-size: 38px;
  color: var(--ink);
  margin-top: 30px;
  display: inline-block;
  transform: rotate(-3deg);
}

/* ----- Top Concepts (editorial cards) ----- */
.concepts-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 40px;
  margin-bottom: 60px;
}
.concepts-header h2 {
  font-family: var(--serif);
  font-size: var(--t-display-m);
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin: 16px 0 0;
  font-weight: 400;
  max-width: 14ch;
}
.concepts-header h2 em { font-style: italic; color: var(--taupe); }

.concepts-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 24px;
}
.cc {
  position: relative;
  cursor: pointer;
}
.cc .ph { aspect-ratio: 3 / 4; }
.cc.wide .ph { aspect-ratio: 5 / 4; }
.cc.tall .ph { aspect-ratio: 3 / 4.6; }
.cc .meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: 16px;
}
.cc .meta h3 {
  font-family: var(--serif);
  font-style: italic;
  font-size: 26px;
  font-weight: 400;
  margin: 0;
}
.cc .meta .num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  color: var(--muted);
}
.cc .tag {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 4px;
}
.cc:hover .ph { transform: scale(1.03); }
.cc-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: 24px;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,0.55) 100%);
  opacity: 0;
  transition: opacity 0.5s var(--ease);
  color: var(--ivory);
}
.cc:hover .cc-overlay { opacity: 1; }
.cc-overlay .view {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--ivory);
  padding-bottom: 3px;
}

/* Specific grid placements */
.cc.s1 { grid-column: span 5; }
.cc.s2 { grid-column: span 4; margin-top: 80px; }
.cc.s3 { grid-column: span 3; }
.cc.s4 { grid-column: span 4; }
.cc.s5 { grid-column: span 4; margin-top: -40px; }
.cc.s6 { grid-column: span 4; margin-top: 30px; }

@media (max-width: 900px) {
  .concepts-grid { grid-template-columns: repeat(2, 1fr); }
  .cc.s1, .cc.s2, .cc.s3, .cc.s4, .cc.s5, .cc.s6 { grid-column: span 1; margin-top: 0; }
}

/* ----- Services rows ----- */
.services-grid {
  display: grid;
  grid-template-columns: 0.7fr 2.5fr 1fr 1fr 0.5fr;
  gap: 24px;
  align-items: center;
  padding: 32px 0;
  border-bottom: 1px solid var(--line);
  transition: padding 0.4s var(--ease), background 0.4s var(--ease);
  cursor: pointer;
}
.services-grid:first-of-type { border-top: 1px solid var(--line); }
.services-grid:hover { padding-left: 16px; }
.services-grid .num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--muted);
}
.services-grid .title {
  font-family: var(--serif);
  font-size: var(--t-h2);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
}
.services-grid .title em { font-style: italic; color: var(--taupe); }
.services-grid .desc {
  font-size: 13px;
  color: var(--muted);
  margin-top: 6px;
  max-width: 50ch;
}
.services-grid .price {
  font-family: var(--serif);
  font-size: 22px;
}
.services-grid .duration {
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
}
.services-grid .arrow {
  text-align: right;
  font-family: var(--mono);
  font-size: 18px;
  color: var(--ink);
}

@media (max-width: 800px) {
  .services-grid { grid-template-columns: auto 1fr auto; }
  .services-grid .desc, .services-grid .duration { display: none; }
}

/* ----- FAQ ----- */
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 28px 0;
}
.faq-item .q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  cursor: pointer;
}
.faq-item .q-text {
  font-family: var(--serif);
  font-size: var(--t-h2);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 0;
  flex: 1;
}
.faq-item .q-text em { font-style: italic; color: var(--taupe); }
.faq-item .toggle {
  width: 28px; height: 28px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--ink);
  transition: transform 0.55s var(--ease), color 0.4s;
}
.faq-item .toggle svg { display: block; }
.faq-item.open .toggle {
  transform: rotate(180deg);
}
.faq-item .a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s var(--ease), margin 0.4s var(--ease);
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.75;
  max-width: 70ch;
}
.faq-item.open .a {
  max-height: 800px;
  margin-top: 22px;
}

/* ----- Testimonials ----- */
.testi {
  display: grid;
  grid-template-columns: 0.9fr 1.5fr;
  gap: clamp(32px, 4vw, 60px);
  align-items: center;
}
.testi-image .ph { aspect-ratio: 4 / 5; }
.testi-quote {
  font-family: var(--serif);
  font-size: var(--t-h1);
  line-height: 1.18;
  letter-spacing: -0.01em;
  text-wrap: balance;
  font-weight: 400;
  color: var(--ink);
}
.testi-quote em { font-style: italic; color: var(--taupe); }
.testi-quote::before {
  content: "“";
  font-family: var(--serif);
  font-style: italic;
  font-size: 1em;
  color: var(--taupe);
  line-height: 0;
  display: block;
  margin-bottom: 30px;
}
.testi-author {
  margin-top: 36px;
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.testi-author::before {
  content: "";
  width: 28px; height: 1px;
  background: var(--taupe);
  display: inline-block;
}
.testi-nav {
  display: flex;
  gap: 14px;
  margin-top: 40px;
}
.testi-nav button {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--ink);
  background: transparent;
  font-family: var(--mono);
  font-size: 12px;
  transition: all 0.4s var(--ease);
}
.testi-nav button:hover { background: var(--ink); color: var(--ivory); }

/* ----- Concept page ----- */
.cp-hero {
  padding: 180px var(--gutter) 60px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: 60px;
  border-bottom: 1px solid var(--line);
}
.cp-hero h1 {
  font-family: var(--serif);
  font-size: var(--t-display-l);
  line-height: 0.9;
  letter-spacing: -0.025em;
  margin: 0;
  font-weight: 400;
}
.cp-hero h1 em { font-style: italic; color: var(--taupe); }
.cp-hero .lede {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 42ch;
}

.cp-cat-tabs {
  display: flex;
  gap: 8px;
  padding: 30px var(--gutter);
  border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
  background: var(--paper);
  position: sticky;
  top: 64px;
  z-index: 20;
  backdrop-filter: blur(8px);
}
.cp-cat-tab {
  padding: 10px 22px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: transparent;
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 0.4s var(--ease);
}
.cp-cat-tab:hover { border-color: var(--ink); color: var(--ink); }
.cp-cat-tab.active {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--ivory);
}
.cp-cat-tab .count {
  font-family: var(--mono);
  font-size: 9px;
  margin-left: 8px;
  opacity: 0.55;
}

.cp-collection {
  padding: 70px var(--gutter);
}
.cp-coll-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 40px;
  flex-wrap: wrap;
  gap: 20px;
}
.cp-coll-header h2 {
  font-family: var(--serif);
  font-size: var(--t-display-s);
  font-weight: 400;
  letter-spacing: -0.02em;
  margin: 0;
}
.cp-coll-header h2 em { font-style: italic; color: var(--taupe); }
.cp-coll-header .meta {
  display: flex;
  gap: 24px;
  align-items: baseline;
  color: var(--muted);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.cp-subs {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-bottom: 60px;
}
.cp-sub {
  cursor: pointer;
  position: relative;
}
.cp-sub .ph { aspect-ratio: 3 / 4; }
.cp-sub .row {
  display: flex;
  justify-content: space-between;
  margin-top: 14px;
  align-items: baseline;
}
.cp-sub h3 {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 400;
  margin: 0;
  font-style: italic;
}
.cp-sub .ct {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--muted);
}
.cp-sub .sub-tag {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-top: 2px;
}

@media (max-width: 900px) {
  .cp-subs { grid-template-columns: repeat(2, 1fr); }
  .cp-hero { grid-template-columns: 1fr; }
}

/* Collection detail (expanded) */
.cp-detail {
  background: var(--ivory);
  padding: 60px var(--gutter);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.cp-detail-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 80px;
  gap: 16px;
}
.cp-detail-grid .ph {
  width: 100%;
  height: 100%;
}
.gi1 { grid-column: span 5; grid-row: span 5; }
.gi2 { grid-column: span 4; grid-row: span 3; }
.gi3 { grid-column: span 3; grid-row: span 4; }
.gi4 { grid-column: span 3; grid-row: span 3; }
.gi5 { grid-column: span 4; grid-row: span 4; }
.gi6 { grid-column: span 5; grid-row: span 3; }
.gi7 { grid-column: span 4; grid-row: span 3; }
.gi8 { grid-column: span 8; grid-row: span 3; }

@media (max-width: 900px) {
  .cp-detail-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 200px; }
  .cp-detail-grid > * { grid-column: span 1 !important; grid-row: span 1 !important; }
}

/* ----- Pricing page ----- */
.pp-hero {
  padding: 180px var(--gutter) 70px;
  text-align: left;
}
.pp-hero h1 {
  font-family: var(--serif);
  font-size: var(--t-display-l);
  line-height: 0.9;
  letter-spacing: -0.025em;
  margin: 0;
  font-weight: 400;
  max-width: 12ch;
}
.pp-hero h1 em { font-style: italic; color: var(--taupe); }
.pp-hero .lede {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 48ch;
  margin-top: 36px;
}

.pp-tier {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--line);
  min-height: 80vh;
}
.pp-tier:last-child { border-bottom: 1px solid var(--line); }
.pp-tier.reverse { direction: rtl; }
.pp-tier.reverse > * { direction: ltr; }
.pp-tier-image {
  background: var(--ivory);
  padding: 60px;
  display: grid;
  place-items: center;
}
.pp-tier-image .ph {
  width: 100%;
  height: 100%;
  aspect-ratio: 4 / 5;
  max-height: 720px;
  border-radius: 4px;
}
.pp-tier-body {
  padding: clamp(28px, 3.5vw, 56px) var(--t-display-m);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 32px;
}
.pp-tier-body h2 {
  font-family: var(--serif);
  font-size: var(--t-display-m);
  line-height: 0.96;
  letter-spacing: -0.02em;
  margin: 0;
  font-weight: 400;
}
.pp-tier-body h2 em { font-style: italic; }
.pp-tier-body p.lede {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 44ch;
  margin: 0;
}
.pp-incl {
  margin: 12px 0 0;
}
.pp-incl-label {
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
}
.pp-incl ul {
  list-style: none;
  margin: 0; padding: 0;
  display: grid;
  gap: 8px;
}
.pp-incl li {
  font-size: 14px;
  color: var(--ink-soft);
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.pp-incl li::before {
  content: "";
  width: 4px; height: 4px;
  border-radius: 50%;
  background: var(--taupe);
  display: inline-block;
  flex-shrink: 0;
}
.pp-rows {
  display: grid;
  gap: 0;
  margin-top: 12px;
}
.pp-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  gap: 24px;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
}
.pp-row .name {
  font-size: 12px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.pp-row .name em {
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--ink);
  font-style: italic;
  margin-right: 12px;
}
.pp-row .price {
  font-family: var(--serif);
  font-size: 22px;
}
.pp-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 14px;
}

@media (max-width: 900px) {
  .pp-tier { grid-template-columns: 1fr; }
  .pp-tier.reverse { direction: ltr; }
}

/* ----- Premium By Vàng (dark) ----- */
.pv-page {
  background: #0A0A0A;
  color: #FFFFFF;
}
.pv-hero {
  min-height: 100vh;
  min-height: 100svh;
  padding: 140px var(--gutter) 60px;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
}
.pv-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.pv-hero-bg .ph {
  position: absolute;
  inset: 0;
  filter: brightness(0.7) sepia(0.15);
}
.pv-hero-bg::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.6) 0%, rgba(0,0,0,0.1) 35%, rgba(0,0,0,0.9) 100%);
}
.pv-hero-inner {
  position: relative;
  z-index: 2;
}
.pv-eyebrow {
  font-size: 11px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  color: var(--taupe-soft);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.pv-eyebrow::before {
  content: "";
  width: 40px; height: 1px;
  background: var(--taupe-soft);
}
.pv-hero h1 {
  font-family: var(--serif);
  font-size: var(--t-display-xl);
  line-height: 0.88;
  letter-spacing: -0.025em;
  font-weight: 400;
  margin: 0;
  max-width: 12ch;
}
.pv-hero h1 em { font-style: italic; color: #FFFFFF; }
.pv-hero-meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: 60px;
  gap: 40px;
  flex-wrap: wrap;
}
.pv-hero-tag {
  max-width: 44ch;
  font-size: 14px;
  line-height: 1.75;
  color: rgba(255,255,255,0.78);
}
.pv-signature {
  font-family: var(--serif);
  font-style: italic;
  font-size: 44px;
  color: var(--taupe-soft);
  transform: rotate(-3deg);
  white-space: nowrap;
}

.pv-section {
  padding: clamp(64px, 8vw, 110px) var(--gutter);
  border-top: 1px solid rgba(255,255,255,0.1);
}
.pv-philosophy {
  display: grid;
  grid-template-columns: 0.4fr 1.4fr;
  gap: clamp(32px, 4vw, 60px);
  align-items: start;
}
.pv-philosophy .label { color: var(--taupe-soft); }
.pv-philosophy h2 {
  font-family: var(--serif);
  font-size: var(--t-display-s);
  line-height: 1.06;
  letter-spacing: -0.015em;
  font-weight: 400;
  margin: 0 0 36px;
  text-wrap: balance;
}
.pv-philosophy h2 em { font-style: italic; color: #FFFFFF; }
.pv-philosophy p {
  font-size: 16px;
  line-height: 1.85;
  color: rgba(255,255,255,0.82);
  max-width: 58ch;
  margin: 0 0 22px;
}

.pv-process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 60px;
}
.pv-step {
  padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.18);
}
.pv-step .n {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  color: var(--taupe-soft);
}
.pv-step h4 {
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 26px 0 14px;
}
.pv-step h4 em { font-style: italic; color: #FFFFFF; }
.pv-step p {
  font-size: 13px;
  line-height: 1.7;
  color: rgba(255,255,255,0.72);
  margin: 0;
}

.pv-gallery {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 100px;
  gap: 18px;
  margin-top: 50px;
}
.pv-gallery .ph.dark { border-radius: 2px; }
.pvg1 { grid-column: span 7; grid-row: span 5; }
.pvg2 { grid-column: span 5; grid-row: span 3; }
.pvg3 { grid-column: span 5; grid-row: span 2; }
.pvg4 { grid-column: span 6; grid-row: span 4; }
.pvg5 { grid-column: span 6; grid-row: span 4; }

.pv-booking {
  text-align: center;
  padding: clamp(64px, 8vw, 110px) var(--gutter);
}
.pv-booking h2 {
  font-family: var(--serif);
  font-size: var(--t-display-l);
  line-height: 0.95;
  letter-spacing: -0.025em;
  font-weight: 400;
  margin: 0 0 40px;
  text-wrap: balance;
}
.pv-booking h2 em { font-style: italic; color: #FFFFFF; }
.pv-booking p {
  color: var(--taupe-soft);
  max-width: 50ch;
  margin: 0 auto 40px;
  line-height: 1.75;
}
.pv-booking .btn.ivory { padding: 22px 44px; font-size: 12px; }

/* Limited atmosphere */
.pv-limited {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin-top: 60px;
  border-top: 1px solid rgba(255,255,255,0.18);
  border-bottom: 1px solid rgba(255,255,255,0.18);
}
.pv-limited > div {
  padding: 36px 24px;
  border-right: 1px solid rgba(255,255,255,0.18);
  text-align: center;
}
.pv-limited > div:last-child { border-right: none; }
.pv-limited .lbl {
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--taupe-soft);
  margin-bottom: 10px;
}
.pv-limited .v {
  font-family: var(--serif);
  font-size: 40px;
  line-height: 1;
  letter-spacing: -0.01em;
}
.pv-limited .v em { font-style: italic; color: #FFFFFF; }

@media (max-width: 900px) {
  .pv-philosophy { grid-template-columns: 1fr; }
  .pv-process-grid { grid-template-columns: 1fr 1fr; }
  .pv-limited { grid-template-columns: 1fr; }
  .pv-limited > div { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.18); }
}

/* ----- Story page ----- */
.st-hero {
  padding: 180px var(--gutter) 60px;
}
.st-hero h1 {
  font-family: var(--serif);
  font-size: var(--t-display-l);
  line-height: 0.9;
  letter-spacing: -0.025em;
  font-weight: 400;
  margin: 0;
  text-wrap: balance;
  max-width: 16ch;
}
.st-hero h1 em { font-style: italic; color: var(--taupe); }
.st-meta {
  display: flex;
  gap: 80px;
  margin-top: 60px;
  flex-wrap: wrap;
  border-top: 1px solid var(--line);
  padding-top: 36px;
}
.st-meta > div .label { margin-bottom: 6px; }
.st-meta > div .v {
  font-family: var(--serif);
  font-size: 22px;
  font-style: italic;
}

.st-feature {
  padding: clamp(48px, 6vw, 80px) var(--gutter);
}
.st-feature .ph { aspect-ratio: 16 / 8; }
.st-feature .cap {
  display: flex;
  justify-content: space-between;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 14px;
}

.st-chapter {
  padding: clamp(48px, 6vw, 80px) var(--gutter);
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: clamp(40px, 7vw, 100px);
  align-items: start;
  border-top: 1px solid var(--line);
}
.st-chapter.alt { grid-template-columns: 1.4fr 1fr; }
.st-chapter.alt .st-chap-image { order: 2; }
.st-chap-image .ph { aspect-ratio: 4 / 5; }
.st-chap-body .n {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  color: var(--muted);
}
.st-chap-body h2 {
  font-family: var(--serif);
  font-size: var(--t-display-s);
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-weight: 400;
  margin: 18px 0 30px;
  text-wrap: balance;
}
.st-chap-body h2 em { font-style: italic; color: var(--taupe); }
.st-chap-body p {
  font-size: 15px;
  line-height: 1.85;
  color: var(--ink-soft);
  max-width: 52ch;
  margin: 0 0 18px;
}
.st-chap-body .pull {
  font-family: var(--serif);
  font-style: italic;
  font-size: var(--t-h2);
  line-height: 1.3;
  color: var(--taupe);
  border-left: 1px solid var(--taupe);
  padding-left: 24px;
  margin: 30px 0;
  max-width: 40ch;
}

@media (max-width: 900px) {
  .st-chapter, .st-chapter.alt { grid-template-columns: 1fr; }
  .st-chapter.alt .st-chap-image { order: 0; }
}

/* ----- Contact ----- */
.ct-page {
  padding: 180px var(--gutter) 80px;
}
.ct-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(32px, 4vw, 60px);
  align-items: start;
}
.ct-grid h1 {
  font-family: var(--serif);
  font-size: var(--t-display-l);
  line-height: 0.92;
  letter-spacing: -0.025em;
  font-weight: 400;
  margin: 0;
}
.ct-grid h1 em { font-style: italic; color: var(--taupe); }
.ct-lede {
  font-size: 15px;
  line-height: 1.75;
  color: var(--ink-soft);
  max-width: 42ch;
  margin: 36px 0;
}
.ct-info {
  margin-top: 50px;
  display: grid;
  gap: 30px;
}
.ct-info > div .label { margin-bottom: 8px; }
.ct-info > div .v {
  font-family: var(--serif);
  font-size: 22px;
  font-style: italic;
}

.ct-form {
  background: var(--ivory);
  padding: clamp(28px, 3.5vw, 50px);
  border-radius: 4px;
}
.ct-form h3 {
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 400;
  font-style: italic;
  margin: 0 0 30px;
}
.ct-field {
  margin-bottom: 22px;
}
.ct-field label {
  display: block;
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 8px;
}
.ct-field input,
.ct-field textarea,
.ct-field select {
  width: 100%;
  border: 0;
  border-bottom: 1px solid var(--line);
  background: transparent;
  padding: 10px 0;
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink);
  outline: none;
  resize: none;
  transition: border-color 0.3s;
  border-radius: 0;
}
.ct-field input:focus,
.ct-field textarea:focus,
.ct-field select:focus { border-color: var(--ink); }
.ct-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.ct-concepts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ct-chip {
  padding: 8px 16px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s;
  background: transparent;
  color: var(--ink-soft);
  font-family: var(--sans);
}
.ct-chip:hover { border-color: var(--ink); color: var(--ink); }
.ct-chip.on {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--ivory);
}

@media (max-width: 900px) {
  .ct-grid, .ct-row { grid-template-columns: 1fr; }
}

/* ----- FAQ Page (full) ----- */
.fq-page {
  padding: 180px var(--gutter) 100px;
}
.fq-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 7vw, 100px);
  align-items: end;
  margin-bottom: 80px;
}
.fq-head h1 {
  font-family: var(--serif);
  font-size: var(--t-display-l);
  line-height: 0.92;
  letter-spacing: -0.025em;
  font-weight: 400;
  margin: 0;
}
.fq-head h1 em { font-style: italic; color: var(--taupe); }
.fq-head p {
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.75;
  max-width: 40ch;
}

.fq-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 40px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 16px;
  flex-wrap: wrap;
}
.fq-tab {
  padding: 8px 18px;
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  cursor: pointer;
  transition: all 0.3s;
  font-family: var(--sans);
}
.fq-tab:hover { border-color: var(--ink); color: var(--ink); }
.fq-tab.active { background: var(--ink); border-color: var(--ink); color: var(--ivory); }

@media (max-width: 900px) {
  .fq-head { grid-template-columns: 1fr; }
}

/* Cursor follow custom on imagery (skip for now — keep performant) */

/* helper */
.flex-between { display: flex; justify-content: space-between; align-items: center; gap: 20px; }
.flex-col { display: flex; flex-direction: column; }

/* page wrapper transition */
.page {
  animation: pageEnter 1.1s var(--ease) both;
}

/* Tweaks overrides target */
body.theme-cool { --taupe: #000000; --taupe-soft: #B0B0B0; --line: #E2E2E2; }
body.theme-neutral { --taupe: #2A2A2A; --taupe-soft: #C0C0C0; --line: #E5E5E5; }
body.font-modern { --serif: "Tenor Sans", "Playfair Display", serif; --sans: "Archivo", "Darker Grotesque", sans-serif; }
body.font-classic { --serif: "Playfair Display", "Times New Roman", serif; --sans: "Darker Grotesque", sans-serif; }
body.font-bold { --serif: "DM Serif Display", "Playfair Display", serif; --sans: "Manrope", "Darker Grotesque", sans-serif; }

/* ============================================================
   Refinements — content boxes, process steps, frame collage,
   refined hover, section headers without em-dash
   ============================================================ */

/* Label: cleaner now without "—" prefix — add a subtle underline reveal on hover when parent is hoverable */
.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 60px;
  margin-bottom: clamp(28px, 3.5vw, 56px);
  flex-wrap: wrap;
}
.section-head .lhs { max-width: 22ch; }
.section-head .lhs .label { display: inline-block; padding-bottom: 12px; position: relative; }
.section-head .lhs .label::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 32px; height: 1px;
  background: currentColor;
  transform-origin: left;
  animation: lineReveal 0.9s var(--ease) both;
}
.section-head h2 {
  font-family: var(--serif);
  font-size: var(--t-display-m);
  line-height: 0.96;
  letter-spacing: -0.02em;
  margin: 24px 0 0;
  font-weight: 400;
  text-wrap: balance;
}
.section-head h2 em { font-style: italic; }
.section-head .rhs {
  max-width: 36ch;
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.75;
}

/* Content box — bordered card on warm-white */
.box {
  background: #FFFFFF;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: clamp(28px, 3.5vw, 50px);
  transition: border-color 0.6s var(--ease), transform 0.7s var(--ease), box-shadow 0.6s var(--ease);
}
.box.tinted { background: #F7F7F7; }
.box.hover:hover {
  border-color: var(--ink);
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -40px rgba(0,0,0,0.18);
}
.box.dark {
  background: #0A0A0A;
  color: #FFFFFF;
  border-color: rgba(255,255,255,0.12);
}

/* Process step grid (replaces old service-as-price rows on home) */
.process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
.process.process-5 { grid-template-columns: repeat(5, 1fr); }
.process-step {
  padding: 50px 36px 60px 0;
  border-right: 1px solid var(--line);
  cursor: default;
  position: relative;
  transition: padding 0.6s var(--ease), background 0.6s var(--ease);
}
.process-step:last-child { border-right: none; }
.process-step::before {
  content: "";
  position: absolute;
  top: -1px; left: 0;
  width: 0; height: 2px;
  background: var(--ink);
  transition: width 0.7s var(--ease);
}
.process-step:hover::before { width: 100%; }
.process-step:hover { padding-top: 60px; }
.process-step .step-n {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  color: var(--muted);
}
.process-step h4 {
  font-family: var(--serif);
  font-size: clamp(26px, 2.6vw, 36px);
  font-weight: 400;
  letter-spacing: -0.01em;
  margin: 28px 0 14px;
  line-height: 1.05;
}
.process-step h4 em { font-style: italic; }
.process-step p {
  font-size: 14px;
  line-height: 1.75;
  color: var(--ink-soft);
  margin: 0;
  max-width: 28ch;
}
.process-step .arrow-out {
  margin-top: 28px;
  font-size: 18px;
  display: inline-block;
  transform: rotate(-45deg);
  opacity: 0.3;
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
}
.process-step:hover .arrow-out { opacity: 1; transform: rotate(0deg); }

@media (max-width: 1100px) {
  .process.process-5 { grid-template-columns: repeat(3, 1fr); }
  .process.process-5 .process-step:nth-child(3n) { border-right: none; }
  .process.process-5 .process-step:nth-child(-n+3) { border-bottom: 1px solid var(--line); }
}
@media (max-width: 900px) {
  .process { grid-template-columns: 1fr 1fr; }
  .process.process-5 { grid-template-columns: 1fr 1fr; }
  .process-step:nth-child(2n) { border-right: none; }
  .process-step:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .process.process-5 .process-step:nth-child(3n) { border-right: 1px solid var(--line); }
  .process.process-5 .process-step:nth-child(2n) { border-right: none; }
  .process.process-5 .process-step:nth-child(-n+4) { border-bottom: 1px solid var(--line); }
}
@media (max-width: 560px) {
  .process { grid-template-columns: 1fr; }
  .process-step { border-right: none; border-bottom: 1px solid var(--line); padding-bottom: 40px; }
  .process-step:last-child { border-bottom: none; }
}

/* Frame collage — asymmetric editorial moodboard */
.collage {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 60px;
  gap: 24px;
}
.collage .ph { width: 100%; height: 100%; transition: transform 1.2s var(--ease), filter 0.6s var(--ease); }
.collage .frame { position: relative; overflow: hidden; cursor: pointer; }
.collage .frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  transition: background 0.6s var(--ease);
}
.collage .frame:hover::after { background: rgba(0,0,0,0.12); }
.collage .frame:hover .ph { transform: scale(1.05); }
.collage .frame:hover ~ .frame .ph { filter: grayscale(1) brightness(0.92); }

.collage .frame .cap {
  position: absolute;
  bottom: 14px; left: 14px;
  color: #FFFFFF;
  font-family: var(--sans);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
  z-index: 2;
}
.collage .frame:hover .cap { opacity: 1; transform: translateY(0); }

.cf1 { grid-column: span 5; grid-row: span 6; }
.cf2 { grid-column: span 4; grid-row: span 4; margin-top: 60px; }
.cf3 { grid-column: span 3; grid-row: span 5; }
.cf4 { grid-column: span 3; grid-row: span 4; }
.cf5 { grid-column: span 4; grid-row: span 5; }
.cf6 { grid-column: span 5; grid-row: span 4; }

@media (max-width: 900px) {
  .collage { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 180px; }
  .collage > * { grid-column: span 1 !important; grid-row: span 1 !important; margin-top: 0 !important; }
}

/* Stronger hover on concept cards (top concepts grid) */
.cc { transition: opacity 0.6s var(--ease); }
.cc .ph { transition: transform 1.2s var(--ease), filter 0.6s var(--ease); }
.cc:hover .ph { transform: scale(1.05); }
.concepts-grid:hover .cc:not(:hover) { opacity: 0.45; }
.concepts-grid:hover .cc:not(:hover) .ph { filter: grayscale(1); }

/* Refined faq hover */
.faq-item { transition: padding 0.5s var(--ease); }
.faq-item:hover .q { padding-left: 8px; transition: padding 0.5s var(--ease); }
.faq-item .q { transition: padding 0.5s var(--ease); }

/* Refined nav link */
.nav-link { transition: opacity 0.4s var(--ease); }
.nav .nav-links:hover .nav-link:not(:hover) { opacity: 0.45; }

/* Subtle text reveal on scroll-style class */
.reveal { animation: fadeUp 1.1s var(--ease) both; }

/* Adjusted display font weight for Playfair (it's heavier than Cormorant) */
.display, .hero-title, .section-head h2, .testi-quote, .pp-hero h1, .pp-tier-body h2, .pv-hero h1, .pv-philosophy h2, .pv-booking h2, .cp-hero h1, .cp-coll-header h2, .st-hero h1, .st-chap-body h2, .fq-head h1, .ct-grid h1, .about-copy h2, .concepts-header h2, .footer-headline {
  font-weight: 400;
}

/* Quote box style — for editorial pull boxes */
.quote-box {
  background: #FFFFFF;
  border: 1px solid var(--line);
  padding: clamp(28px, 3.5vw, 50px) clamp(28px, 3.5vw, 56px);
  border-radius: 6px;
  text-align: left;
}
.quote-box .mark {
  font-family: var(--serif);
  font-style: italic;
  font-size: 80px;
  line-height: 0.4;
  color: var(--ink);
  display: block;
  margin-bottom: 24px;
}

/* Larger gutters for hero */
.hero { padding: 140px var(--gutter) 80px; }

/* Reduce verbosity on hero tagline */
.hero-tag { font-size: 15px; line-height: 1.7; max-width: 38ch; }

/* Section header without em-dash — letter-spacing animates on hover for h2 */
.concepts-header h2 em, .section-head h2 em, .about-copy h2 em { font-style: italic; }

/* ============================================================
   Directory — Home page section tiles (each = own page)
   ============================================================ */
.directory {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(0, auto);
  gap: clamp(28px, 4vw, 60px) clamp(28px, 4vw, 50px);
}
.d-tile {
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 28px;
  transition: opacity 0.6s var(--ease);
}
.d-wide { grid-column: span 4; }
.d-tall { grid-column: span 2; }
.d-half { grid-column: span 3; }
.d-image {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  position: relative;
}
.d-tile.d-tall .d-image { aspect-ratio: 3 / 4.2; }
.d-tile.d-half .d-image { aspect-ratio: 5 / 3; }
.d-image .ph {
  width: 100%; height: 100%;
  transition: transform 1.2s var(--ease), filter 0.6s var(--ease);
}
.d-tile:hover .d-image .ph { transform: scale(1.05); }
.d-image::after {
  content: "";
  position: absolute; inset: 0;
  background: rgba(0,0,0,0);
  transition: background 0.6s var(--ease);
  pointer-events: none;
}
.d-tile:hover .d-image::after { background: rgba(0,0,0,0.10); }

.directory:hover .d-tile:not(:hover) { opacity: 0.55; }
.directory:hover .d-tile:not(:hover) .ph { filter: grayscale(1) brightness(0.95); }

.d-meta { display: flex; flex-direction: column; gap: 18px; }
.d-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.d-title {
  font-family: var(--serif);
  font-size: var(--t-h1);
  font-weight: 400;
  letter-spacing: -0.02em;
  line-height: 0.98;
  margin: 0;
  text-wrap: balance;
}
.d-title em { font-style: italic; }
.d-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: 4px;
  transition: gap 0.5s var(--ease);
}
.d-tile:hover .d-link { gap: 22px; }
.d-link .d-arrow { transition: transform 0.5s var(--ease); }
.d-tile:hover .d-link .d-arrow { transform: translateX(6px); }

@media (max-width: 1100px) {
  .d-wide, .d-tall, .d-half { grid-column: span 3; }
}
@media (max-width: 700px) {
  .directory { grid-template-columns: 1fr; }
  .d-wide, .d-tall, .d-half { grid-column: span 1; }
  .d-tile.d-tall .d-image,
  .d-tile.d-half .d-image,
  .d-image { aspect-ratio: 4 / 3; }
}

/* ============================================================
   Concept page — Magazine Spread layout
   ============================================================ */

/* Volume Index strip (replaces pill tabs) */
.vol-index {
  position: sticky;
  top: 64px;
  z-index: 30;
  background: var(--paper);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.vol-index-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: stretch;
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.vol-index .vol-title {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 22px 30px 22px 0;
  border-right: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-soft);
  white-space: nowrap;
}
.vol-index .vol-title .v-num {
  font-family: var(--serif);
  font-style: italic;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-transform: none;
}
.vol-list {
  display: flex;
  align-items: center;
  overflow-x: auto;
  scrollbar-width: none;
}
.vol-list::-webkit-scrollbar { display: none; }
.vol-item {
  flex-shrink: 0;
  padding: 18px 22px;
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  transition: color 0.4s var(--ease);
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
}
.vol-item .v-n {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: 0.2em;
  opacity: 0.7;
}
.vol-item:hover { color: var(--ink); }
.vol-item.active { color: var(--ink); }
.vol-item.active::after {
  content: "";
  position: absolute;
  left: 22px; right: 22px;
  bottom: 12px;
  height: 1px;
  background: var(--ink);
}
.vol-cta {
  display: flex;
  align-items: center;
  padding: 22px 0 22px 30px;
  border-left: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  cursor: pointer;
  background: transparent;
  border-right: 0;
  border-top: 0;
  border-bottom: 0;
  color: var(--ink);
  white-space: nowrap;
}
@media (max-width: 900px) {
  .vol-index-inner { grid-template-columns: 1fr; }
  .vol-index .vol-title, .vol-cta { border: 0; padding: 16px 0; }
  .vol-list { padding: 0 0 12px; }
}

/* Spread — each category as a magazine spread */
.spread {
  position: relative;
  padding: clamp(64px, 8vw, 110px) var(--gutter);
  border-bottom: 1px solid var(--line);
}
.spread.tinted { background: #FAFAFA; }
.spread.dark { background: #0A0A0A; color: #FFFFFF; }
.spread.dark .label { color: rgba(255,255,255,0.7); }
.spread.dark .line, .spread.dark hr { border-color: rgba(255,255,255,0.18); }

.spread-folio {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 30px;
  margin-bottom: clamp(28px, 3.5vw, 50px);
  border-bottom: 1px solid currentColor;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--muted);
}
.spread.dark .spread-folio { color: rgba(255,255,255,0.6); }

.spread-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.55fr;
  gap: clamp(32px, 4vw, 60px);
  align-items: start;
}

.spread-side {
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: sticky;
  top: 160px;
}
.spread-volume {
  font-family: var(--serif);
  font-size: clamp(72px, 12vw, 160px);
  line-height: 0.78;
  letter-spacing: -0.04em;
  font-weight: 400;
  margin: 0;
  font-feature-settings: "lnum";
}
.spread-volume em { font-style: italic; }
.spread-volume sup {
  font-family: var(--sans);
  font-size: 14px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 500;
  vertical-align: top;
  display: inline-block;
  margin-left: 14px;
  margin-top: 18px;
  color: var(--ink-soft);
}
.spread.dark .spread-volume sup { color: rgba(255,255,255,0.65); }

.spread-title {
  font-family: var(--serif);
  font-size: var(--t-display-s);
  line-height: 1.02;
  letter-spacing: -0.015em;
  font-weight: 400;
  margin: 0;
  text-wrap: balance;
}
.spread-title em { font-style: italic; }

.spread-desc {
  max-width: 36ch;
  color: var(--ink-soft);
  font-size: 14px;
  line-height: 1.85;
  margin: 0;
}
.spread.dark .spread-desc { color: rgba(255,255,255,0.75); }

.spread-stat {
  display: grid;
  grid-template-columns: auto auto;
  gap: 22px 30px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
}
.spread.dark .spread-stat { border-top-color: rgba(255,255,255,0.18); color: rgba(255,255,255,0.6); }
.spread-stat span:nth-child(even) {
  color: var(--ink);
  font-family: var(--serif);
  font-style: italic;
  font-size: 16px;
  letter-spacing: -0.01em;
  text-transform: none;
}
.spread.dark .spread-stat span:nth-child(even) { color: #FFFFFF; }

/* Asymmetric sub-grid — varied collage patterns, all images STRAIGHT */
.spread-subs {
  display: grid;
  gap: clamp(24px, 3vw, 50px);
  position: relative;
}
.spread-sub {
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: opacity 0.6s var(--ease), transform 0.7s var(--ease);
}
.spread-sub .frame-wrap {
  overflow: hidden;
  position: relative;
}
.spread-sub .ph {
  width: 100%;
  height: 100%;
  transition: transform 1.2s var(--ease), filter 0.6s var(--ease);
}
.spread-sub:hover .ph { transform: scale(1.05); }
.spread-sub:hover { transform: translateY(-6px); }
.spread-subs:hover .spread-sub:not(:hover) { opacity: 0.55; }
.spread-subs:hover .spread-sub:not(:hover) .ph { filter: grayscale(1); }

/* Pattern A — 4 subs: portrait + stepped descending */
.spread-subs.pa { grid-template-columns: 1.15fr 1fr; }
.spread-subs.pa .sb-1 { margin-top: 0; }
.spread-subs.pa .sb-1 .frame-wrap { aspect-ratio: 4 / 5; }
.spread-subs.pa .sb-2 { margin-top: 80px; }
.spread-subs.pa .sb-2 .frame-wrap { aspect-ratio: 3 / 4; }
.spread-subs.pa .sb-3 { margin-top: 20px; }
.spread-subs.pa .sb-3 .frame-wrap { aspect-ratio: 5 / 4; }
.spread-subs.pa .sb-4 { margin-top: -40px; }
.spread-subs.pa .sb-4 .frame-wrap { aspect-ratio: 3 / 4; }

/* Pattern B — 4 subs: tall left + grouped right */
.spread-subs.pb { grid-template-columns: 1fr 1.2fr; }
.spread-subs.pb .sb-1 { margin-top: 60px; }
.spread-subs.pb .sb-1 .frame-wrap { aspect-ratio: 3 / 4.3; }
.spread-subs.pb .sb-2 { margin-top: 0; }
.spread-subs.pb .sb-2 .frame-wrap { aspect-ratio: 4 / 5; }
.spread-subs.pb .sb-3 { margin-top: -30px; }
.spread-subs.pb .sb-3 .frame-wrap { aspect-ratio: 4 / 5; }
.spread-subs.pb .sb-4 { margin-top: 30px; }
.spread-subs.pb .sb-4 .frame-wrap { aspect-ratio: 5 / 4; }

/* Pattern C — 3 subs: wave / staircase */
.spread-subs.pc { grid-template-columns: repeat(3, 1fr); }
.spread-subs.pc .sb-1 { margin-top: 0; }
.spread-subs.pc .sb-1 .frame-wrap { aspect-ratio: 3 / 4; }
.spread-subs.pc .sb-2 { margin-top: 120px; }
.spread-subs.pc .sb-2 .frame-wrap { aspect-ratio: 3 / 4.5; }
.spread-subs.pc .sb-3 { margin-top: 40px; }
.spread-subs.pc .sb-3 .frame-wrap { aspect-ratio: 3 / 4; }

/* Pattern D — 3 subs: one large + two stacked */
.spread-subs.pd { grid-template-columns: 1.4fr 1fr; grid-auto-rows: auto; }
.spread-subs.pd .sb-1 { grid-row: span 2; margin-top: 0; }
.spread-subs.pd .sb-1 .frame-wrap { aspect-ratio: 4 / 5.2; }
.spread-subs.pd .sb-2 { margin-top: 30px; }
.spread-subs.pd .sb-2 .frame-wrap { aspect-ratio: 5 / 4; }
.spread-subs.pd .sb-3 { margin-top: 30px; }
.spread-subs.pd .sb-3 .frame-wrap { aspect-ratio: 5 / 4; }

.spread-sub-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 14px 8px 0;
}
.spread-sub-meta h3 {
  font-family: var(--serif);
  font-style: italic;
  font-size: var(--t-h2);
  font-weight: 400;
  margin: 0;
}
.spread-sub-meta .n {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--muted);
}
.spread-sub .stag {
  padding: 0 8px;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.spread.dark .spread-sub-meta .n { color: rgba(255,255,255,0.5); }
.spread.dark .spread-sub .stag { color: rgba(255,255,255,0.7); }

.spread-sub .stag-line {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  padding: 0 8px;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
}
.spread.dark .spread-sub .stag-line { color: #FFFFFF; }
.spread-sub:hover .stag-line { opacity: 1; transform: translateY(0); }

/* Issue separator — between spreads, mimic page-break */
.issue-break {
  text-align: center;
  padding: 28px 0;
  display: flex;
  align-items: center;
  gap: 30px;
  justify-content: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--muted);
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.issue-break .l {
  flex: 1;
  height: 1px;
  background: var(--line);
  max-width: 240px;
}

@media (max-width: 1000px) {
  .spread-grid { grid-template-columns: 1fr; }
  .spread-side { position: static; }
  .spread-subs.pa, .spread-subs.pb { grid-template-columns: 1fr 1fr; }
  .spread-subs.pc { grid-template-columns: repeat(3, 1fr); }
  .spread-subs.pd { grid-template-columns: 1.4fr 1fr; }
  .spread-volume { font-size: clamp(80px, 16vw, 160px); }
}
@media (max-width: 640px) {
  .spread-subs.pa, .spread-subs.pb, .spread-subs.pc, .spread-subs.pd { grid-template-columns: 1fr; }
  .spread-sub { margin-top: 0 !important; }
  .spread-sub .frame-wrap { aspect-ratio: 4 / 5 !important; }
  .spread-subs.pd .sb-1 { grid-row: auto; }
}

/* ============================================================
   Motion / UX FX
   ============================================================ */

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* Scroll progress bar (top) */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 2px;
  background: var(--ink);
  transform-origin: left center;
  transform: scaleX(0);
  z-index: 90;
  pointer-events: none;
  mix-blend-mode: difference;
}

/* Cursor follower — not bundled with this theme, so keep the native cursor. */
@media (pointer: fine) {
  a, button, .cc, .d-tile, .spread-sub, .faq-item .q, .vol-item, .frame, .ct-chip, .cp-sub,
  [data-nav-to], [data-fq-tab], .nav-burger, .btn, .nav-link, .nav-cta, .link-arrow { cursor: pointer; }
  input, textarea, select { cursor: auto; }
}
.cursor-outer {
  position: fixed;
  top: 0; left: 0;
  width: 36px; height: 36px;
  border: 1px solid var(--ink);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transition: width 0.35s var(--ease), height 0.35s var(--ease), background 0.35s var(--ease), border-color 0.35s var(--ease), opacity 0.3s var(--ease);
  mix-blend-mode: difference;
  border-color: #FFFFFF;
}
.cursor-outer.on {
  width: 64px; height: 64px;
  background: rgba(255,255,255,0.06);
}
.cursor-outer.with-label {
  width: 96px; height: 96px;
  background: var(--ink);
  border-color: var(--ink);
  mix-blend-mode: normal;
}
.cursor-outer.down {
  width: 24px; height: 24px;
  background: var(--ink);
}
.cursor-inner {
  position: fixed;
  top: 0; left: 0;
  width: 4px; height: 4px;
  background: #FFFFFF;
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: difference;
  font-family: var(--sans);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #FFFFFF;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
}
@media (pointer: coarse) {
  .cursor-outer, .cursor-inner { display: none; }
  body, a, button { cursor: auto; }
}

/* Page transition overlay */
.page-transition {
  position: fixed;
  inset: 0;
  z-index: 95;
  background: var(--ink);
  transform: translateY(100%);
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-transition.in {
  animation: pageSweepIn 0.55s cubic-bezier(0.7, 0, 0.2, 1) forwards;
}
.page-transition.out {
  animation: pageSweepOut 0.55s cubic-bezier(0.7, 0, 0.2, 1) forwards;
}
.page-transition-label {
  color: var(--ivory);
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(36px, 6vw, 80px);
  opacity: 0;
  transform: translateY(20px);
  letter-spacing: -0.01em;
}
.page-transition.in .page-transition-label {
  animation: ptLabel 0.55s 0.1s var(--ease) forwards;
}
@keyframes pageSweepIn {
  from { transform: translateY(100%); }
  to   { transform: translateY(0%); }
}
@keyframes pageSweepOut {
  from { transform: translateY(0%); }
  to   { transform: translateY(-100%); }
}
@keyframes ptLabel {
  0% { opacity: 0; transform: translateY(20px); }
  40% { opacity: 1; transform: translateY(0); }
  100% { opacity: 0; transform: translateY(-12px); }
}

/* Scroll Reveal — applied via data-reveal */
[data-reveal] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1s var(--ease), transform 1s var(--ease), filter 1s var(--ease);
  filter: blur(2px);
}
[data-reveal].in-view {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
[data-reveal="image"] {
  transform: scale(1.05);
  filter: brightness(0.95);
}
[data-reveal="image"].in-view {
  transform: scale(1);
  filter: brightness(1);
}
[data-reveal="left"] {
  transform: translateX(-30px);
}
[data-reveal="left"].in-view {
  transform: translateX(0);
}
[data-reveal="right"] {
  transform: translateX(30px);
}
[data-reveal="right"].in-view {
  transform: translateX(0);
}
[data-reveal-delay="1"] { transition-delay: 0.08s; }
[data-reveal-delay="2"] { transition-delay: 0.16s; }
[data-reveal-delay="3"] { transition-delay: 0.24s; }
[data-reveal-delay="4"] { transition-delay: 0.32s; }
[data-reveal-delay="5"] { transition-delay: 0.4s; }
[data-reveal-delay="6"] { transition-delay: 0.48s; }

/* Split text */
.split { display: inline-block; }
.split-char {
  display: inline-block;
  opacity: 0;
  transform: translateY(60%);
  animation: charIn 0.9s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@keyframes charIn {
  to { opacity: 1; transform: translateY(0); }
}

/* Magnetic */
.magnetic {
  display: inline-block;
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.3, 1);
  will-change: transform;
}

/* Parallax helper */
.parallax-wrap { will-change: transform; transform: translateY(var(--parallax-y, 0)); transition: none; }

/* Refine hero — parallax background */
.hero-bg .ph { will-change: transform; }

/* Link underline animation refresh */
.link-arrow {
  position: relative;
  overflow: hidden;
}
.link-arrow span:first-child {
  display: inline-block;
  transition: transform 0.5s var(--ease);
}
.link-arrow:hover span:first-child {
  transform: translateY(-2px);
}

/* Smooth button text on hover — slight shift */
.btn span:first-child {
  display: inline-block;
  transition: transform 0.5s var(--ease);
}
.btn:hover span:first-child {
  transform: translateX(-2px);
}

/* Section-head label hairline already animates; refine for entering view */
[data-reveal] .section-head .label::after,
.section-head .label::after {
  transform: scaleX(0);
}
[data-reveal].in-view .section-head .label::after,
.section-head.in-view .label::after {
  animation: lineReveal 0.9s 0.2s var(--ease) forwards;
}

/* Marquee soft fade edges */
.marquee {
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}

/* Hide cursor follower when over inputs (let native caret show) */
input, textarea { cursor: text !important; }

/* ============================================================
   Responsive polish — missing breakpoints, mobile cleanup
   ============================================================ */

/* About grid was missing a mobile breakpoint */
@media (max-width: 900px) {
  .about-grid { grid-template-columns: 1fr; gap: 50px; }
  .about-image-stack .ph.tall { grid-row: span 1; margin-top: 0; }
}

/* Footer was 4-col with no breakpoint */
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .footer-base { flex-direction: column; gap: 16px; text-align: center; }
}

/* Page hero paddings (top was 180px on mobile too — too much) */
.cp-hero, .pp-hero, .st-hero, .fq-page, .ct-page {
  padding-top: clamp(110px, 14vw, 160px);
}
.cp-hero { padding-bottom: 50px; }

/* Hero: cap hero-title at clean breakpoints */
.hero {
  padding: clamp(100px, 14vw, 140px) var(--gutter) clamp(40px, 6vw, 70px);
  min-height: 100svh;
}
.hero-title { margin-bottom: 0; }

/* Section heads: shorter h2 + better alignment */
.section-head { margin-bottom: clamp(40px, 6vw, 70px); }
.section-head .lhs { max-width: 24ch; }

/* Spread side stat: smaller on mobile, switch to single col */
.spread-stat { font-size: 10px; gap: 14px 24px; }
.spread-stat span:nth-child(even) { font-size: 14px; }

/* Spread folio: allow wrapping cleanly */
.spread-folio { flex-wrap: wrap; gap: 12px 24px; }

/* Pricing tier image: don't lock huge max-height on mobile */
@media (max-width: 900px) {
  .pp-tier-image { padding: 30px; }
  .pp-tier-image .ph { max-height: none; aspect-ratio: 4 / 5; }
  .pp-tier-body { padding: 40px 28px; }
}

/* Premium hero — adjust mobile */
@media (max-width: 700px) {
  .pv-hero { min-height: 80vh; }
  .pv-hero-meta { flex-direction: column; align-items: flex-start; }
  .pv-signature { font-size: 22px; white-space: normal; max-width: 100%; overflow-wrap: break-word; }
}

/* Premium gallery: simpler on mobile */
@media (max-width: 900px) {
  .pv-gallery { grid-template-columns: 1fr 1fr; grid-auto-rows: 200px; }
  .pv-gallery > * { grid-column: span 1 !important; grid-row: span 1 !important; }
  .pvg1, .pvg4, .pvg5 { grid-row: span 2 !important; }
}
@media (max-width: 560px) {
  .pv-gallery { grid-template-columns: 1fr; }
  .pv-gallery > * { grid-row: auto !important; aspect-ratio: 4 / 5; }
}

/* Story hero meta: stack stats nicely */
@media (max-width: 700px) {
  .st-meta { gap: 30px; }
  .st-meta > div { min-width: 45%; }
}

/* Contact form: better padding on mobile */
@media (max-width: 700px) {
  .ct-form { padding: 30px 24px; }
}

/* Concept hero: better mobile rhythm */
@media (max-width: 700px) {
  .cp-hero { gap: 30px; padding-bottom: 30px; }
}

/* Pricing hero meta — wrap cleanly */
.pp-hero .lede { font-size: 15px; }

/* Container max width respect */
.container { max-width: var(--max); }

/* Tighten section-pad on mobile */
@media (max-width: 700px) {
  .section-pad { padding-block: clamp(56px, 12vw, 90px); }
  .section-pad-sm { padding-block: clamp(48px, 10vw, 72px); }
  .spread { padding: clamp(56px, 10vw, 90px) var(--gutter); }
  .pv-section { padding: clamp(56px, 10vw, 90px) var(--gutter); }
  .pv-booking { padding: clamp(60px, 12vw, 100px) var(--gutter); }
}

/* Pricing rows: better spacing on small */
@media (max-width: 560px) {
  .pp-row { grid-template-columns: 1fr; gap: 6px; padding: 16px 0; }
  .pp-actions { flex-direction: column; align-items: flex-start; gap: 16px; }
  .pp-actions .btn { width: 100%; justify-content: space-between; }
}

/* Service rows on home (legacy if used) */
@media (max-width: 560px) {
  .services-grid { padding: 20px 0; gap: 12px; }
}

/* Hero buttons stack on small */
@media (max-width: 560px) {
  .hero-bottom { gap: 24px; }
  .hero-meta .h-mono { display: none; }
}

/* Concept folio: hide middle on small */
@media (max-width: 600px) {
  .spread-folio span:nth-child(2) { display: none; }
}

/* Story chapter: tighter image at small */
@media (max-width: 700px) {
  .st-chap-image .ph { aspect-ratio: 4 / 5; }
}

/* Testimonial box: stack image + quote on mobile */
@media (max-width: 800px) {
  .box .testi { grid-template-columns: 1fr !important; }
  .box .testi .testi-image .ph { aspect-ratio: 4 / 3; min-height: 0 !important; }
}

/* Process step border-right on full row when 2-col */
@media (max-width: 900px) and (min-width: 561px) {
  .process-step:nth-child(2n) { border-right: none; }
}

/* Concept Detail grid: smaller rows on mobile */
@media (max-width: 700px) {
  .cp-detail-grid { grid-auto-rows: 140px; gap: 10px; }
}

/* Marquee tighter */
@media (max-width: 600px) {
  .marquee-track { gap: 30px; }
  .marquee-track span { gap: 30px; }
}

/* Cleaner small-screen page-hero */
@media (max-width: 700px) {
  .cp-hero, .pp-hero, .st-hero { padding-left: var(--gutter); padding-right: var(--gutter); }
  .pp-hero .lede, .cp-hero .lede { margin-top: 24px; }
}

/* Hero title: tighter on mobile (already via var, but ensure no overflow) */
.hero-title { hyphens: none; word-break: keep-all; }

/* Vol-index list shouldn't crowd on small */
@media (max-width: 700px) {
  .vol-list { padding-bottom: 8px; }
  .vol-item { padding: 14px 14px; }
}

/* Page transition label smaller on mobile */
@media (max-width: 600px) {
  .page-transition-label { font-size: 36px; }
}

/* Cursor follower: smaller on tablet */
@media (max-width: 900px) and (pointer: fine) {
  .cursor-outer { width: 28px; height: 28px; }
  .cursor-outer.on { width: 48px; height: 48px; }
}

/* Hide cursor follower entirely on touch */
@media (pointer: coarse) {
  .cursor-outer, .cursor-inner { display: none !important; }
  body, * { cursor: auto !important; }
}




